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
推荐阅读
-
log4j配置在was中无效
-
[sql Server]除非另外还指定了TOP 或 FOR XML,否则,ORDER BY 子句在视图、内联函数、派生表、子查询和公用表表达式中无效
-
关于session在PHP5的配置文件中的详细设置参数说明_PHP教程
-
.NET Core在类库中读取配置文件appsettings.json
-
教你在PHPStorm中配置Xdebug_PHP
-
探讨fckeditor在Php中的配置详解_php技巧
-
说说在 Spring Boot 中如何配置数据源
-
在CentOS6.4中安装配置LAMP环境的详细步骤_PHP教程
-
在APACHE中,同一个IP配置两个虚拟主机的例子
-
探讨fckeditor在Php中的配置详解_PHP教程