本文主要是介绍springboot jar 配置文件同级目录 启动脚本sh 并添加日志文件,日志文件定时分文件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
为了创建一个Spring Boot应用的启动脚本,并且配置日志输出到一个会定期分割的日志文件中,你可以按照以下步骤来进行:
-
创建启动脚本:首先,创建一个shell脚本文件,比如命名为
start-your-app.sh
。 -
配置日志文件:使用
logback.xml
或者application.properties
来配置日志输出。如果你的应用已经有一个日志配置文件,那么你可能只需要稍微修改一下配置即可。 -
日志文件滚动配置:通常使用
logback
的<rollingFile>
标签来配置日志滚动策略。
以下是一个基本的start-your-app.sh
脚本示例:
#!/bin/bash# 设置工作目录为脚本所在目录
WORK_DIR=$(dirname "$0")
cd "$WORK_DIR"# 设置JVM参数
JAVA_OPTS="-Xmx512m -Xms512m -Dspring.profiles.active=prod -Djava.security.egd=file:/dev/./urandom"# 设置日志文件路径
LOG_FILE="$WORK_DIR/app.log"# 启动Spring Boot应用
nohup java $JAVA_OPTS -jar your-app.jar > "$LOG_FILE" 2>&1 &echo "Application started, check logs in $LOG_FILE"
在这个脚本中:
JAVA_OPTS
用于设置JVM参数,例如内存分配和环境变量。LOG_FILE
定义了日志文件的位置。nohup
命令使得进程可以在后台持续运行,即使关闭了终端窗口。> "$LOG_FILE" 2>&1
将标准输出和错误重定向到指定的日志文件。
接下来,你需要配置日志文件的滚动策略。假设你的Spring Boot应用使用的是logback.xml
进行日志配置,可以添加或修改如下配置:
<configuration><appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"><file>logs/app.log</file><rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"><!-- daily rollover --><fileNamePattern>logs/app.%d{yyyy-MM-dd}.log</fileNamePattern><!-- keep 30 days' worth of history --><maxHistory>30</maxHistory></rollingPolicy><encoder><pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern></encoder></appender><root level="INFO"><appender-ref ref="FILE" /></root>
</configuration>
这个logback.xml
配置中的<rollingPolicy>
部分指定了日志文件每天自动滚动一次,并保留最近30天的日志文件。
最后,确保给你的启动脚本添加执行权限:
chmod +x start-your-app.sh
这样,你可以通过运行./start-your-app.sh
来启动你的Spring Boot应用,并且日志会被记录到logs/app.log
及其滚动文件中。
这篇关于springboot jar 配置文件同级目录 启动脚本sh 并添加日志文件,日志文件定时分文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!