多进程写日志文件

方法一:

解决log4j公用配置文件,多进程同时写同一个log文件,因存在操作系统pv操作问题, 导致部分日志丢失。解决方案是不同的进程写不同的log文件

测试于:Log4j 1.2.15 | CentOS 5.7

假设有个一个web项目,项目中同时包含一些app,这些app是是需要用java命令来启动的。
每启动一个app就相当于启动一个虚拟机,即一个进程。

问题一:如果公用项目中的log4j,那么必然多进程同时同一个log文件,存在操作系统pv操作问题,
导致部分日志丢失。
问题二:如何实现在代码,log4j等配置文件公用的情况下,不同的进程写不同的log文件?

解决方法:

  1. 在app 用java命令启动的时候增加-D参数。
    假设是Linux 下Java启动脚本中的脚本,只需修改JAVA_OPTS值,即

JAVA_OPTS="-Xms64m -Xmx512m -Djava.awt.headless=true -Dlog4j.log.app=app1"

  1. 在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代码  

  1. <appender name="FILE" class="org.apache.log4j.DailyRollingFileAppender">
  2. lt;param name="File" value="${webapp.root}/WEB-INF/logs/${weblogic.Name}-jrwwg.log" />
  3. <param name="DatePattern" value="'.'yyyy-MM-dd-HH" />
  4. <layout class="org.apache.log4j.PatternLayout">
  5. <param name="ConversionPattern" value="%-5p %c{1} %m%n" />
  6. </layout>
  7. </appender>

web.xml配置片段

Xml代码  

  1. <context-param>
  2. <param-name>log4jConfigLocation</param-name>
  3. <param-value>/WEB-INF/classes/log/log4j.xml</param-value>
  4. </context-param>
  5. <!---定时扫描loj4j配置文件的变化---->

<context-param>

<param-name>log4jRefreshInterval</param-name>

<param-value>6000</param-value>

</context-param>

Xml代码  

  1. <listener>
  2. <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
  3. </listener>

自己实践

用方法一配置 -Dlog4j.log.app=app1  时,


下图中是可以实现的:

 

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

 

用方法二 完美的解决了问题。

log4j 多进程配置要注意的的更多相关文章

  1. commons-logging和Log4j 日志管理/log4j.properties配置详解

    commons-logging和Log4j 日志管理 (zz) 什么要用日志(Log)? 这个……就不必说了吧. 为什么不用System.out.println()? 功能太弱:不易于控制.如果暂时不 ...

  2. springmvc 项目完整示例06 日志–log4j 参数详细解析 log4j如何配置

    Log4j由三个重要的组件构成: 日志信息的优先级 日志信息的输出目的地 日志信息的输出格式 日志信息的优先级从高到低有ERROR.WARN. INFO.DEBUG,分别用来指定这条日志信息的重要程度 ...

  3. Log4J实用配置指南

    转自:http://www.cnblogs.com/licheng/archive/2008/08/23/1274566.html 1         概述 本文档是针对Log4j日志工具的使用指南. ...

  4. Log4j XML配置

    问题描述:     Log4j  XML配置 问题解决:     (1)编写log4j.xml配置文件 注:     如上的XML文件必须以log4j.xml文件命名,否则无法读取配置文件,同样的如果 ...

  5. Hibernate4搭建Log4J日志管理(附Log4j.properties配置详解)

    1.首先加入slf4j的jar包,即slf4j-api-1.6.1.jar 在hibernate官网下载hibernate-release-4.2.2.Final.zip并解压,在hibernate- ...

  6. java之log4j的配置

    java之log4j的配置 log4j有很多的优点,用起来很方便,就是配置起来有些麻烦,下面我介绍一下log4j的配置方法. log4j是用来记录日志的. 软件的运行过程离不开日志.日志主要用来记录系 ...

  7. Log4j.properties配置详细解读

    Log4j.properties配置 Log4j有三个主要的组件:Loggers(记录器),Appenders  (输出源)和Layouts(布局).这里可简单理解为日志类别,日志要输出的地方和日志以 ...

  8. 热切换Log4j级别配置

    欢迎和大家交流技术相关问题:邮箱: jiangxinnju@163.com博客园地址: http://www.cnblogs.com/jiangxinnjuGitHub地址: https://gith ...

  9. java日志框架log4j详细配置及与slf4j联合使用教程

    最后更新于2017年02月09日 一.log4j基本用法 首先,配置log4j的jar,maven工程配置以下依赖,非maven工程从maven仓库下载jar添加到“build path” <d ...

随机推荐

  1. NPOI_winfrom导出Excel表格(二)(直接打开Excel软件,将数据填充在当前的sheet中)

    //// 存储路径弹框选择 SaveFileDialog saveDialog = new SaveFileDialog(); saveDialog.DefaultExt = "xls&qu ...

  2. vi/vim 编辑、搜索、查找、定位

    介绍vi/vim 相关命令,主要涉及:编辑.搜索.查找.定位. 分为两个章节,即常用命令  及 键盘图 一.vi/vim常用命令 set nu 显示行号 gg 跳转到文件开头 / 向后搜索 ? 向前搜 ...

  3. Js 参数乱码

    在前台,对URL的中文参数执行两次encodeURI:  序列化 var param = encodeURI(encodeURI("中文")); 反序列化 decodeURI($. ...

  4. NSIS逻辑函数头文件介绍

    !include "LogicLib.nsh"使用 NSIS 的宏来提供各种逻辑基本语句,不需要预先添加函数. 基本语句 If|Unless..{ElseIf|ElseUnless ...

  5. 向PHP发送HTTP-Post请求

    欢迎访问我的个人博客,获取更多有用的东西 链接一 链接二 也可以关注我的微信订阅号:CN丶Moti 1.post.html <!DOCTYPE html> <html lang=&q ...

  6. javascript实现网页分享至朋友圈功能

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  7. python图像处理-生成随机验证码

    前面说了PIL库,还说了图片的缩放.旋转和翻转.现在说下网站上常用的随机验证码的生成.参考网站:https://www.liaoxuefeng.com/wiki/1016959663602400/10 ...

  8. C++虚函数和纯虚函数的用法和区别

    C++虚函数与纯虚函数用法与区别(转)   1. 虚函数和纯虚函数可以定义在同一个类(class)中,含有纯虚函数的类被称为抽象类(abstract class),而只含有虚函数的类(class)不能 ...

  9. jsonp的原理介绍及Promise封装

    什么叫jsonp? jsonp是json with padding(填充式json或参数式json)的简写,是通过ajax请求跨域接口,获取数据的新实现方式 jsonp的实现原理: 动态创建scrip ...

  10. idea中安装git后,代码颜色代表的含义

    idea中安装git以后,代码文件出现了不同的颜色 它们分别表示的含义: 绿色,已经加入控制暂未提交 红色,未加入版本控制 蓝色,加入,已提交,有改动 白色,加入,已提交,无改动 灰色:版本控制已忽略 ...