首页后端开发PHPjava启动时如何自定义配置文件路径和log4j2.xml位置

java启动时如何自定义配置文件路径和log4j2.xml位置

时间2023-07-06 23:01:01发布访客分类PHP浏览743
导读:这篇文章主要介绍“java启动时如何自定义配置文件路径和log4j2.xml位置”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“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-vgrep|awk'{
    print$2}
        '`
    if[$pid];
    then
    echo${
    name}
    isrunningpid=$pid
    kill-9$pid
    fi
    nohupjava-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 可能没有加上依赖

    !--日志依赖-->
        
    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>
        
    
    dependency>
        
    groupId>
        org.springframework.boot/groupId>
        
    artifactId>
        spring-boot-starter-log4j2/artifactId>
        
    /dependency>
        

    最后附上整个文件的目录结构

    my-web
    ----bin
    ----start.sh
    ----stop.sh
    ----config
    ----log4j2.xml
    ----application.yml
    ----application.properties
    ----logs
    ----my-web.jar

    java服务启动指定配置文件路径

    关于“java启动时如何自定义配置文件路径和log4j2.xml位置”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注行业资讯频道,小编每天都会为大家更新不同的知识点。

    声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

    javalog4j2.xml

    若转载请注明出处: java启动时如何自定义配置文件路径和log4j2.xml位置
    本文地址: https://pptw.com/jishu/292670.html
    vue如何获取点击dom对象 Java中如何实现让线程按照自己指定的顺序执行

    游客 回复需填写必要信息