我使用了来自Maven repo的log4j-1.2.17软件包。 我尝试在bundle中执行此代码(我的bundle调用log4j-1.2.17包)
PropertyConfigurator.configure(props());
private static Properties props() {
Properties props = new Properties();
props.put("log4j.rootLogger", "INFO, R");
props.put("log4j.appender.R",
"org.apache.log4j.DailyRollingFileAppender");
props.put("log4j.appender.R.File", "logs/IhtikaClient.log");
props.put("log4j.appender.R.Append", "true");
props.put("log4j.appender.R.Threshold", "INFO");
props.put("log4j.appender.R.DatePattern", "'.'yyyy-MM-dd");
props.put("log4j.appender.R.layout", "org.apache.log4j.PatternLayout");
props.put("log4j.appender.R.layout.ConversionPattern",
//"%d{HH:mm:ss,SSS} %c - %m%n");
//"[%5p] %d{yyyy-MM-dd mm:ss} (%F:%M:%L)%n%m%n%n");
"[%5p] %d{yyyy-MM-dd mm:ss} %c (%F:%M:%L)%n%m%n");
return props;
}
但我有错误
log4j:ERROR A "org.apache.log4j.DailyRollingFileAppender" object is not assignable to a "org.apache.log4j.Appender" variable.
log4j:ERROR The class "org.apache.log4j.Appender" was loaded by
log4j:ERROR [org.apache.felix.framework.BundleWiringImpl@9da1dd] whereas object of type
log4j:ERROR "org.apache.log4j.DailyRollingFileAppender" was loaded by [sun.misc.Launcher$AppClassLoader@4b222f].
log4j:ERROR Could not instantiate appender named "R".
log4j:ERROR A "org.apache.log4j.DailyRollingFileAppender" object is not assignable to a "org.apache.log4j.Appender" variable.
log4j:ERROR The class "org.apache.log4j.Appender" was loaded by
log4j:ERROR [org.apache.felix.framework.BundleWiringImpl@9da1dd] whereas object of type
log4j:ERROR "org.apache.log4j.DailyRollingFileAppender" was loaded by [sun.misc.Launcher$AppClassLoader@4b222f].
log4j:ERROR Could not instantiate appender named "R".
Bundles已按顺序加载
.getBundleContext().installBundle("......../log4j-1.2.17.jar")
.getBundleContext().installBundle("......../I_MainForm-1.0-SNAPSHOT.jar")
如何解决此错误? 拜托,对不起我的英语。 最好的问候,亚瑟。
答案 0 :(得分:7)
基本上,不要使用org.osgi.framework.system.packages
或org.osgi.framework.system.packages.extra
将您的类“泄漏”到框架中,除非您真的需要在代码中而不是修复其他一些问题。显然,这是log4j问题。
您可以通过设置系统属性来修复它:
-Dlog4j.ignoreTCL=true
答案 1 :(得分:4)
由于您的Log4j类似乎已由sun.misc
类加载器加载,我认为有些东西是从OSGi外部提供log4j类。事实上有Log4J条目解释了为什么它无法加载Log4J类意味着某些版本的Log4J 已经存在。
您使用的是Felix的自定义版本吗?如果是这样,你能找到类似带有org.osgi.framework.system.packages=...
条目或org.osgi.framework.system.packages.extra=...
条目的配置文件吗?
如果您只是删除Log4j捆绑包会发生什么?它还能找到Log4j类吗?
问候,弗兰克
答案 2 :(得分:0)
在OSGi中,在自己的代码中设置log4j并不是一个好主意。你应该看看ops4j pax日志记录。它负责日志框架设置,您只需在捆绑中使用log4j api即可。请参阅:http://team.ops4j.org/wiki/display/paxlogging/Pax+Logging