springboot jar 配置文件同级目录 启动脚本sh 并添加日志文件,日志文件定时分文件

为了创建一个Spring Boot应用的启动脚本,并且配置日志输出到一个会定期分割的日志文件中,你可以按照以下步骤来进行:

  1. 创建启动脚本:首先,创建一个shell脚本文件,比如命名为start-your-app.sh

  2. 配置日志文件:使用logback.xml或者application.properties来配置日志输出。如果你的应用已经有一个日志配置文件,那么你可能只需要稍微修改一下配置即可。

  3. 日志文件滚动配置:通常使用logback标签来配置日志滚动策略。

以下是一个基本的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.logfile>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            
            <fileNamePattern>logs/app.%d{yyyy-MM-dd}.logfileNamePattern>
            
            <maxHistory>30maxHistory>
        rollingPolicy>
        <encoder>
            <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%npattern>
        encoder>
    appender>

    <root level="INFO">
        <appender-ref ref="FILE" />
    root>
configuration>

这个logback.xml配置中的部分指定了日志文件每天自动滚动一次,并保留最近30天的日志文件。

最后,确保给你的启动脚本添加执行权限:

chmod +x start-your-app.sh

这样,你可以通过运行./start-your-app.sh来启动你的Spring Boot应用,并且日志会被记录到logs/app.log及其滚动文件中。

你可能感兴趣的:(java,spring,boot,jar,后端)