程序中设置logback以及Jar包启动

logback.xml 放入resources目录下:
<?xml version="1.0" encoding="UTF-8"?>
<configuration>

    <timestamp key="ymd" datePattern="yyyy-MM-dd"/>
    <timestamp key="byMillionSecond" datePattern="HH_mm_ss.SSS"/>
    <property name="LOG_FILE" value="./logs/info"/>

    <!-- 控制台输出 -->
    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{0} - %msg%n
            </pattern>
        </encoder>
    </appender>

    <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <!-- 正在记录的日志文档的路径及文档名 -->
        <file>${LOG_FILE}-info.log</file>
        <!--日志文档输出格式-->
        <encoder>
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [requestId-%X{requestId}] [%thread] %-5level %logger{50} - %msg%n
            </pattern>
            <charset>UTF-8</charset>
        </encoder>
        <!-- 日志记录器的滚动策略,按日期,按大小记录 -->
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!-- 每天日志归档路径以及格式 -->
            <fileNamePattern>${LOG_FILE}-info-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
            <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                <maxFileSize>100MB</maxFileSize>
            </timeBasedFileNamingAndTriggeringPolicy>
            <!--日志文档保留天数-->
            <maxHistory>3</maxHistory>
        </rollingPolicy>
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <level>info</level>
            <onMatch>ACCEPT</onMatch>
            <onMismatch>ACCEPT</onMismatch>
        </filter>
    </appender>




    <root level="INFO">
        <appender-ref ref="STDOUT" />
        <appender-ref ref="FILE" />
    </root>
</configuration>
代码中使用
//@Slf4j 原来使用的是这个,注释掉即可

 //   引用下面的logback
 private static Logger log = LoggerFactory.getLogger(MyTaskJSON2.class);
程序打包成jar
启动
nohup java -jar collect_task_input-1.0-SNAPSHOT.jar >/dev/null nohup.out &

这样后面查看日志在/logs文件下查看即可,不会因为日志占用太多磁盘空间

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果你在 `logback.xml` 文件中使用 `${}` 语法来引用外部的属性,但是无法匹配 jar 外部指定的 yml 文件中的路径,可能是因为 `logback.xml` 文件中的属性无法在 Spring 环境中被解析。 为了解决这个问题,你可以将 `logback.xml` 文件中的属性定义为 Spring 的环境变量,然后在外部的 yml 文件中进行配置。这样,Spring 就能够正确地解析这些属性了。 以下是一个示例 `logback.xml` 文件: ```xml <configuration> <springProperty scope="context" name="log.path" source="myapp.log.path"/> <appender name="FILE" class="ch.qos.logback.core.FileAppender"> <file>${log.path}/myapp.log</file> <encoder> <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern> </encoder> </appender> <root level="INFO"> <appender-ref ref="FILE"/> </root> </configuration> ``` 在上面的示例中,我们将 `log.path` 定义为 Spring 的环境变量,使用 `springProperty` 标签来引用。这里的 `myapp.log.path` 是一个自定义的属性,你可以在外部的 yml 文件中进行配置,例如: ```yml myapp.log.path: /var/log/myapp ``` 这样,`logback.xml` 文件中的 `${log.path}` 就能够正确地被解析为 `/var/log/myapp` 了。 需要注意的是,这种方式需要确保 Spring 环境已经启动,所以你需要在外部的 yml 文件中设置对应的属性值,并在应用程序启动时指定该 yml 文件的路径。例如: ``` java -jar myapp.jar --spring.config.location=/path/to/application.yml ``` 其中,`/path/to/application.yml` 是你的外部 yml 文件的路径。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值