前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >使用Log4J来作为Spring Boot的日志系统

使用Log4J来作为Spring Boot的日志系统

作者头像
白石
发布2019-08-23 10:29:47
4220
发布2019-08-23 10:29:47
举报
文章被收录于专栏:白石

1. 修改build.gradle

排除掉对logback的依赖,添加对log4j的依赖

代码语言:javascript
复制
dependencies {
	compile('org.springframework.boot:spring-boot-starter-web') {
		exclude group: 'org.springframework.boot', module: 'spring-boot-starter-logging' 
	}
	compile('org.slf4j:slf4j-api')
	compile('org.slf4j:slf4j-log4j12')
	compile('commons-logging:commons-logging')

}

2.设置定log4j的配置文件位置,例如:

log4j-dev.xml文件放到src/main/resources目录下,然后在application.properties文件里设置

代码语言:javascript
复制
logging.config=classpath:log4j-dev.xml

3. 在Spring Boot的启动类里用代码手动加载log4j,例如:

代码语言:javascript
复制
@SpringBootApplication
public class Application implements EnvironmentAware {

	private Environment env;

	@Value('${logging.config}')
	private String log4jName;

	public static void main(String[] args) {
		SpringApplication.run(Application.class, args);
	}

	@Override
	public void setEnvironment(Environment environment) {
		this.env = environment;
		String[] dProfiles = env.getDefaultProfiles();
		String[] aProfiles = env.getActiveProfiles();

		System.out.println("Spring DefaultProfiles:" + java.util.Arrays.asList(dProfiles));
		System.out.println("Spring ActiveProfiles:" + java.util.Arrays.asList(aProfiles));
		if (aProfiles.length == 0) {
			System.out.println("Please set 'spring.profiles.active'");
			System.exit(-1);
		}

		//加载Log4J配置文件
		DOMConfigurator.configure(org.springframework.util.ResourceUtils.getURL(log4jName));
		Logger log = LoggerFactory.getLogger(this.getClass());

		log.info("当前ActiveProfiles:"+env.getActiveProfiles().toString());
	}
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 修改build.gradle
  • 2.设置定log4j的配置文件位置,例如:
  • 3. 在Spring Boot的启动类里用代码手动加载log4j,例如:
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档