LOG_PATH_IS_UNDEFINED 解决

问题:
SpringBoot + LogBack 写日志,除了正常的日志之外,程序跑起来后会在项目根目录多生成一个 LOG_PATH_IS_UNDEFINED 的文件夹,我的配置是以下:

applickation.yml

logging:
  # logback.xml配置文件的位置
  config: classpath:logback-spring.xml
  file:
    path: D:\\mylog\\logs

logback-spring.xml

<?xml version="1.0" encoding="UTF-8"?>
<!-- 日志级别从低到高分为TRACE < DEBUG < INFO < WARN < ERROR < FATAL,如果设置为WARN,则低于WARN的信息都不会输出 -->
<!-- scan:当此属性设置为true时,配置文件如果发生改变,将会被重新加载,默认值为true -->
<!-- scanPeriod:设置监测配置文件是否有修改的时间间隔,如果没有给出时间单位,默认单位是毫秒。当scan为true时,此属性生效。默认的时间间隔为1分钟。 -->
<!-- debug:当此属性设置为true时,将打印出logback内部日志信息,实时查看logback运行状态。默认值为false。 -->
<configuration scan="true" scanPeriod="10 seconds">
    <!--读取配置中心的属性 -->
    <!-- 读取springboot配置文件application.yml中的属性标签,此处读取的日志存放路径,不带文件名,文件名后面根据级别命名 -->
    <springProperty scope="context" name="log.filePath" source="logging.file.path"/>
    <springProperty scope="context" name="applicationName" source="spring.application.name"/>

    <!-- <property name="LOG_PATH" value="logs" /> -->
    <property name="MAX_FILE_SIZE" value="100MB" />
    <property name="MAX_HISTORY" value="30" />
    <!-- 日志的打印格式,不带颜色,因为带颜色的在文件中不显示 -->
    <property name="log.pattern" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%-5level] %class:%method  [%tid] ${applicationName}  %msg%n"/>
    <!-- 控制台日志的打印格式,带颜色的 -->
    <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度,%msg:日志消息,%n是换行符-->
    <property name="logconsole.pattern" value="%boldCyan(%d{yyyy-MM-dd HH:mm:ss.SSS}){faint} %green([%thread]) %highlight([%-5level]) %boldMagenta(%class):%boldCyan(%method)  %yellow([%tid]) [%red(${applicationName})]  %cyan(%msg%n)"/>




    <!--输出到控制台 -->
    <!-- %m输出的信息,%p日志级别,%t线程名,%d日期,%c类的全名,%-5level:级别从左显示5个字符宽度,%logger{50}:表示logger名字最长50个字符,否则按照句点分割,%msg:日志消息,%i索引【从数字0开始递增】 -->
    <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
            <level>DEBUG</level>
        </filter>
        <encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder">
            <!--在控制台使用caller方式打印堆栈信息有超链接,使用replace去掉换行符-->
            <layout class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.TraceIdPatternLogbackLayout">
            <Pattern>${logconsole.pattern}</Pattern>
            </layout>
            <!-- 设置字符集 -->
            <charset>UTF-8</charset>
        </encoder>
    </appender>

    <!--所有日志输出到文件 -->
    <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <!--日志名,指定最新的文件名,其他文件名使用FileNamePattern -->
        <File>${log.filePath}/all.log</File>
        <!--日志文件输出格式 -->
        <encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder">
            <!--%logger{50}:表示logger名字最长50个字符,否则按照句点分割。
             %M:输出执行日志请求的方法名。尽量避免使用,除非执行速度不造成任何问题。
             %line:输出执行日志请求的行号。尽量避免使用,除非执行速度不造成任何问题。 -->
            <layout class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.TraceIdPatternLogbackLayout">
                <Pattern>${log.pattern}</Pattern>
            </layout>
            <!-- 设置字符集 -->
            <charset>UTF-8</charset>
        </encoder>
        <!-- 日志记录器的滚动策略,按日期,按大小记录 -->
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!-- 日志归档 后面可以加.zip -->
            <fileNamePattern>${LOG_PATH}/all-%d{yyyy-MM-dd}-%i.log</fileNamePattern>
            <!--日志文件保留天数 -->
            <maxHistory>${MAX_HISTORY}</maxHistory>
            <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                <!--文件达到 最大时会被压缩和切割 -->
                <maxFileSize>${MAX_FILE_SIZE}</maxFileSize>
            </timeBasedFileNamingAndTriggeringPolicy>
        </rollingPolicy>
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
        <!-- 指定级别 -->
        <level>DEBUG</level>
        </filter>
    </appender>

    <!-- ERROR 日志 -->
    <appender name="ERROR_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <!--日志名,指定最新的文件名,其他文件名使用FileNamePattern -->
        <File>${LOG_PATH}/error.log</File>
        <encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder">
            <layout class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.TraceIdPatternLogbackLayout">
                <Pattern>${log.pattern}</Pattern>
            </layout>
            <!-- 设置字符集 -->
            <charset>UTF-8</charset>
        </encoder>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${LOG_PATH}/error-%d{yyyy-MM-dd}.log</fileNamePattern>
            <maxHistory>${MAX_HISTORY}</maxHistory>
        </rollingPolicy>
        <!-- 此日志文件只记录ERROR级别的 -->
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <!-- 指定级别 -->
            <level>ERROR</level>
            <!-- onMatch:意思是>=指定级别 接受 -->
            <onMatch>ACCEPT</onMatch>
            <!-- onMismatch:意思是<指定级别 拒绝 -->
            <onMismatch>DENY</onMismatch>
        </filter>
    </appender>

    <!-- 异步日志输出看情况配置 -->
    <appender name="ASYNC_FILE" class="ch.qos.logback.classic.AsyncAppender">
        <!-- 更改默认的队列的深度,该值会影响性能.默认值为256 -->
        <queueSize>512</queueSize>
        <!-- 添加附加的appender,最多只能添加一个 -->
        <appender-ref ref="FILE" />
    </appender>
    <appender name="ASYNC_ERROR_FILE" class="ch.qos.logback.classic.AsyncAppender">
        <!-- 更改默认的队列的深度,该值会影响性能.默认值为256 -->
        <queueSize>512</queueSize>
        <!-- 添加附加的appender,最多只能添加一个 -->
        <appender-ref ref="ERROR_FILE" />
    </appender>

    <!-- 统一配置日志输出,root标签和logger标签,如果这开启了就把不同环境的关上 -->
    <!-- root标签:相当于开关,只有把定义的appender添加到这里 才会生效有日志 -->
    <!-- <root level="INFO">
        <appender-ref ref="CONSOLE" />
        <appender-ref ref="ASYNC_FILE" />
        <appender-ref ref="ASYNC_ERROR_FILE" />
    </root> -->
    <!-- logger标签:用来设置某一个包或者具体的某一个类的日志打印级别 -->
    <!-- <logger name="com.test.springboot.admin" level="DEBUG" /> -->


    <!-- 配置不同环境的日志输出,root标签和logger标签 -->
    <springProfile name="dev">
        <logger name="com.zhubayi.mylog" level="info"/>
        <root level="DEBUG">
            <appender-ref ref="CONSOLE" />
            <appender-ref ref="ASYNC_FILE" />
            <appender-ref ref="ASYNC_ERROR_FILE" />
        </root>
    </springProfile>

    <!-- <springProfile name="prod">
        <root level="INFO">
            <appender-ref ref="ASYNC_FILE" />
            <appender-ref ref="ASYNC_ERROR_FILE" />
        </root>
    </springProfile> -->
