dubbo框架生产者不打印错误日志解决办法
最近在改造公司的项目架构 --我可不是公司的架构师我就是一普通的码农因为是采用的阿里提供的Main类来启动的生产者没有使用Tomcat 等容器所用发现生产者产生异常了根本就没在控制台输出因为公司使用的slf4j来输出日志的所以一番百度过后决定采用logback来输出生产者的错误日志首先引入依赖的包 <dependency>
最近在改造公司的项目架构 --我可不是公司的架构师我就是一普通的码农
因为是采用的阿里提供的Main类来启动的生产者没有使用Tomcat 等容器所用发现生产者产生异常了根本就没在控制台输出
因为公司使用的slf4j来输出日志的所以一番百度过后决定采用logback来输出生产者的错误日志
首先引入依赖的包
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-core</artifactId>
<version>1.1.7</version>
</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.1.7</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.21</version>
</dependency>
然后在resources根目录下现在一个logback.xml
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<!--定义日志文件的存储地址 勿在 LogBack 的配置中使用相对路径 -->
<property name="LOG_HOME" value="logs" />
<!-- 控制台输出 -->
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符 -->
<pattern>%-4relative [%thread] %-5level %logger{35} - %msg%n</pattern>
</encoder>
</appender>
<!-- 按照每天生成日志文件 -->
<appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!--日志文件输出的文件名 -->
<FileNamePattern>${LOG_HOME}/%d{yyyy-MM-dd}.log</FileNamePattern>
<!--日志文件保留天数 -->
<MaxHistory>2</MaxHistory>
</rollingPolicy>
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符 -->
<pattern>%-4relative [%thread] %-5level %logger{35} - %msg%n</pattern>
</encoder>
<!--日志文件最大的大小 -->
<triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">
<MaxFileSize>5MB</MaxFileSize>
</triggeringPolicy>
</appender>
<!-- 日志输出级别 -->
<root level="ERROR">
<appender-ref ref="STDOUT" />
</root>
</configuration>
蓝色表示可以修改
如果要自定义logback.xml的路劲需要在入口类中自己去读取logback.xml
使用log4j还是slf4j最简单的配置策略可以在<dubbo:application logger="slf4j"/>中指定默认是log4j
更多推荐
所有评论(0)