log4j2使用总结
一、Log4j有三个主要的组件:Loggers,Appenders和Layouts,这里可简单理解为日志级别,日志要输出的地方和日志格式
1、
Logger
Logger的日志级别有6级,分别是TRACE<DEBUG
< INFO < WARN < ERROR < FATAL 分别按照一定的等级来表示此条日志的重要程度
2、
appender常用的输出有控制台、文件、数据库等
二、Log4j2配置
1、web.xml配置文件
|
1
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
<listener>
<listener-class>org.apache.logging.log4j.web.Log4jServletContextListener</listener-class> </listener> <filter> <filter-name>log4jServletFilter</filter-name> <filter-class>org.apache.logging.log4j.web.Log4jServletFilter</filter-class> </filter> <filter-mapping> <filter-name>log4jServletFilter</filter-name> <url-pattern>/*</url-pattern> <dispatcher>REQUEST</dispatcher> <dispatcher>FORWARD</dispatcher> <dispatcher>INCLUDE</dispatcher> <dispatcher>ERROR</dispatcher> </filter-mapping> |
2、log4j2的配置文件:log4j2.xml
,建在类路径下
|
1
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 |
<?xml version="1.0" encoding="utf-8"?>
<Configuration status="off" monitorInterval="1800"> <properties> <property name="filename">d:/logs/log4j.log</property> </properties> <Appenders> <!--输出到控制台配置--> <Console name="Console"> <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss } %p %l %m%n" /> </Console> <!--输出到文件配置--> <RollingFile name="file" fileName="${filename}" filePattern="d:/logs/log4j--%d{yyyy-MM-dd}.log.gz"> <PatternLayout pattern="%d{HH:mm:ss.SSS} %p %C:%L %m%n" /> <TimeBasedTriggeringPolicy interval="1" modulate="“true”" /> </RollingFile> </Appenders> <Loggers> <!--com.render包下的日志输出策略,输出warn级别及以上级别的日志到控制台和文件--> <Logger name="com.render" level="warn" additivity="false"> <AppenderRef ref=" Console" /> <AppenderRef ref="file" /> </Logger> <!--其它日志输出策略--> <Root level="error"> <AppenderRef ref="file" /> <AppenderRef ref="Console" /> </Root> </Loggers> </Configuration> |
上述配置可以将日志打印到控制台的同时,保存到文件
除此之外,log4j2的JDBC Appender还支持将日志输出到数据库保存
首先,需要配置一个JNDI数据源,具体配置方式可参见:
[Tomcat下配置Jndi数据源](http://blog.csdn.net/kris234seth/article/details/46694971)
之后在上述log4j2的配置文件中新增Jdbc Appender之后的配置:
|
1
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 |
<?xml version="1.0" encoding="utf-8"?>
<Configuration status="off" monitorInterval="1800"> <properties> <property name="filename">d:/logs/log4j.log</property> </properties> <Appenders> <!--输出到控制台配置--> <Console name="Console"> <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss } %p %l %m%n" /> </Console> <!--输出到文件配置--> <RollingFile name="file" fileName="${filename}" filePattern="d:/logs/log4j--%d{yyyy-MM-dd}.log.gz"> <PatternLayout pattern="%d{HH:mm:ss.SSS} %p %C:%L %m%n" /> <TimeBasedTriggeringPolicy interval="1" modulate="“true”" /> </RollingFile> <!--JdbcAppender配置--> <JDBC name="JdbcAppender" tableName="logger"> <DataSource jndiName="java:/comp/env/jndi" /> <!--日期时间配置--> <Column name="eventDate" isEventTimestamp="true" /> <!--日志输出级别--> <Column name="level" pattern="%level" /> <!--日志对应的类--> <Column name="Class" pattern="%C:%L" /> <!--日志对应的方法--> <Column name="Method" pattern="%M" /> <!--日志内容--> <Column name="message" pattern="%message" /> <!--本次操作请求的ip地址--> <Column name="ip" pattern="%X{ip}" /> <!--本次操作请求的用户id--> <Column name="userid" pattern="%X{userid}" /> </JDBC> </Appenders> <Loggers> <!--com.render包下的日志输出策略,输出warn级别及以上级别的日志到控制台和文件--> <Logger name="com.render" level="warn" additivity="false"> <AppenderRef ref=" Console" /> <AppenderRef ref="file" /> </Logger> <!--其它日志输出策略--> <Root level="error"> <AppenderRef ref="file" /> <AppenderRef ref="Console" /> </Root> </Loggers> </Configuration> |
说明:logger为保存日志的表名,jndiName为容器中配置的JNDI数据源的名称,column元素中的name属性为表的字段名
注意:上述配置中的最后2项,即用户id和ip地址(可以使其它任何信息)是需要单独来进行处理,才能在数据库保存成功,这时需要借助org.apache.log4j.MDC这个类来对id和ip进行设置。MDC是一个保存特定context数据的map,类似于session对象。具体使用方式如下:
|
1
2 3 4 5 6 |
;
...0”; MDC.put(“userid”, userid); MDC.put(“ip”, ip); logger.info(“来自ip地址为:” +ip + “, id为” +userid + “的用户请求”); |
注意:一定要在在日志打印语句之前进行id和ip信息(同样可以是其它任何需要的信息)的设置!
这样设置之后,在配置文件中就可以使用%X{ip}、%X{userid}来取到对应的值。
除此之外,对于要保存的一些公共的信息,每次在打印日志的时候都需要使用MDC来进行设置,这对于代码的书写时很繁琐的,解决这个问题,我们可以把这些信息的设置放置到一个过滤器中,在请求开始的时候就进行相关信息的设置,这样就不需要每次都单独设置了。
|
1
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 |
public class AuthenticationFilter implements Filter
{ @Override public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { HttpServletRequest re = (HttpServletRequest) request //这里可以从request中获取到session中的用户相关信息、ip地址、请求的uri等等信息 try { MDC.put(); chain.doFilter(request, response); } finally { MDC.remove("userid "); } } } |
增加了过滤器之后还需要在web.xml文件中增加过滤器的相关配置,如下
<filter>
< filter-name > AuthFilter < /filter-name >
< filter-class > com.log4jmdc.AuthenticationFilter </filter-class >
</filter >
< filter-mapping >
< filter-name > AuthFilter </filter-name>
< url-pattern >/*</url-pattern>
</filter-mapping>
以上所有的配置都完成了,启动项目可以进行测试,看看日志有没有存到数据库吧!
log4j2使用总结的更多相关文章
- dubbox升级spring到4.x及添加log4j2支持
今天花了点时间,把dubbox依赖的spring从3.x升级成最新版的4.x了,其它一些依赖的组件也顺带升级了,同时dubbo支持的第三方日志组件居然没有log4j2,加了点代码也一并支持了,蛋疼的是 ...
- 聊一聊log4j2配置文件log4j2.xml
一.背景 最近由于项目的需要,我们把log4j 1.x的版本全部迁移成log4j 2.x 的版本,那随之而来的slf4j整合log4j的配置(使用Slf4j集成Log4j2构建项目日志系统的完美解决方 ...
- 使用Slf4j集成Log4j2构建项目日志系统的完美解决方案
一.背景 最近因为公司项目性能需要,我们考虑把以前基于的log4j的日志系统重构成基于Slf4j和log4j2的日志系统,因为,使用slf4j可以很好的保证我们的日志系统具有良好的兼容性,兼容当前常见 ...
- log4j2.xml实用例子
一个多月前,我写了篇关于log4j.xml配置的文章,点击此处查看:http://www.cnblogs.com/guogangj/p/3931397.html 最近,我把自己的log4j升级到2.0 ...
- log4j2 不使用配置文件,动态生成logger对象
大家平时使用Log4j一般都是在classpath下放置一个log4j的配置文件,比如log4j.xml,里面配置好Appenders和Loggers,但是前一阵想做某需求的时候,想要的效果是每一个任 ...
- Log4j2 - 配置
官方文档:http://logging.apache.org/log4j/2.x/index.html 1 概述 Log4j2的配置包含四种方式,其中3种都是在程序中直接调用Log4j2的方法进行配置 ...
- MyBatis - MyBatis使用log4j2显示sql和结果集
mybatis-config.xml <settings> <setting name="logImpl" value="LOG4J2" /& ...
- web项目 log4j2的路径问题
项目中用到log4j2记录日志,结果运行的时候总也不见log文件的产生. 查看官方文档得知,在web项目中使用log4j2需要加入log4j-web包 log4j2.xml <?xml vers ...
- 在java下使用log4j2记录日志
1.定义: log4j2 指log4j 2.X及以上版本 2.安装 log4j-core-xx.jarlog4j-api-xx.jarlog4j-web-xx.jar(web项目的需要引用) 3.配置 ...
- log4j2配置详解
1. log4j2需要两个jar log4j-api-2.x.x.jar log4j-core-2.x.x.jar .log4j和log4j2有很大的区别,jar包不要应错. 2. ...
随机推荐
- ganglia的yum插件的配置
由于默认的centos的库是不存在ganglia的相关软件,因此要重新配置yum的库 配置yum库 安装yum优先级插件 yum install yum-priorities 安装Epel 此处是6 ...
- CodeForces 489A (瞎搞) SwapSort
题意: 给n个整数(可能有重复),输出一个不超过n次交换的方案,使得经过这n次交换后,整个序列正好是非递减的. 分析: 首先说题解给的算法. 从左到右扫一遍,交换第i个数和它后面最小的那个数. 代码看 ...
- BZOJ_1030_[JSOI2007]_文本生成器_(AC自动机+DP)
描述 http://www.lydsy.com/JudgeOnline/problem.php?id=1030 给出一些单词,问长度为\(m\)的文章有多少文章中出现过任意一个或多个单词. 分析 文章 ...
- jquery dialog-优雅的弹出框
前面一章已经对datepicker的使用,做了简单的说明.这一章主要对dialog如何使用做个说明. jquery ui-dialog在web开发中运用还是比较多的.最常见的例子就是登 ...
- ti processor sdk linux am335x evm /bin/setup-host-check.sh hacking
#!/bin/sh # # ti processor sdk linux am335x evm /bin/setup-host-check.sh hacking # 说明: # 本文主要对TI的sdk ...
- Nginx - 指定log_format,常用于 Awstats 分析
1. vim /etc/nginx/nginx.conf (下面格式, Awstats 使用) log_format new_log '$remote_addr - $remote_user [$ti ...
- 【C#学习笔记】读access2007
using System; using System.Data.OleDb; namespace ConsoleApplication { class Program { static void Ma ...
- 【C#学习笔记】结构体使用
using System; namespace ConsoleApplication { struct _st { public string name; public int age; } clas ...
- LeetCode: 3SumClosest
Title : Given an array S of n integers, find three integers in S such that the sum is closest to a g ...
- 【字符串处理】HDOJ-1020-Encoding
[题目链接:HDOJ-1020] 相邻字符,两两比较. #include<cstdio> #include<cstring> ; char sr[MAXN]; int main ...