log4j配置在was中无效
在was中要看日志很不方便,默认情况下是在was自己的System.out文件中(可以在“故障诊断”——“日志和跟踪”——“记录和跟踪 > server1 > JVM 日志”中看到路径)。这是log4j中配置的日志就不会生成。
在目录:
/opt/IBM/WebSphere/AppServer/profiles/AppSrv01/properties
增加一个文件名:
commons-logging.properties
内容为
org.apache.commons.logging.LogFactory=org.apache.commons.logging.impl.LogFactoryImpl
问题解决。
原因:
在 $WAS_HOME/lib/ws-commons-logging.jar 中有个文件 commons-logging.properties,其中有一行 org.apache.commons.logging.LogFactory=com.ibm.ws.commons.logging.TrLogFactory,虽然你的应用中可能也有一个 commons-logging.properties,可是很不幸,WAS 自己的 commons-logging.properties 优先了,原因是类加载器的委托机制在作用,所以最终 log4j 没派上用场,被 com.ibm.ws.commons.logging.TrLog 取而代之了,解决办法是要抢在它之前,比系统属性中声明 LogFactory 实现类,或是在 META-INF/services/org.apache.commons.logging.LogFactory 中指名 org.apache.commons.logging.impl.Log4jFactory 或 org.apache.commons.logging.impl.LogFactoryImpl 作为实现类名。
引用: http://blog.sina.com.cn/s/blog_8f768e7b010117u8.html
生成的日志文件路径是在当前工程的war文件夹下,可以用find /opt/IBM -name 文件名查找,eg:
[root@localhost IBM]# find . -name myapp.log
./WebSphere/AppServer/profiles/AppSrv01/installedApps/localhostNode01Cell/myapp_war.ear/myapp.war/logs/myapp.log
推荐阅读
-
在Python的Django框架中调用方法和处理无效变量
-
在Windows平台的Apache中配置Python
-
详解ASP.NET Core 在 JSON 文件中配置依赖注入
-
快速解决vue-cli在ie9+中无效的问题
-
在Windows中配置Rsync同步文件的方法
-
在Nginx服务器中配置针对TCP的负载均衡的方法
-
在centos 7中安装配置k8s集群的步骤详解
-
在Asp.Net或.Net Core中配置使用MarkDown富文本编辑器有开源模板代码(代码是.net core3.0版本)
-
在Asp.Net Core中配置使用MarkDown富文本编辑器实现图片上传和截图上传(开源代码.net core3.0)
-
在VSCode中如何配置Python开发环境