maven云笔记之日志

日志有一个很好的作用就是可以随时随地查看项目的进程,发现bug
今天就学习一下

总体的做法
1.在pom.xml中引入jar包,需要到阿帕奇官网
2.在conf文件夹中新建log4j2.xml
3.在web.xml中添加log4j配置
4.需要在Servers/Tomcat vx.x Server at localhost-config/catalina.properties中添加信息
5.具体做法

============================================================================================================

引入jar包

 <!-- https://mvnrepository.com/artifact/org.apache.logging.log4j/log4j-core -->

<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>2.13.2</version>
</dependency>

	<!-- https://mvnrepository.com/artifact/org.apache.logging.log4j/log4j-api -->
 <dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-api</artifactId>
<version>2.13.2</version>
</dependency>

<!-- https://mvnrepository.com/artifact/org.apache.logging.log4j/log4j-web -->
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-web</artifactId>
<version>2.13.2</version>
</dependency>

============================================================================================================

新建log4j2.xml

<?xml version="1.0" encoding="UTF-8"?>
<configuration status="error">
    <!--先定义所有的appender -->
    <appenders>
        <!--这个输出控制台的配置 -->
        <Console name="Console" target="SYSTEM_OUT">
        <!--日志级别以及优先级排序: OFF > FATAL > ERROR > WARN > INFO > DEBUG > TRACE > ALL -->
		<!-- 
		trace:追踪,就是程序推进一下,可以写个trace输出
		debug:调试,一般作为最低级别,trace基本不用。
		info:输出重要的信息,使用较多
		warn:警告,有些信息不是错误信息,但也要给程序员一些提示。
		error:错误信息。用的也很多。
		fatal:致命错误。级别较高,这种级别不用调试了,重写吧……
		机制:如果一条日志信息的级别大于等于配置文件的级别,就记录。 -->

            <!--             控制台只输出level及以上级别的信息(onMatch),其他的直接拒绝(onMismatch) -->
            <ThresholdFilter level="debug" onMatch="ACCEPT" onMismatch="DENY"/>
            <!--             这个都知道是输出日志的格式 -->
            <PatternLayout pattern="%d{HH:mm:ss.SSS} %-5level %class{36} %L %M - %msg%xEx%n"/>
        </Console>
 
        <!--文件会打印出所有信息,这个log每次运行程序会自动清空,由append属性决定,这个也挺有用的,适合临时测试用 -->
        <!--append为TRUE表示消息增加到指定文件中,false表示消息覆盖指定的文件内容,默认值是true -->
        <File name="log" fileName="D:/wznoteserver/log.log" append="true">
            <PatternLayout pattern="%d{HH:mm:ss.SSS} %-5level %class{36} %L %M - %msg%xEx%n"/>
        </File>
 
        <!--添加过滤器ThresholdFilter,可以有选择的输出某个级别以上的类别  onMatch="ACCEPT" onMismatch="DENY"意思是匹配就接受,否则直接拒绝  -->
        <File name="ERROR" fileName="D:/wznoteserver/error.log">
            <ThresholdFilter level="error" onMatch="ACCEPT" onMismatch="DENY"/>
            <PatternLayout pattern="%d{yyyy.MM.dd 'at' HH:mm:ss z} %-5level %class{36} %L %M - %msg%xEx%n"/>
        </File>
 
        <!--这个会打印出所有的信息,每次大小超过size,则这size大小的日志会自动存入按年份-月份建立的文件夹下面并进行压缩,作为存档 -->
        <RollingFile name="RollingFile" fileName="D:/wznoteserver/web.log"
                     filePattern="D:/wznoteserver/$${date:yyyy-MM}/web-%d{MM-dd-yyyy}-%i.log.gz">
            <PatternLayout pattern="%d{yyyy-MM-dd 'at' HH:mm:ss z} %-5level %class{36} %L %M - %msg%xEx%n"/>
            <SizeBasedTriggeringPolicy size="2MB"/>
        </RollingFile>
    </appenders>
 
 
    <!--然后定义logger,只有定义了logger并引入的appender,appender才会生效 -->
    <loggers>
        <root level="trace">
            <appender-ref ref="RollingFile"/>
            <appender-ref ref="Console"/>
            <appender-ref ref="ERROR" />
            <appender-ref ref="log"/>
        </root>
    </loggers>
</configuration>

============================================================================================================

添加log4j配置

 <!-- log4j配置 -->
    <context-param>  
         <param-name>log4jConfiguration</param-name>  
        <param-value>classpath:conf/log4j2.xml</param-value>  
    </context-param>  

    <listener>
        <listener-class>
        org.apache.logging.log4j.web.Log4jServletContextListener
        </listener-class>
    </listener>

============================================================================================================

在catalina.properties中添加log4j*.jar,\

============================================================================================================

在controller层中

private  Logger logger = LogManager.getLogger(UserController.class);
logger.info("登录:"+user.getUsername());
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值