Springboot允许logger.debug输出日志方式

目录
  • Springboot允许logger.debug输出日志
  • SpringBoot启动debug级别日志报错
    • 错误截图
    • 原因
    • 解决办法

Springboot允许logger.debug输出日志

说实话对日志这东西一直只是太肤浅的懂,就会用logger.info和logger.error输出,今天在写LemonRobot项目的时候,决定把调试信息也打出来,然后根据日志级别控制让上线的时候不显示debug级别的日志。

但是运行后发现,默认logger.debug产生的日志也没有输出到控制台,经过一番研究,是由于logback的配置问题。

在sr/main/resources文件夹中新建logback.xml,然后复制下面的配置到文件中:

logback.xml会被自动加载,如果名字不一样,我们需要在application.yml或者是application.properties中配置:

#配置日志
logging:
#此处存放日志的路径
  path:
    config: classpath:config/logback-spring.xml
#指定不同目录下的日志的级别
  level:
    com.shimain.springboot.mapper: DEBUG
<?xml version="1.0" encoding="UTF-8" ?>

<configuration scan="true" scanPeriod="3 seconds">
    <!--设置日志输出为控制台-->
    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%-5level] [%logger{32}] %msg%n</pattern>
        </encoder>
    </appender>
    <!--设置日志输出为文件-->
    <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <File>logFile.log</File>
        <rollingPolicy  class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <FileNamePattern>logFile.%d{yyyy-MM-dd_HH-mm}.log.zip</FileNamePattern>
        </rollingPolicy>
        <layout class="ch.qos.logback.classic.PatternLayout">
            <Pattern>%d{HH:mm:ss,SSS} [%thread] %-5level %logger{32} - %msg%n</Pattern>
        </layout>
    </appender>
    <root>
        <level value="DEBUG"/>
        <appender-ref ref="STDOUT"/>
        <appender-ref ref="FILE"/>
    </root>
</configuration>

这段配置文件可以让日志同时输出到控制台和本地文件,同时将日志文件打成zip压缩包。

如果这个时候项目上线了,不需要debug日志了,只需要修改root标签下面的level级别为INFO即可。

SpringBoot启动debug级别日志报错

Tomcat Native library could not be found using names [tcnative-1, libtcnative-1]

错误截图

原因

tomcat没有找到JNI动态链接库。Apache Tomcat下是有这个dll的,但是启动时在Springboot中内嵌Tomcat下没有找到。

这是因为Tomcat中的connector为了提高性能,采用了加载与操作系统绑定(非跨平台)的本地库的方式,比如Windows系统中就是.dll动态链接库。

上述异常中找不到的两个.dll库文件,默认会去Tomcat的bin目录下去找,但是由于SpringBoot的Tomcat是嵌入式的,没有这两个.dll。

解决办法

可以忽略这个报错,因此SpringBoot把这个错误的日志级别设置为debug。

如果有强迫症者,也可以按如下方式解决:

直接将tomcat下的tcnative-1.dll和libtcnative-1.dll放到C:\Windows\System32下,重新启动项目即可。

