• logo back 日志 发送邮件


    <?xml version="1.0" encoding="UTF-8"?>
    <configuration>
        <!--<property name="logname" value="test"/>-->
        <!--获取配置中的参数信息-->
        <springProperty scope="context" name="logname" source="spring.application.name"/>
        <springProperty scope="context" name="smtpHost" source="email.smtpHost"/>
        <!--<springProperty scope="context" name="smtpPort" source="email.smtpPort"/>-->
        <springProperty scope="context" name="to" source="email.to"/>
        <springProperty scope="context" name="from" source="email.from"/>
        <springProperty scope="context" name="username" source="email.username"/>
        <springProperty scope="context" name="password" source="email.password"/>
        <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
            <target>System.out</target>
            <encoder>
                <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
            </encoder>
        </appender>
        <appender name="FILE_INFO" class="ch.qos.logback.core.rolling.RollingFileAppender">
            <!--如果只是想要 Info 级别的日志,只是过滤 info 还是会输出 Error 日志,因为 Error 的级别高, 所以我们使用下面的策略,可以避免输出 Error 的日志-->
            <filter class="ch.qos.logback.classic.filter.LevelFilter">
                <!--过滤 INFO-->
                <level>INFO</level>
                <!--匹配到就允许-->
                <onMatch>ACCEPT</onMatch>
                <!--没有匹配到就禁止-->
                <onMismatch>DENY</onMismatch>
            </filter>
            <!--日志名称,如果没有File 属性,那么只会使用FileNamePattern的文件路径规则 如果同时有<File>和<FileNamePattern>,那么当天日志是<File>,明天会自动把今天的日志改名为今天的日期。即,<File> 的日志都是当天的。 -->
            <File>/home/logs/${logname}-info.log</File>
            <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                <!--文件路径,定义了日志的切分方式——把每一天的日志归档到一个文件中,以防止日志填满整个磁盘空间-->
                <fileNamePattern>/home/logs/${logname}-info-%d{yyyy-MM-dd}.log</fileNamePattern>
                <!--只保留最近30天的日志-->
                <maxHistory>30</maxHistory>
            </rollingPolicy>
            <encoder>
                <charset>UTF-8</charset>
                <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
            </encoder>
        </appender>
    
        <appender name="FILE_WARN" class="ch.qos.logback.core.rolling.RollingFileAppender">
            <!--如果只是想要 Error 级别的日志,那么需要过滤一下,默认是 info 级别的,ThresholdFilter-->
            <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
                <level>WARN</level>
            </filter>
            <!--日志名称,如果没有File 属性,那么只会使用FileNamePattern的文件路径规则 如果同时有<File>和<FileNamePattern>,那么当天日志是<File>,明天会自动把今天的日志改名为今天的日期。即,<File> 的日志都是当天的。 -->
            <File>/home/logs/${logname}-warn.log</File>
            <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                <!--文件路径,定义了日志的切分方式——把每一天的日志归档到一个文件中,以防止日志填满整个磁盘空间-->
                <fileNamePattern>/home/logs/${logname}-warn-%d{yyyy-MM-dd}.log</fileNamePattern>
                <!--只保留最近30天的日志-->
                <maxHistory>30</maxHistory>
            </rollingPolicy>
            <encoder>
                <charset>UTF-8</charset>
                <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
            </encoder>
        </appender>
    
        <appender name="FILE_ERROR" class="ch.qos.logback.core.rolling.RollingFileAppender">
            <!--如果只是想要 Error 级别的日志,那么需要过滤一下,默认是 info 级别的,ThresholdFilter-->
            <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
                <level>Error</level>
            </filter>
            <!--日志名称,如果没有File 属性,那么只会使用FileNamePattern的文件路径规则 如果同时有<File>和<FileNamePattern>,那么当天日志是<File>,明天会自动把今天的日志改名为今天的日期。即,<File> 的日志都是当天的。 -->
            <File>/home/logs/${logname}-error.log</File>
            <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                <!--文件路径,定义了日志的切分方式——把每一天的日志归档到一个文件中,以防止日志填满整个磁盘空间-->
                <fileNamePattern>/home/logs/${logname}-error-%d{yyyy-MM-dd}.log</fileNamePattern>
                <!--只保留最近30天的日志-->
                <maxHistory>30</maxHistory>
            </rollingPolicy>
            <encoder>
                <charset>UTF-8</charset>
                <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
            </encoder>
        </appender>
    
        <!--邮件发送-->
        <appender name="EMAIL" class="ch.qos.logback.classic.net.SMTPAppender">
            <!--smtp 服务器-->
            <smtpHost>smtp.qq.com</smtpHost>
            <!--port-->
            <smtpPort>25</smtpPort>
            <!-- 发给谁的邮件列表,多个人用逗号分隔 -->
            <to>942582838@qq.com</to>
            <!--发件人,添加邮箱和上面的username保持一致-->
            <from>942582838@qq.com</from>
            <subject>错误异常:%logger - %msg</subject>
            <!--发件人的邮箱-->
            <username>942582838@qq.com</username>
            <!--发件人的邮箱密码-->
            <password>zahggefrblqpbfgf</password>
            <SSL>false</SSL>
            <!--是否异步-->
            <asynchronousSending>true</asynchronousSending>
            <layout class="ch.qos.logback.classic.PatternLayout">
                <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
            </layout>
            <cyclicBufferTracker class = "ch.qos.logback.core.spi.CyclicBufferTracker" >
                <bufferSize> 1 </bufferSize>
            </cyclicBufferTracker>
            <!--过滤器-->
            <!-- 这里采用等级过滤器 指定等级相符才发送 -->
            <filter class="ch.qos.logback.classic.filter.LevelFilter">
                <level>ERROR</level>
                <onMatch>ACCEPT</onMatch>
                <onMismatch>DENY</onMismatch>
            </filter>
        </appender>
                
        <root level="INFO">
            <appender-ref ref="CONSOLE"/>
            <appender-ref ref="FILE_INFO"/>
            <appender-ref ref="FILE_WARN"/>
            <appender-ref ref="FILE_ERROR"/>
            <!--  log error send EMAIL -->
            <appender-ref ref="EMAIL"/>
        </root>
    
    </configuration>

    pom 依赖:

       <dependency>
                <groupId>javax.mail</groupId>
                <artifactId>javax.mail-api</artifactId>
                <version>1.6.2</version>
            </dependency>
    
    
      <!--  实际上用到的是这个..!!! -->    
            <dependency>
                <groupId>com.sun.mail</groupId>
                <artifactId>javax.mail</artifactId>
                <version>1.6.2</version>
            </dependency>
  • 相关阅读:
    C#中Linq查询基本操作
    Python中的四种数据结构
    20200917练习题
    SRS搭建自己的直播、点播系统
    20200916练习题
    20200915练习题
    20200914练习题
    20200911练习题
    UTF-8最多编码字符数(最多可以容纳多少数量的字符)?
    k8s新手必看
  • 原文地址:https://www.cnblogs.com/whm-blog/p/10608113.html
Copyright © 2020-2023  润新知