美文网首页
springboot+mybatis框架搭建--2.配置logb

springboot+mybatis框架搭建--2.配置logb

作者: 小狼在IT | 来源:发表于2019-02-15 14:16 被阅读0次

    1.在application.properties加上logback的路径:


    image.png

    2.在pom.xml加上logbackPath对应的值,就是实际的路径。


    image.png

    3.logback-spring.xml配置文件

        <?xml version="1.0" encoding="UTF-8"?>
        <configuration>
            <!--
               说明:
               1、日志级别及文件
                   日志记录采用分级记录,级别与日志文件名相对应,不同级别的日志信息记录到不同的日志文件中
                   例如:error级别记录到log_error_xxx.log或log_error.log(该文件为当前记录的日志文件),而log_error_xxx.log为归档日志,
                   日志文件按日期记录,同一天内,若日志文件大小等于或大于2M,则按0、1、2...顺序分别命名
                   例如log-level-2013-12-21.0.log
                   其它级别的日志也是如此。
               2、文件路径
                   若开发、测试用,在Eclipse中运行项目,则到Eclipse的安装路径查找logs文件夹,以相对路径../logs。
                   若部署到Tomcat下,则在Tomcat下的logs文件中
               3、Appender
                   FILEERROR对应error级别,文件名以log-error-xxx.log形式命名
                   FILEWARN对应warn级别,文件名以log-warn-xxx.log形式命名
                   FILEINFO对应info级别,文件名以log-info-xxx.log形式命名
                   FILEDEBUG对应debug级别,文件名以log-debug-xxx.log形式命名
                   stdout将日志信息输出到控制上,为方便开发测试使用
            -->
            <contextName>SpringBootDemo</contextName>
            <springProperty scop="context" name="logbackPath" source="logbackPath" defaultValue="/home/logs"/>
            <property name="LOG_PATH" value="${logbackPath}" />
            <!--设置系统日志目录-->
            <property name="APP_DIR" value="unknowtruth" />
        
            <!-- 不带彩色的日志在控制台输出时候的设置 -->
            <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
                <encoder>
                    <!-- 格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符-->
                    <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
                </encoder>
            </appender>
        
            <!-- 日志记录器,日期滚动记录 -->
            <appender name="FILEERROR" class="ch.qos.logback.core.rolling.RollingFileAppender">
                <!-- 正在记录的日志文件的路径及文件名 -->
                <file>${LOG_PATH}/${APP_DIR}/log_error.log</file>
                <!-- 日志记录器的滚动策略,按日期,按大小记录 -->
                <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                    <!-- 归档的日志文件的路径,例如今天是2013-12-21日志,当前写的日志文件路径为file节点指定,可以将此文件与file指定文件路径设置为不同路径,从而将当前日志文件或归档日志文件置不同的目录。
                    而2013-12-21的日志文件在由fileNamePattern指定。%d{yyyy-MM-dd}指定日期格式,%i指定索引 -->
                    <fileNamePattern>${LOG_PATH}/${APP_DIR}/error/log-error-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
                    <!-- 除按日志记录之外,还配置了日志文件不能超过2M,若超过2M,日志文件会以索引0开始,
                    命名日志文件,例如log-error-2013-12-21.0.log -->
                    <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                        <maxFileSize>2MB</maxFileSize>
                    </timeBasedFileNamingAndTriggeringPolicy>
                </rollingPolicy>
                <!-- 追加方式记录日志 -->
                <append>true</append>
                <!-- 日志文件的格式 -->
                <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
                    <pattern>===%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %logger Line:%-3L - %msg%n</pattern>
                    <charset>utf-8</charset>
                </encoder>
                <!-- 此日志文件只记录info级别的 -->
                <filter class="ch.qos.logback.classic.filter.LevelFilter">
                    <level>error</level>
                    <onMatch>ACCEPT</onMatch>
                    <onMismatch>DENY</onMismatch>
                </filter>
            </appender>
        
            <!-- 日志记录器,日期滚动记录 -->
            <appender name="FILEWARN" class="ch.qos.logback.core.rolling.RollingFileAppender">
                <!-- 正在记录的日志文件的路径及文件名 -->
                <file>${LOG_PATH}/${APP_DIR}/log_warn.log</file>
                <!-- 日志记录器的滚动策略,按日期,按大小记录 -->
                <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                    <!-- 归档的日志文件的路径,例如今天是2013-12-21日志,当前写的日志文件路径为file节点指定,可以将此文件与file指定文件路径设置为不同路径,从而将当前日志文件或归档日志文件置不同的目录。
                    而2013-12-21的日志文件在由fileNamePattern指定。%d{yyyy-MM-dd}指定日期格式,%i指定索引 -->
                    <fileNamePattern>${LOG_PATH}/${APP_DIR}/warn/log-warn-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
                    <!-- 除按日志记录之外,还配置了日志文件不能超过2M,若超过2M,日志文件会以索引0开始,
                    命名日志文件,例如log-error-2013-12-21.0.log -->
                    <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                        <maxFileSize>2MB</maxFileSize>
                    </timeBasedFileNamingAndTriggeringPolicy>
                </rollingPolicy>
                <!-- 追加方式记录日志 -->
                <append>true</append>
                <!-- 日志文件的格式 -->
                <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
                    <pattern>===%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %logger Line:%-3L - %msg%n</pattern>
                    <charset>utf-8</charset>
                </encoder>
                <!-- 此日志文件只记录info级别的 -->
                <filter class="ch.qos.logback.classic.filter.LevelFilter">
                    <level>warn</level>
                    <onMatch>ACCEPT</onMatch>
                    <onMismatch>DENY</onMismatch>
                </filter>
            </appender>
        
            <!-- 日志记录器,日期滚动记录 -->
            <appender name="FILEINFO" class="ch.qos.logback.core.rolling.RollingFileAppender">
                <!-- 正在记录的日志文件的路径及文件名 -->
                <file>${LOG_PATH}/${APP_DIR}/log_info.log</file>
                <!-- 日志记录器的滚动策略,按日期,按大小记录 -->
                <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                    <!-- 归档的日志文件的路径,例如今天是2013-12-21日志,当前写的日志文件路径为file节点指定,可以将此文件与file指定文件路径设置为不同路径,从而将当前日志文件或归档日志文件置不同的目录。
                    而2013-12-21的日志文件在由fileNamePattern指定。%d{yyyy-MM-dd}指定日期格式,%i指定索引 -->
                    <fileNamePattern>${LOG_PATH}/${APP_DIR}/info/log-info-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
                    <!-- 除按日志记录之外,还配置了日志文件不能超过2M,若超过2M,日志文件会以索引0开始,
                    命名日志文件,例如log-error-2013-12-21.0.log -->
                    <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                        <maxFileSize>2MB</maxFileSize>
                    </timeBasedFileNamingAndTriggeringPolicy>
                </rollingPolicy>
                <!-- 追加方式记录日志 -->
                <append>true</append>
                <!-- 日志文件的格式 -->
                <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
                    <pattern>===%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %logger Line:%-3L - %msg%n</pattern>
                    <charset>utf-8</charset>
                </encoder>
                <!-- 此日志文件只记录info级别的 -->
                <filter class="ch.qos.logback.classic.filter.LevelFilter">
                    <level>info</level>
                    <onMatch>ACCEPT</onMatch>
                    <onMismatch>DENY</onMismatch>
                </filter>
            </appender>
        
            <!-- 日志记录器,日期滚动记录 -->
            <appender name="FILEDEBUG" class="ch.qos.logback.core.rolling.RollingFileAppender">
                <!-- 正在记录的日志文件的路径及文件名 -->
                <file>${LOG_PATH}/${APP_DIR}/log_debug.log</file>
                <!-- 日志记录器的滚动策略,按日期,按大小记录 -->
                <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                    <!-- 归档的日志文件的路径,例如今天是2013-12-21日志,当前写的日志文件路径为file节点指定,可以将此文件与file指定文件路径设置为不同路径,从而将当前日志文件或归档日志文件置不同的目录。
                    而2013-12-21的日志文件在由fileNamePattern指定。%d{yyyy-MM-dd}指定日期格式,%i指定索引 -->
                    <fileNamePattern>${LOG_PATH}/${APP_DIR}/debug/log-debug-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
                    <!-- 除按日志记录之外,还配置了日志文件不能超过2M,若超过2M,日志文件会以索引0开始,
                    命名日志文件,例如log-error-2013-12-21.0.log -->
                    <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                        <maxFileSize>2MB</maxFileSize>
                    </timeBasedFileNamingAndTriggeringPolicy>
                </rollingPolicy>
                <!-- 追加方式记录日志 -->
                <append>true</append>
                <!-- 日志文件的格式 -->
                <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
                    <pattern>===%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %logger Line:%-3L - %msg%n</pattern>
                    <charset>utf-8</charset>
                </encoder>
                <!-- 此日志文件只记录info级别的 -->
                <filter class="ch.qos.logback.classic.filter.LevelFilter">
                    <level>DEBUG</level>
                    <onMatch>ACCEPT</onMatch>
                    <onMismatch>DENY</onMismatch>
                </filter>
            </appender>
        
            <!-- <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
                 &lt;!&ndash;encoder 默认配置为PatternLayoutEncoder&ndash;&gt;
                 <encoder>
                     <pattern>===%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %logger Line:%-3L - %msg%n</pattern>
                     <charset>utf-8</charset>
                 </encoder>
                 &lt;!&ndash;此日志appender是为开发使用,只配置最底级别,控制台输出的日志级别是大于或等于此级别的日志信息&ndash;&gt;
                 <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
                     <level>debug</level>
                 </filter>
             </appender>-->
        
            <!-- show parameters for hibernate sql 专为 Hibernate 定制 -->
            <!-- <logger name="org.hibernate.type.descriptor.sql.BasicBinder"  level="TRACE" />
            <logger name="org.hibernate.type.descriptor.sql.BasicExtractor"  level="DEBUG" />
            <logger name="org.hibernate.SQL" level="DEBUG" />
            <logger name="org.hibernate.engine.QueryParameters" level="DEBUG" />
            <logger name="org.hibernate.engine.query.HQLQueryPlan" level="DEBUG" />  -->
        
            <!--myibatis log configure-->
            <!-- project default level -->
            <!--<logger name="org.apache.ibatis" level="debug" />-->
        
            <!--  mapper 文件的包路径-->
            <logger name="com.example.demo.dao" level="debug" />
        
            <!--log4jdbc -->
            <logger name="jdbc.sqltiming" level="debug"/>
            <logger name="com.ibatis" level="debug" />
            <logger name="com.ibatis.common.jdbc.SimpleDataSource" level="debug" />
            <logger name="com.ibatis.common.jdbc.ScriptRunner" level="debug" />
            <logger name="com.ibatis.sqlmap.engine.impl.SqlMapClientDelegate" level="debug" />
            <logger name="java.sql.Connection" level="debug" />
            <logger name="java.sql.Statement" level="debug" />
            <logger name="java.sql.PreparedStatement" level="debug" />
            <logger name="java.sql.ResultSet" level="debug" />
            <logger name="java.sql" level="debug" />
        
            <logger name="org.springframework" level="WARN" />
        
            <!-- 生产环境下,将此级别配置为适合的级别,以免日志文件太多或影响程序性能 -->
            <root level="INFO">
                <appender-ref ref="FILEERROR" />
                <appender-ref ref="FILEWARN" />
                <appender-ref ref="FILEINFO" />
                <appender-ref ref="FILEDEBUG" />
                <!-- 生产环境将请stdout,testfile去掉 -->
                <appender-ref ref="CONSOLE" />
            </root>
        
            <!-- 环境配置 -->
            <!--   <springProfile name="test,dev">
                   <logger name="org.springframework.web" level="INFO"/>
                   <logger name="org.springboot.sample" level="INFO" />
                   <logger name="com.kfit" level="info" />
               </springProfile>-->
            <!-- 生产环境. -->
            <!--  <springProfile name="prod">
                  <logger name="org.springframework.web" level="ERROR"/>
                  <logger name="org.springboot.sample" level="ERROR" />
                  <logger name="com.kfit" level="ERROR" />
              </springProfile>-->
        
            <!--日志异步到数据库 -->
            <!-- <appender name="DB" class="ch.qos.logback.classic.db.DBAppender">
                日志异步到数据库
                <connectionSource class="ch.qos.logback.core.db.DriverManagerConnectionSource">
                   连接池
                   <dataSource class="com.mchange.v2.c3p0.ComboPooledDataSource">
                      <driverClass>com.mysql.jdbc.Driver</driverClass>
                      <url>jdbc:mysql://127.0.0.1:3306/databaseName</url>
                      <user>root</user>
                      <password>root</password>
                    </dataSource>
                </connectionSource>
          </appender> -->
        
            <!-- 测试环境+开发环境. 多个使用逗号隔开. -->
        
        </configuration>
    

    这是网上找到的配置文件,这里只介绍搭建框架,不会详述每项配置的信息,请自行百度。
    这里只说说我自行修改的部分:


    image.png

    如图,利用maven配置的便利,可以让日志文件根据不同的环境放到不同的路径。

    运行结果:
    设置一个controller:


    image.png

    配置端口:


    image.png

    打开网页触发请求:


    image.png

    日志成功显示:


    image.png

    相关文章

      网友评论

          本文标题:springboot+mybatis框架搭建--2.配置logb

          本文链接:https://www.haomeiwen.com/subject/kjbpeqtx.html