解决JBOSS与log4j冲突的完美配置指南
需积分: 43 176 浏览量
更新于2024-09-13
收藏 67KB DOC 举报
"本文主要介绍了如何解决JBoss与log4j之间的配置冲突,并提供了一种理想的配置方案。主要内容包括修改`jboss-service.xml`和`jbossweb-tomcat55.sar/META-INF/jboss-service.xml`文件,以及创建一个用于初始化的InitServlet来指定log4j的配置文件路径。"
在Java应用服务器JBoss中,log4j作为日志处理框架,有时会遇到与服务器自身的日志系统冲突的问题。为了解决这种冲突,我们可以按照以下步骤进行配置:
1. 调整`jbossweb-tomcat55.sar/META-INF/jboss-service.xml`文件:
- 在`jbossweb-tomcat55.sar/META-INF/jboss-service.xml`文件中,找到`Java2ClassLoadingCompliance`和`UseJBossWebLoader`两个属性,将它们都设置为`false`。这样做可以防止JBoss使用自己的类加载机制,从而避免与log4j的类加载冲突。
- 如果你的应用程序目录下有`WEB-INF/jboss-web.xml`文件,同样需要将其中的`java2ClassLoadingCompliance`和`java2ParentDelegation`属性设置为`false`。
2. 修改`jboss-service.xml`文件中的`Log4jService`设置:
- 在`jboss-service.xml`的`org.jboss.logging.Log4jService`服务定义中,添加一个名为`CatchSystemOut`的属性,将其值设置为`false`。这将阻止JBoss捕获控制台输出,让log4j能够正常输出日志到控制台。
- 同时,可考虑设置`Log4jQuietMode`为`true`,以便在启动时减少log4j的启动输出。
3. 创建InitServlet来初始化log4j配置:
- 创建一个Servlet子类,命名为`InitServlet`,并在其`init`方法中使用`PropertyConfigurator.configure()`方法,指定log4j读取应用程序下`WEB-INF/classes/log4j.properties`的配置文件。这样可以确保log4j使用的是应用级的配置,而不是服务器级别的。
- 在`web.xml`文件中注册这个Servlet,并为其设置初始化参数,以指定`log4j.properties`的位置。
通过以上配置,我们可以有效地解决JBoss与log4j之间的冲突,实现自定义的日志配置。同时,通过InitServlet确保了应用启动时log4j的正确初始化,使得日志输出符合预期。这样的配置方式对于优化日志管理和调试环境十分有帮助。
330 浏览量
2007-09-19 上传
129 浏览量
2023-04-26 上传
321 浏览量
2024-09-24 上传
107 浏览量
165 浏览量
feiwen20
- 粉丝: 0
- 资源: 1
最新资源
- 50个CSS超炫丽button样式代码下载
- pid控制器代码matlab-PID_Node.js_Framework:PID_Node.js_Framework
- dask-blog:达斯发展博客
- KMVDR.rar_MVDR宽带_mvdr wideband_宽带mvdr_波束形成
- 行业文档-设计装置-一种折叠式英语书写练习专用书写板.zip
- symbiomon:SYMBIOMON监视微服务
- 设计:设计材料,海报以及更多代表SAIG的作品。 :artist_palette:
- case1
- RAIM算法集合(卫星导航).zip
- 翻牌消除、翻牌消除代码
- learn-scala-3:现代Scala沙箱
- Flatland 2D Physics Library-开源
- 行业文档-设计装置-一种拖动式太阳能热水器清尘刷.zip
- 7958013659
- pid控制器代码matlab-SeniorProject2018-2019:高级项目2018-2019
- 行业文档-设计装置-一种折叠式纸盒.zip