java启动时如何自定义配置文件路径和log4j2.xml位置
这篇文章主要介绍“java启动时如何自定义配置文件路径和log4j2.xml位置”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“java启动时如何自定义配置文件路径和log4j2.xml位置”文章能帮助大家解决问题。
创新互联公司是一家集网站建设,石嘴山企业网站建设,石嘴山品牌网站建设,网站定制,石嘴山网站建设报价,网络营销,网络优化,石嘴山网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。
java启动时自定义配置文件路径,自定义log4j2.xml位置
启动时指定配置文件位置
项目打成jar包后,配置文件会一起打包到jar包的classes下,这就是所说的classpath。比如spring boot 就是在jar\BOOT-INF\classes下
然后在jar文件运行时,就会自动去jar文件内找配置文件,这对我们部署服务是不利的,通常都是将配置文件放在外面,方便修改配置内容。
有一种说法:说配置文件加载顺序为(由高到低)
jar包同级目录下的config文件夹下配置
jar包同级目录下配置
classpath下config目录下配置
classpath下配置
经验证
application.properties 或者 application.yml 是上面的加载顺序,但是我在搭建spring boot 项目时 【jar包同级目录下的config文件夹下配置】优先级是 > 【classpath下配置】,但是 【jar包同级目录下配置】优先级并没有【classpath下配置】的高。。不知为何。不过把配置文件放到 jar包同级目录下的config文件夹是能够解决需求的。
后来又发现一个问题
外部log4j2.xml 加载不到,不管是放在jar同级目录,还是jar包同级目录下的config,都不起作用,每次启动都加在 jar包内的log4j2.xml ,查了很多资料都说不到点上。
后面终于找到解决办法了,就是在启动jar文件的时候手动加载,如下(start.sh内容)
name="my-web" pid=`ps -ef | grep ${name} | grep -v grep |awk '{print $2}'` if [ $pid ]; then echo ${name} is running pid=$pid kill -9 $pid fi nohup java -Xms100m -Xmx100m -jar ../${name}-0.0.1-SNAPSHOT.jar --logging.config=../config/log4j2.xml > ../logs/${name}.log & tail -f ../logs/${name}.log
就是加上 【--logging.config=config/log4j2.xml】 来制定加载的 log4j2.xml
如果启动不了
pom 可能没有加上依赖
org.springframework.boot spring-boot-starter org.springframework.boot spring-boot-starter-logging org.springframework.boot spring-boot-starter-log4j2
最后附上整个文件的目录结构
my-web ----bin ----start.sh ----stop.sh ----config ----log4j2.xml ----application.yml ----application.properties ----logs ----my-web.jar
java服务启动指定配置文件路径
关于“java启动时如何自定义配置文件路径和log4j2.xml位置”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注创新互联行业资讯频道,小编每天都会为大家更新不同的知识点。
网页题目:java启动时如何自定义配置文件路径和log4j2.xml位置
转载注明:http://pcwzsj.com/article/jhschj.html