log4j 多进程配置要注意的
多进程写日志文件
方法一:
解决log4j公用配置文件,多进程同时写同一个log文件,因存在操作系统pv操作问题, 导致部分日志丢失。解决方案是不同的进程写不同的log文件
测试于:Log4j 1.2.15 | CentOS 5.7
假设有个一个web项目,项目中同时包含一些app,这些app是是需要用java命令来启动的。
每启动一个app就相当于启动一个虚拟机,即一个进程。
问题一:如果公用项目中的log4j,那么必然多进程同时同一个log文件,存在操作系统pv操作问题,
导致部分日志丢失。
问题二:如何实现在代码,log4j等配置文件公用的情况下,不同的进程写不同的log文件?
解决方法:
- 在app 用java命令启动的时候增加-D参数。
假设是Linux 下Java启动脚本中的脚本,只需修改JAVA_OPTS值,即
JAVA_OPTS="-Xms64m -Xmx512m -Djava.awt.headless=true -Dlog4j.log.app=app1"
- 在log4j的配置文件中调用此变量
假设是Log4j 实例配置解析中的配置,需要修改log4j.appender.F.file值,即
log4j.appender.F.file = /logs/basic/${log4j.log.app}/log
假设web项目中有两个app,app1和app2
各自的启动脚本中配置为-Dlog4j.log.app=app1和-Dlog4j.log.app=app2
tomcat启动jvm并没有配置,所以log4j会默认为空,log目录效果如下
app日志会放在相应的app*目录下
web日志由于没有得到-D配置,会放在和app*目录平级的位置,当然如果需要的也可以修改tomcat bin下的catalina.sh,增加-D参数,但为了让项目和web服务器解耦,不推荐这么做。
当然有人可能会说,可以用在启动java进程时将日志重定向到指定的文件中,如
nohup java $JAVA_OPTS $MAIN_CLASS $* > /logs/basic/app1/log &
这种方法的缺点是不能实现日志的自动切割,不能避免日志不断增大甚至占满磁盘的问题。
如过此内容对您有帮助,欢迎以点击广告的形式来支持我们,但请每天不要多于一次,否则可能被识别恶意点击,导致封号。
方法二
1.log4j代码片段(log4j的配置文件支持System Property的环境变量的获取)
<appender name="FILE"
class="org.apache.log4j.DailyRollingFileAppender">
<param name="File"
value="D:/${weblogic.Name}ank.log" />
<param name="DatePattern"
value="'.'yyyy-MM-dd-HH" />
<layout
class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern"
value="%-5p %c{1} %m%n" />
</layout>
</appender>
2.${weblogic.Name}对应的是JAVA启动时环境变量;
看startWebLogic.sh中的代码片段
D:\bea92\JDK150~1\bin\java -client
-Dweblogic.Name=AdminServer
如何设置JAVA启动时的环境变量:
java -D<参数>=<值>
3.使用spring中的Log4jConfigListener把log文件定在 /WEB-INF/logs/ 而不需要写绝对路径。
log4j.xml配置片段:
Java代码
- <appender name="FILE" class="org.apache.log4j.DailyRollingFileAppender">
- lt;param name="File" value="${webapp.root}/WEB-INF/logs/${weblogic.Name}-jrwwg.log" />
- <param name="DatePattern" value="'.'yyyy-MM-dd-HH" />
- <layout class="org.apache.log4j.PatternLayout">
- <param name="ConversionPattern" value="%-5p %c{1} %m%n" />
- </layout>
- </appender>
web.xml配置片段
Xml代码
- <context-param>
- <param-name>log4jConfigLocation</param-name>
- <param-value>/WEB-INF/classes/log/log4j.xml</param-value>
- </context-param>
- <!---定时扫描loj4j配置文件的变化---->
<context-param>
<param-name>log4jRefreshInterval</param-name>
<param-value>6000</param-value>
</context-param>
Xml代码
- <listener>
- <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
- </listener>
自己实践
用方法一配置 -Dlog4j.log.app=app1 时,
在
下图中是可以实现的:

但是在
weblogic中的
server start中
配置 不起作用,如下图:

