我正在使用 spring-boot-starter
,并想要配置 log4j2.xml
以异步记录不同内容到不同的日志文件。
我已经创建了 log4j2 文件,但是 Spring
仍然使用 spring-boot 的默认日志记录。如何切换日志记录?
我正在使用 spring-boot-starter
,并想要配置 log4j2.xml
以异步记录不同内容到不同的日志文件。
我已经创建了 log4j2 文件,但是 Spring
仍然使用 spring-boot 的默认日志记录。如何切换日志记录?
我有更好的方式:
排除 logback 日志记录器:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
</exclusion>
</exclusions>
</dependency>
添加log4j2引导器:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-log4j2</artifactId>
</dependency>
祝愉快!
试试这个:
排除 spring-boot-starter-logging,例如:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
</exclusion>
</exclusions>
</dependency>
为您的日志记录接口添加依赖项,例如 slf4j
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-slf4j-impl</artifactId>
<version>2.0.2</version>
</dependency>
添加指向所选日志接口的其他日志记录实现,例如:
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>jcl-over-slf4j</artifactId>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>jul-to-slf4j</artifactId>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>log4j-over-slf4j</artifactId>
</dependency>
添加您的目标日志记录实现,例如:
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-api</artifactId>
<version>2.0.2</version>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>2.0.2</version>
</dependency>
而且它应该能够正常工作。
spring-boot-starter-log4j2
。这只是作为参考信息。 - membersound这是对我有效的解决方案。需要添加两个额外的排除项,否则应用程序无法捕获log4j并会出现冲突。
实际绑定类型为[ch.qos.logback.classic.util.ContextSelectorStaticBinder]
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.0.0</version>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
</exclusion>
<exclusion>
<artifactId>logback-classic</artifactId>
<groupId>ch.qos.logback</groupId>
</exclusion>
<exclusion>
<artifactId>log4j-over-slf4j</artifactId>
<groupId>org.slf4j</groupId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-log4j2</artifactId>
</dependency>
</exclusions> - vsingh
configurations.all*.exclude group: 'org.springframework.boot', module: 'spring-boot-starter-logging'
然后在我的dependencies{}部分中添加runtime 'org.springframework.boot:spring-boot-starter-log4j2'
- Eric