解决 log4j 在 linux 上出现乱码的问题

转载:http://blog.youkuaiyun.com/lzc3144/article/details/7643210


使用log4j的时候,在WIN系统的时候正常显示中文,但是发布到linux系统的时候中文就显示成乱码了

由于log4j配置文件中没有设置编码格式(encoding),所以log4j就使用系统默认编码。导致乱码。

解决方法是设置编码格式UTF-8,方法为(有时改成UTF-8还是会乱码,需要设置成GBK,这可能跟你输入的字符的编码有关):

log4j.appender.logfile.encoding=UTF-8

 

 

#### file log #####

log4j.appender.logfile=org.apache.log4j.RollingFileAppender

log4j.appender.logfile.File=D:/log/shop/logs.log

log4j.appender.logfile.MaxFileSize=5MB

log4j.appender.logfile.Threshold=DEBUG

log4j.appender.logfile.layout=org.apache.log4j.PatternLayout

log4j.appender.logfile.layout.ConversionPattern=[%d{MM/ddHH:mm:ss,SSS}] [%-3p] %c{1}: %m%n

log4j.appender.logfile.encoding=UTF-8


### Linux环境中log4j日志配置与管理 在Linux环境下的`log4j`日志配置主要依赖于其配置文件来实现各种功能,包括但不限于设置日志级别、指定日志输出位置以及定义日志格式等[^4]。 #### 配置文件结构解析 对于`log4j.properties`或者`log4j.xml`这样的配置文件而言,通常会涉及到以下几个方面: - **根记录器(Root Logger)**: 定义全局的日志等级,默认情况下可以是DEBUG, INFO, WARN, ERROR 或 FATAL中的任何一个。这决定了哪些级别的消息会被处理。 - **Appenders (附加器)**: 这些是用来控制如何存储或发送日志数据的对象。常见的有File Appender用于向特定文件写入日志;Console Appender则负责把日志打印到标准输出流上,在调试期间非常有用。还可以设定编码方式以防止乱码现象的发生,比如通过如下语句设置UTF-8编码:`log4j.appender.stdout.encoding=UTF-8`[^1]。 - **Layouts (布局)**: 布局对象用来规定每条日志的具体呈现形式。Pattern Layout是最常用的类型之一,允许自定义复杂的模式字符串来自由组合时间戳、线程名、类别名称等内容形成最终的日志行。 #### 解决乱码问题的方法 当遇到中文字符显示异常的情况时,可以通过调整Log4J配置文件内的编码参数来解决问题。具体做法是在相应的appender部分增加encoding属性并赋值为系统默认使用的字符集,例如UTF-8。这样就能确保从应用程序产生的所有非ASCII字符都能被正确解释和展示。 #### Tomcat集成实例 如果项目运行在一个基于Tomcat的应用服务器之上,则可能还需要特别关注一下Web应用启动过程中加载logging框架的方式。为了使Log4J能够正常工作,可以在web.xml中注册监听器`org.apache.logging.log4j.web.Log4jServletContextListener`以便初始化必要的资源[^2]。与此同时,也要记得按照实际需求定制化地指明日志文件的位置,像下面这段配置就说明了将日志保存至Tomcat安装目录下logs子文件夹里的名为`logs_tomcat.log`的文档里去[^3]: ```properties log4j.appender.R.File=${catalina.home}/logs/logs_tomcat.log ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值