用方法二 完美的解决了问题。
log4j 多进程配置要注意的的更多相关文章
- commons-logging和Log4j 日志管理/log4j.properties配置详解
commons-logging和Log4j 日志管理 (zz) 什么要用日志(Log)? 这个……就不必说了吧. 为什么不用System.out.println()? 功能太弱:不易于控制.如果暂时不 ...
- springmvc 项目完整示例06 日志–log4j 参数详细解析 log4j如何配置
Log4j由三个重要的组件构成: 日志信息的优先级 日志信息的输出目的地 日志信息的输出格式 日志信息的优先级从高到低有ERROR.WARN. INFO.DEBUG,分别用来指定这条日志信息的重要程度 ...
- Log4J实用配置指南
转自:http://www.cnblogs.com/licheng/archive/2008/08/23/1274566.html 1 概述 本文档是针对Log4j日志工具的使用指南. ...
- Log4j XML配置
问题描述: Log4j XML配置 问题解决: (1)编写log4j.xml配置文件 注: 如上的XML文件必须以log4j.xml文件命名,否则无法读取配置文件,同样的如果 ...
- Hibernate4搭建Log4J日志管理(附Log4j.properties配置详解)
1.首先加入slf4j的jar包,即slf4j-api-1.6.1.jar 在hibernate官网下载hibernate-release-4.2.2.Final.zip并解压,在hibernate- ...
- java之log4j的配置
java之log4j的配置 log4j有很多的优点,用起来很方便,就是配置起来有些麻烦,下面我介绍一下log4j的配置方法. log4j是用来记录日志的. 软件的运行过程离不开日志.日志主要用来记录系 ...
- Log4j.properties配置详细解读
Log4j.properties配置 Log4j有三个主要的组件:Loggers(记录器),Appenders (输出源)和Layouts(布局).这里可简单理解为日志类别,日志要输出的地方和日志以 ...
- 热切换Log4j级别配置
欢迎和大家交流技术相关问题:邮箱: jiangxinnju@163.com博客园地址: http://www.cnblogs.com/jiangxinnjuGitHub地址: https://gith ...
- java日志框架log4j详细配置及与slf4j联合使用教程
最后更新于2017年02月09日 一.log4j基本用法 首先,配置log4j的jar,maven工程配置以下依赖,非maven工程从maven仓库下载jar添加到“build path” <d ...
随机推荐
- spark内存管理详解
Spark 作为一个基于内存的分布式计算引擎,其内存管理模块在整个系统中扮演着非常重要的角色.理解 Spark 内存管理的基本原理,有助于更好地开发 Spark 应用程序和进行性能调优.本文旨在梳理出 ...
- javascript是否像php一样有isset和empty?
javascript是否像php一样有isset和empty? is set()在php中用于检测是否设置了变量木浴桶,函数返回布尔值true/false.在javascript中,您可以用替换它!( ...
- vuex中的this.$store.commit
Vue的项目中,如果项目简单, 父子组件之间的数据传递可以使用 props 或者 $emit 等方式 进行传递 但是如果是大中型项目中,很多时候都需要在不相关的平行组件之间传递数据,并且很多数据需要多 ...
- css高度居中
1.已知元素高度 // 子盒子 #div1{ width:200px; height:200px; position: absolute; //父元素需要相对定位 top: 50%; left: 50 ...
- django orm 数据查询详解
一 在django里面创建模型 from django.db import models class Blog(models.Model): name = models.CharField(max_l ...
- django 使用mysql数据库
一 修改settings里面的配置文件 import pymysql # 一定要添加这两行!通过pip install pymysql! 或者pycharm 里面安装 pymysql.install_ ...
- 入坑django2
数据模型 关于时间的字段设置 add_date = models.DateTimeField('保存日期',default = timezone.now) mod_date = models.Date ...
- 网络初级篇之VLAN间路由(原理与配置)
一.VLAN间的路由 由于VLAN隔离了二层广播域,也间接的隔离了各个VLAN之间的其他二层流量交换,这样导致属于不同VLAN之间的用户不能进行二层的通信.只能经过三层的路由转发才能将报文从一个VLA ...
- 在Linux中,当需要从磁盘读取块时,进程状态会发生什么变化?被封锁了吗?如果是这样,如何选择另一个流程来执行?
当某个进程需要从磁盘中获取数据时,它实际上会停止在CPU上运行以让其他进程运行,因为该操作可能需要很长时间才能完成-至少需要5ms的磁盘寻道时间,而5ms就是1000万从程序的角度来看,CPU周期是永 ...
- python常用模块:包的使用、init作用、相对导入绝对导入与内置函数
今天主要讲的内容有: 一.包的详解二.相对导入和绝对导入三.内置模块补充 一.包的详解 1.包是什么 包其实也是一个模块,只不过是一个大的模块下包含一堆模块的载体 本质上也是一个文件夹,与普通文件的区 ...