</configuration>

注意:CONSOLE与FILE最后保持一致,不然日志文件会出现??乱码在这里插入图片描述
若出现LOG_PATH_IS_UNDEFINED
把下面的改成

<springProperty scope="context" name="log.filePath" source="logging.file.path"/>

改为

<property name="log.filePath" value="D:\\mylog\\logs"/>
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是对代码的优化建议: 1. class error 中的 __init__ 方法中有一个无用的 pass,可以删除。 2. class error 中的 network_error 和 no_finf_element 方法中有相同的代码,可以将重复代码提取出来,写成一个私有方法,然后在这两个方法中调用。 3. network_error 和 no_finf_element 方法中的循环读取文件的方式不够高效,可以使用 readline() 方法替换 readlines() 方法,每次只读取一行,这样可以减少内存占用。 4. network_error 和 no_finf_element 方法中可以使用 with open(log_path, 'r') as f: 的方式打开文件,这样可以自动关闭文件,避免忘记关闭导致的资源泄漏。 5. 在 error_judge 方法中,if network_error(...) == True 可以简写成 if network_error(...): 6. 在 error_judge 方法中,if no_finf_elemen(...) == True 应该是 if no_finf_element(...) == True: 下面是优化后的代码: ```python import datetime class error: def __init__(self, log_path, port, end_time, start_time=0): self.log_path = log_path self.port = port self.end_time = end_time self.start_time = start_time def _check_error(self, log_path, end_time, start_time, error_str): with open(log_path, 'r') as f: line = f.readline() while line: log_time_str = line.split()[0] datetime_object = datetime.datetime.strptime(log_time_str, '%Y-%m-%d %H:%M:%S') log_time = datetime_object.timestamp() if start_time <= log_time <= end_time: if error_str in line: return True line = f.readline() return False def network_error(self): return self._check_error(self.log_path, self.end_time, self.start_time, self.port) def no_finf_element(self): return self._check_error(self.log_path, self.end_time, self.start_time, 'no such element') def error_judge(self): if self.network_error() and self.no_finf_element(): pass # 不执行重跑 else: pass # 执行重跑 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值