fix: 移除启动命令中的日志格式参数,避免shell解析错误
问题: - LOG_PATTERN包含特殊字符(百分号、方括号等) - 通过-D参数传递导致shell解析错误 修改: - start.sh: 移除LOG_LEVEL_ROOT/LOG_LEVEL_APP/LOG_PATTERN参数 只保留logging.file.path用于指定日志目录 - logback-spring.xml: 日志格式改为直接配置 使用<property>而非<springProperty> - env.properties: 更新注释说明日志配置由logback管理 优势: - 启动命令简洁,无特殊字符解析问题 - 日志配置统一在logback-spring.xml管理 - 避免shell注入风险
This commit is contained in:
parent
1f30315a2f
commit
ca1d0edd56
@ -2,12 +2,13 @@
|
||||
<configuration scan="true" scanPeriod="60 seconds" debug="false">
|
||||
|
||||
<!-- 从环境变量/系统属性读取配置 -->
|
||||
<springProperty scope="context" name="APP_NAME" source="spring.application.name" defaultValue="fund-sys"/>
|
||||
<springProperty scope="context" name="APP_NAME" source="spring.application.name" defaultValue="fund-cust"/>
|
||||
<springProperty scope="context" name="LOG_PATH" source="logging.file.path" defaultValue="/datacfs/applogs"/>
|
||||
<springProperty scope="context" name="LOG_LEVEL_ROOT" source="logging.level.root" defaultValue="INFO"/>
|
||||
<springProperty scope="context" name="LOG_LEVEL_APP" source="logging.level.app" defaultValue="DEBUG"/>
|
||||
<springProperty scope="context" name="LOG_PATTERN" source="logging.pattern.console"
|
||||
defaultValue="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%X{traceId:-}][%X{spanId:-}] %-5level %logger{50} - %msg%n"/>
|
||||
|
||||
<!-- 日志格式(直接配置,不从参数读取避免shell解析问题) -->
|
||||
<property name="LOG_PATTERN" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%X{traceId:-}][%X{spanId:-}] %-5level %logger{50} - %msg%n"/>
|
||||
|
||||
<!-- 控制台输出 -->
|
||||
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
|
||||
|
||||
@ -2,12 +2,13 @@
|
||||
<configuration scan="true" scanPeriod="60 seconds" debug="false">
|
||||
|
||||
<!-- 从环境变量/系统属性读取配置 -->
|
||||
<springProperty scope="context" name="APP_NAME" source="spring.application.name" defaultValue="fund-sys"/>
|
||||
<springProperty scope="context" name="APP_NAME" source="spring.application.name" defaultValue="fund-exp"/>
|
||||
<springProperty scope="context" name="LOG_PATH" source="logging.file.path" defaultValue="/datacfs/applogs"/>
|
||||
<springProperty scope="context" name="LOG_LEVEL_ROOT" source="logging.level.root" defaultValue="INFO"/>
|
||||
<springProperty scope="context" name="LOG_LEVEL_APP" source="logging.level.app" defaultValue="DEBUG"/>
|
||||
<springProperty scope="context" name="LOG_PATTERN" source="logging.pattern.console"
|
||||
defaultValue="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%X{traceId:-}][%X{spanId:-}] %-5level %logger{50} - %msg%n"/>
|
||||
|
||||
<!-- 日志格式(直接配置,不从参数读取避免shell解析问题) -->
|
||||
<property name="LOG_PATTERN" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%X{traceId:-}][%X{spanId:-}] %-5level %logger{50} - %msg%n"/>
|
||||
|
||||
<!-- 控制台输出 -->
|
||||
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
|
||||
|
||||
@ -2,12 +2,13 @@
|
||||
<configuration scan="true" scanPeriod="60 seconds" debug="false">
|
||||
|
||||
<!-- 从环境变量/系统属性读取配置 -->
|
||||
<springProperty scope="context" name="APP_NAME" source="spring.application.name" defaultValue="fund-sys"/>
|
||||
<springProperty scope="context" name="APP_NAME" source="spring.application.name" defaultValue="fund-file"/>
|
||||
<springProperty scope="context" name="LOG_PATH" source="logging.file.path" defaultValue="/datacfs/applogs"/>
|
||||
<springProperty scope="context" name="LOG_LEVEL_ROOT" source="logging.level.root" defaultValue="INFO"/>
|
||||
<springProperty scope="context" name="LOG_LEVEL_APP" source="logging.level.app" defaultValue="DEBUG"/>
|
||||
<springProperty scope="context" name="LOG_PATTERN" source="logging.pattern.console"
|
||||
defaultValue="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%X{traceId:-}][%X{spanId:-}] %-5level %logger{50} - %msg%n"/>
|
||||
|
||||
<!-- 日志格式(直接配置,不从参数读取避免shell解析问题) -->
|
||||
<property name="LOG_PATTERN" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%X{traceId:-}][%X{spanId:-}] %-5level %logger{50} - %msg%n"/>
|
||||
|
||||
<!-- 控制台输出 -->
|
||||
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
|
||||
|
||||
@ -2,12 +2,13 @@
|
||||
<configuration scan="true" scanPeriod="60 seconds" debug="false">
|
||||
|
||||
<!-- 从环境变量/系统属性读取配置 -->
|
||||
<springProperty scope="context" name="APP_NAME" source="spring.application.name" defaultValue="fund-sys"/>
|
||||
<springProperty scope="context" name="APP_NAME" source="spring.application.name" defaultValue="fund-gateway"/>
|
||||
<springProperty scope="context" name="LOG_PATH" source="logging.file.path" defaultValue="/datacfs/applogs"/>
|
||||
<springProperty scope="context" name="LOG_LEVEL_ROOT" source="logging.level.root" defaultValue="INFO"/>
|
||||
<springProperty scope="context" name="LOG_LEVEL_APP" source="logging.level.app" defaultValue="DEBUG"/>
|
||||
<springProperty scope="context" name="LOG_PATTERN" source="logging.pattern.console"
|
||||
defaultValue="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%X{traceId:-}][%X{spanId:-}] %-5level %logger{50} - %msg%n"/>
|
||||
|
||||
<!-- 日志格式(直接配置,不从参数读取避免shell解析问题) -->
|
||||
<property name="LOG_PATTERN" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%X{traceId:-}][%X{spanId:-}] %-5level %logger{50} - %msg%n"/>
|
||||
|
||||
<!-- 控制台输出 -->
|
||||
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
|
||||
|
||||
@ -2,12 +2,13 @@
|
||||
<configuration scan="true" scanPeriod="60 seconds" debug="false">
|
||||
|
||||
<!-- 从环境变量/系统属性读取配置 -->
|
||||
<springProperty scope="context" name="APP_NAME" source="spring.application.name" defaultValue="fund-sys"/>
|
||||
<springProperty scope="context" name="APP_NAME" source="spring.application.name" defaultValue="fund-proj"/>
|
||||
<springProperty scope="context" name="LOG_PATH" source="logging.file.path" defaultValue="/datacfs/applogs"/>
|
||||
<springProperty scope="context" name="LOG_LEVEL_ROOT" source="logging.level.root" defaultValue="INFO"/>
|
||||
<springProperty scope="context" name="LOG_LEVEL_APP" source="logging.level.app" defaultValue="DEBUG"/>
|
||||
<springProperty scope="context" name="LOG_PATTERN" source="logging.pattern.console"
|
||||
defaultValue="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%X{traceId:-}][%X{spanId:-}] %-5level %logger{50} - %msg%n"/>
|
||||
|
||||
<!-- 日志格式(直接配置,不从参数读取避免shell解析问题) -->
|
||||
<property name="LOG_PATTERN" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%X{traceId:-}][%X{spanId:-}] %-5level %logger{50} - %msg%n"/>
|
||||
|
||||
<!-- 控制台输出 -->
|
||||
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
|
||||
|
||||
@ -2,12 +2,13 @@
|
||||
<configuration scan="true" scanPeriod="60 seconds" debug="false">
|
||||
|
||||
<!-- 从环境变量/系统属性读取配置 -->
|
||||
<springProperty scope="context" name="APP_NAME" source="spring.application.name" defaultValue="fund-sys"/>
|
||||
<springProperty scope="context" name="APP_NAME" source="spring.application.name" defaultValue="fund-receipt"/>
|
||||
<springProperty scope="context" name="LOG_PATH" source="logging.file.path" defaultValue="/datacfs/applogs"/>
|
||||
<springProperty scope="context" name="LOG_LEVEL_ROOT" source="logging.level.root" defaultValue="INFO"/>
|
||||
<springProperty scope="context" name="LOG_LEVEL_APP" source="logging.level.app" defaultValue="DEBUG"/>
|
||||
<springProperty scope="context" name="LOG_PATTERN" source="logging.pattern.console"
|
||||
defaultValue="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%X{traceId:-}][%X{spanId:-}] %-5level %logger{50} - %msg%n"/>
|
||||
|
||||
<!-- 日志格式(直接配置,不从参数读取避免shell解析问题) -->
|
||||
<property name="LOG_PATTERN" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%X{traceId:-}][%X{spanId:-}] %-5level %logger{50} - %msg%n"/>
|
||||
|
||||
<!-- 控制台输出 -->
|
||||
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
|
||||
|
||||
@ -2,12 +2,13 @@
|
||||
<configuration scan="true" scanPeriod="60 seconds" debug="false">
|
||||
|
||||
<!-- 从环境变量/系统属性读取配置 -->
|
||||
<springProperty scope="context" name="APP_NAME" source="spring.application.name" defaultValue="fund-sys"/>
|
||||
<springProperty scope="context" name="APP_NAME" source="spring.application.name" defaultValue="fund-report"/>
|
||||
<springProperty scope="context" name="LOG_PATH" source="logging.file.path" defaultValue="/datacfs/applogs"/>
|
||||
<springProperty scope="context" name="LOG_LEVEL_ROOT" source="logging.level.root" defaultValue="INFO"/>
|
||||
<springProperty scope="context" name="LOG_LEVEL_APP" source="logging.level.app" defaultValue="DEBUG"/>
|
||||
<springProperty scope="context" name="LOG_PATTERN" source="logging.pattern.console"
|
||||
defaultValue="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%X{traceId:-}][%X{spanId:-}] %-5level %logger{50} - %msg%n"/>
|
||||
|
||||
<!-- 日志格式(直接配置,不从参数读取避免shell解析问题) -->
|
||||
<property name="LOG_PATTERN" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%X{traceId:-}][%X{spanId:-}] %-5level %logger{50} - %msg%n"/>
|
||||
|
||||
<!-- 控制台输出 -->
|
||||
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
|
||||
|
||||
@ -2,12 +2,13 @@
|
||||
<configuration scan="true" scanPeriod="60 seconds" debug="false">
|
||||
|
||||
<!-- 从环境变量/系统属性读取配置 -->
|
||||
<springProperty scope="context" name="APP_NAME" source="spring.application.name" defaultValue="fund-sys"/>
|
||||
<springProperty scope="context" name="APP_NAME" source="spring.application.name" defaultValue="fund-req"/>
|
||||
<springProperty scope="context" name="LOG_PATH" source="logging.file.path" defaultValue="/datacfs/applogs"/>
|
||||
<springProperty scope="context" name="LOG_LEVEL_ROOT" source="logging.level.root" defaultValue="INFO"/>
|
||||
<springProperty scope="context" name="LOG_LEVEL_APP" source="logging.level.app" defaultValue="DEBUG"/>
|
||||
<springProperty scope="context" name="LOG_PATTERN" source="logging.pattern.console"
|
||||
defaultValue="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%X{traceId:-}][%X{spanId:-}] %-5level %logger{50} - %msg%n"/>
|
||||
|
||||
<!-- 日志格式(直接配置,不从参数读取避免shell解析问题) -->
|
||||
<property name="LOG_PATTERN" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%X{traceId:-}][%X{spanId:-}] %-5level %logger{50} - %msg%n"/>
|
||||
|
||||
<!-- 控制台输出 -->
|
||||
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
|
||||
|
||||
@ -6,8 +6,9 @@
|
||||
<springProperty scope="context" name="LOG_PATH" source="logging.file.path" defaultValue="/datacfs/applogs"/>
|
||||
<springProperty scope="context" name="LOG_LEVEL_ROOT" source="logging.level.root" defaultValue="INFO"/>
|
||||
<springProperty scope="context" name="LOG_LEVEL_APP" source="logging.level.app" defaultValue="DEBUG"/>
|
||||
<springProperty scope="context" name="LOG_PATTERN" source="logging.pattern.console"
|
||||
defaultValue="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%X{traceId:-}][%X{spanId:-}] %-5level %logger{50} - %msg%n"/>
|
||||
|
||||
<!-- 日志格式(直接配置,不从参数读取避免shell解析问题) -->
|
||||
<property name="LOG_PATTERN" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%X{traceId:-}][%X{spanId:-}] %-5level %logger{50} - %msg%n"/>
|
||||
|
||||
<!-- 控制台输出 -->
|
||||
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
|
||||
|
||||
@ -64,15 +64,16 @@ FILE_STORAGE_MAX_BYTES=52428800
|
||||
|
||||
# --------------------------------------------
|
||||
# 日志配置(由logback-spring.xml统一管理)
|
||||
# 以下参数仅供参考,实际配置在logback-spring.xml中
|
||||
# --------------------------------------------
|
||||
# 日志文件路径
|
||||
# 日志文件路径(由启动脚本LOG_HOME决定)
|
||||
LOG_PATH=/datacfs/applogs
|
||||
# 根日志级别
|
||||
LOG_LEVEL_ROOT=INFO
|
||||
# 应用包日志级别
|
||||
LOG_LEVEL_APP=DEBUG
|
||||
# 日志格式
|
||||
LOG_PATTERN=%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%X{traceId:-}][%X{spanId:-}] %-5level %logger{50} - %msg%n
|
||||
# 日志格式(已在logback-spring.xml中配置)
|
||||
# LOG_PATTERN=%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%X{traceId:-}][%X{spanId:-}] %-5level %logger{50} - %msg%n
|
||||
|
||||
# --------------------------------------------
|
||||
# 多租户路由配置
|
||||
|
||||
@ -59,12 +59,8 @@ PID_FILE="${APP_HOME}/${INSTANCE_NAME}.pid"
|
||||
# JVM参数(可通过环境变量覆盖)
|
||||
JAVA_OPTS="${JAVA_OPTS:--Xms256m -Xmx512m -XX:+UseG1GC -XX:MaxGCPauseMillis=200}"
|
||||
|
||||
# 日志参数(从env.properties读取或使用默认值)
|
||||
# 日志目录参数(其他日志配置在application.yml/logback-spring.xml中)
|
||||
LOG_OPTS="-Dlogging.file.path=${LOG_HOME}"
|
||||
LOG_OPTS="$LOG_OPTS -Dspring.application.name=${APP_NAME}"
|
||||
LOG_OPTS="$LOG_OPTS -Dlogging.level.root=${LOG_LEVEL_ROOT:-INFO}"
|
||||
LOG_OPTS="$LOG_OPTS -Dlogging.level.app=${LOG_LEVEL_APP:-DEBUG}"
|
||||
LOG_OPTS="$LOG_OPTS -Dlogging.pattern.console=${LOG_PATTERN}"
|
||||
|
||||
# 多租户参数
|
||||
TENANT_OPTS=""
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user