日志管理体系1 (Log4j+Commons-Logging)

 使用Log4j+Commons-Logging来进行日志的管理

1.导入依赖

<dependencies>
    <!-- https://mvnrepository.com/artifact/log4j/log4j -->
    <dependency>
        <groupId>log4j</groupId>
        <artifactId>log4j</artifactId>
        <version>1.2.17</version>
    </dependency>
    <!-- https://mvnrepository.com/artifact/commons-logging/commons-logging -->
    <dependency>
        <groupId>commons-logging</groupId>
        <artifactId>commons-logging</artifactId>
        <version>1.2</version>
    </dependency>

    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.12</version>
    </dependency>
</dependencies>

2.基本使用

public class LogTest {

    //日志对象
    private Log log = LogFactory.getLog(LogTest.class);

    @Test
    public void test1() {
        log.trace("hello trace");
        log.debug("hello debug");
        log.info("hello info");
        log.warn("hello warn");
        log.error("hello error");
        log.fatal("hello fatal");
    }
}

配置一个追加器,在resources里面创建一个log4j.xml的文件

 

<?xml version="1.0"  encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration PUBLIC "-//LOGGER"
        "http://org/apache/log4j/xml/log4j.dtd">
<log4j:configuration>

    <!-- org.apache.log4j.ConsoleAppender 输出到控制台 -->
    <appender name="myConsole" class="org.apache.log4j.ConsoleAppender">
        <!--输出格式-->
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern"
                   value="%-d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n"/>
        </layout>
    </appender>

    <!-- 根logger的设置-->
    <root>
        <!--优先级设置,all < trace < debug < info < warn < error < fatal < off -->
        <priority value="all"/>
        <appender-ref ref="myConsole"/>
    </root>
</log4j:configuration>

输出运行结果

写完控制台输出之后,我们再来研究如何输入保存到本地文件

在resources里面的log4j.xml中添加这样的配置

<!-- 输出到文件 -->
<appender name="myFile1" class="org.apache.log4j.RollingFileAppender">
    <param name="File" value="e:/log/hello.log"/><!--文件位置-->
    <param name="Append" value="true"/><!--是否选择追加-->
    <param name="MaxFileSize" value="1kb"/><!--文件最大字节数-->
    <param name="MaxBackupIndex" value="2"/><!--新文件数量-->
    <layout class="org.apache.log4j.PatternLayout">
        <param name="ConversionPattern" value="%-d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n"/>
    </layout>
</appender>

 在<root>里面配置logger

<appender-ref ref="myFile1"/>

我们再来运行可以看到在我本地多了一个日志文件

 

里面正是打印的日志信息

第二种方式:每天都生成一个日志文件

<!-- 输出到文件 (每天都生成一个日志文件)-->
<appender name="myFile2" class="org.apache.log4j.DailyRollingFileAppender">
    <param name="File" value="e:/log/world.log"/><!--文件位置-->
    <param name="Append" value="true"/><!--是否选择追加-->
    <layout class="org.apache.log4j.PatternLayout">
        <param name="ConversionPattern"
               value="%-d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n"/>
    </layout>
</appender>
<appender-ref ref="myFile2"/>

 这里我们循环10次日志信息

@Test
    public void test1() {
        for(int i=1;i<10;i++)
        {
            log.trace("hello trace"+i);
            log.debug("hello debug"+i);
            log.info("hello info"+i);
            log.warn("hello warn"+i);
            log.error("hello error"+i);
            log.fatal("hello fatal"+i);
        }
    }

运行效果

到此我们就学完第一种日志配置方法的使用 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果您想要使用Commons LoggingLog4J 2进行日志记录,可以按照以下步骤进行配置: 1. 首先,您需要添加以下依赖项到您的项目中: ``` <dependency> <groupId>org.apache.logging.log4j</groupId> <artifactId>log4j-api</artifactId> <version>2.x.x</version> </dependency> <dependency> <groupId>org.apache.logging.log4j</groupId> <artifactId>log4j-core</artifactId> <version>2.x.x</version> </dependency> <dependency> <groupId>commons-logging</groupId> <artifactId>commons-logging</artifactId> <version>1.2</version> </dependency> ``` 其中,`log4j-api`和`log4j-core`是Log4J 2的核心依赖项,而`commons-logging`则是Commons Logging依赖项。 2. 在项目的classpath下添加一个`log4j2.xml`配置文件,例如: ``` <?xml version="1.0" encoding="UTF-8"?> <Configuration status="WARN"> <Appenders> <Console name="Console" target="SYSTEM_OUT"> <PatternLayout pattern="%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/> </Console> </Appenders> <Loggers> <Root level="info"> <AppenderRef ref="Console"/> </Root> </Loggers> </Configuration> ``` 这个示例配置文件将日志记录到控制台,并将日志级别设置为`info`。 3. 在代码中使用Commons Logging进行日志记录,例如: ``` import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; public class MyClass { private static final Log LOG = LogFactory.getLog(MyClass.class); public void doSomething() { LOG.info("Doing something..."); } } ``` 在这个示例中,`MyClass`使用Commons Logging来获取日志记录器实例,并在`doSomething()`方法中记录一条日志。 运行应用程序时,您应该可以在控制台上看到与配置文件中定义的日志级别匹配的日志消息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值