我有一个 EAR,它只有 EJB (EJB3.0),没有 WAR 模块,服务器是 Linux 上的 JBOSS 4.3。
我想在服务器外部使用 log4j.properties 文件初始化 LOG4J,并使用 slf4j 作为外观。
初始化 log4j 的最佳方法是什么?
提前致谢
最佳答案
我已经在启动中初始化并将log4j放入META-INF文件夹中。并且只使用log4j而不使用Slf4j。 (EJB 3.1)
我希望下面的代码有帮助;
import org.apache.log4j.BasicConfigurator;
import org.apache.log4j.Logger;
import org.apache.log4j.PropertyConfigurator;
@Singleton
@Startup
public class InitClass {
@PostConstruct
private void log4jIlkle() {
String log4jProp = yourlog4jPath;//My path definition maybe put more flexible path: "../applications/DeployName/META-INF/log4j.properties";
File logFile = new File(log4jProp);
if (logFile.exists()) {
System.out.println("Log4j init: " + log4jProp);
PropertyConfigurator.configure(log4jProp);
}
else {
System.err.println("*** " + log4jProp + " file not found, initialize with default settings");
BasicConfigurator.configure();
}
}
}
关于java - 使用 EJB 3.0 初始化 log4j 的最佳方法是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8834610/