可到官方地址下载。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • SpringBoot log打印及输出方式

    目录 SpringBoot log打印及输出 导入jar包 代码示例 日志输出配置 springboot切面技术打印log日志 mvaen 准备 还有spring家族的 创建 WebLogAcpect 类 配置log4j SpringBoot log打印及输出 导入jar包 import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; 代码示例 private final Log log

  • SpringBoot日志框架如何使用

    不管是开发过程中调试还是线上问题的定位追踪,日志都发挥着及其重要的作用.平时,我们会用System.out.println()打印一些信息到控制台,我们可以使用该语句输出日志,但是System.out会增加资源的消耗,所以最好使用日志框架打印日志信息. Java中的日志框架有JCL.Jboss-logging.slf4j.logback.log4j.log4j2等等,其中JCL.Jboss-logging.slf4j属于日志门面(日志的抽象),logback.log4j.log4j2是日志框架的

  • Spring Boot 日志配置方法(超详细)

    默认日志 Logback : 默认情况下,Spring Boot会用Logback来记录日志,并用INFO级别输出到控制台.在运行应用程序和其他例子时,你应该已经看到很多INFO级别的日志了. 从上图可以看到,日志输出内容元素具体如下: 时间日期:精确到毫秒 日志级别:ERROR, WARN, INFO, DEBUG or TRACE 进程ID 分隔符:- 标识实际日志的开始 线程名:方括号括起来(可能会截断控制台输出) Logger名:通常使用源代码的类名 日志内容 添加日志依赖 假如mave

  • springboot使用Logback把日志输出到控制台或输出到文件

    一:日志: 1.配置日志级别 日志记录器(Logger)的行为是分等级的.如下表所示: 分为:OFF.FATAL.ERROR.WARN.INFO.DEBUG.ALL 默认情况下,spring boot从控制台打印出来的日志级别只有INFO及以上级别,可以配置日志级别 设置日志级别 logging.level.root=WARN 这种方式只能将日志打印在控制台上 二.Logback日志 spring boot内部使用Logback作为日志实现的框架. Logback和log4j非常相似,如果你对l

  • Springboot允许logger.debug输出日志方式

    目录 Springboot允许logger.debug输出日志 SpringBoot启动debug级别日志报错 错误截图 原因 解决办法 Springboot允许logger.debug输出日志 说实话对日志这东西一直只是太肤浅的懂,就会用logger.info和logger.error输出,今天在写LemonRobot项目的时候,决定把调试信息也打出来,然后根据日志级别控制让上线的时候不显示debug级别的日志. 但是运行后发现,默认logger.debug产生的日志也没有输出到控制台,经过一

  • logback输出日志屏蔽quartz的debug等级日志方式

    目录 logback输出日志屏蔽quartz的debug等级日志 解决方法 quartz关闭DBUG日志 把他的log级别改成 ERROR 或者索性 logback输出日志屏蔽quartz的debug等级日志 在一个spring的老项目中,使用了logback来作为日志管理,logback.xml中已经设定日志输出等级为INFO,但是quartz的日志还是debug级别在输出,导致日志内容很多很乱 解决方法 在标签内加上,如: <configuration debug="false&quo

  • springboot如何去除debug日志

    目录 springboot去除控制台打印的debug日志 1.创建logback-spring.xml文件 2.给application.properties文件 无法控制springboot中的debug日志 问题 最后试了一下,这样解决的 springboot去除控制台打印的debug日志 1.创建logback-spring.xml文件 文件内容如下 <?xml version="1.0" encoding="UTF-8"?> <config

  • SpringBoot多环境开发与日志小结

    前置导入 什么是多环境?其实就是说你的电脑上写的程序最终要放到别人的服务器上去运行.每个计算机环境不一样,这就是多环境.常见的多环境开发主要兼顾3种环境设置,开发环境——自己用的,测试环境——自己公司用的,生产环境——甲方爸爸用的.因为这是绝对不同的三台电脑,所以环境肯定有所不同,比如连接的数据库不一样,设置的访问端口不一样等等. 多环境开发(yaml单一文件版) 那什么是多环境开发?就是针对不同的环境设置不同的配置属性即可.比如你自己开发时,配置你的端口如下: server: port: 80

  • SpringBoot 2.x整合Log4j2日志的详细步骤

    目录 概述 整合步骤 Log4j2配置详解 根节点configuration 子节点Properties 子节点Appenders 子节点Loggers 总结 参考 概述 公司的spring boot项目不是使用默认的logback作为日志框架,而是log4j2, 主要原因是logback出现过一个生产问题导致,具体什么问题难以追溯了.本文主要讲解下SpringBoot 2.x如何更换springboot的日志框架为log4j2, 以及log4j2的配置. 整合步骤 本次演示采用的springb

  • Springboot项目使用Slf4j将日志保存到本地目录的实现代码

    1.引入jar包 <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> <version>1.7.25</version> </dependency> 2.编写application.properties/yml #.properties logging.config= classpath:logback-spr

  • python 实现logging动态变更输出日志文件名

    python作为一门非常容易上手的脚本语言,日志输出更是简单,logging模块,简单的设置配置和属性,就能实现到控制台输出日志,在basicConfig()设置文件名,就能够将日志信息写入文件,简直是简单到不能再简单. 最近在项目中就遇到一个日志问题,使用python编写的服务程序一直运行,连续处理一些任务,每个任务的关键信息都需要输出到文件中,便于维护人员查看,可是对于简单实用logging来说,日志写入文件非常简单,由于服务程序连续运行,一直向一个文件记录日志信息有些不妥,有常识的开发人员

  • dubbo 如何使用logback来输出日志

    dubbo logback输出日志 两者皆为国内使用比较广的两个开源框架:一个是服务治理框架,另一个则是日志框架.这个问题的解决方案一部分就在dubbo官网上: dubbo的日志适配 缺省自动查找: log4j slf4j jcl jdk 可以通过以下方式配置日志输出策略: java -Ddubbo.application.logger=log4j dubbo.properties dubbo.application.logger=log4j dubbo.xml <dubbo:applicati

  • SpringBoot开发教程之AOP日志处理

    目录 日志处理: 需求分析 实现过程: 实验效果: 参考文献: 总结 日志处理: 需求分析 日志处理需要记录的是: 请求的URL 访问者IP 调用的方法 传入的参数 返回的内容 上面的内容要求在控制台和日志中输出. 在学习这部分知识的时候,真的感觉收获很多,在之前Spring学习的aop只是初步了解,现在有了一些深入的理解.好记性不如烂笔头! 在日志处理这部分主要是aop的使用,通过切面的方式来整合到项目了,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开发的效率. 人话

随机推荐