Java 不写入控制台

标签 java eclipse tomcat logging

我正在开发一个不会向控制台输出任何内容的 Java EE Web 应用程序。它使用 log4j,将 log4j.properties 文件设置为输出到 stdout。但是,它没有运行,控制台中没有出现任何日志记录。事实证明,即使是 System.out 也没有出现在控制台中。什么可能导致这种情况?

我正在运行 MyEclipse 10.1、log4j-1.2.11、tomcat 5.5.35、java 1.6.0_31。

根据请求,这是我的 .properties 文件:

### direct log messages to stdout ###
# Configure Root Logger
log4j.rootLogger = DEBUG, stdout
log4j.logger.org.hibernate = DEBUG, stdout
#log4j.logger.org.springframework = ERROR, stdout

# Configure stdout Appender 
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern =%d [%t] %-5p %c - %m%n

和日志处理程序:

public class LogHandler {
private static Logger sLog = Logger.getLogger(LogHandler.class);
public LogHandler(){

}
public void info_toLOG(String msg00) {
    sLog.info("\n" + msg00 + "\n");
}

public void error_toLOG(Exception e) {
    sLog.error("\n" + e.getClass() + "\n"
            + e.getCause() + "\n"
            + e.getMessage() + "\n"
            + e.getLocalizedMessage() + "\n"
            + e.getStackTrace().toString() + "\n");
}

public void warning_toLOG(String msg00) {
    sLog.warn("\n" + msg00 + "\n");
}

我使用 MyEclipse 来启动和停止。只需指向我的 tomcat 安装目录。 MyEclipse 添加了以下 VM 参数:

-Dcatalina.home="<tomcat dir>" 
-Dcatalina.base="<tomcat dir> " 
-Djava.endorsed.dirs="<tomcat dir>/common/endorsed" 
-Djava.io.tmpdir="<tomcat dir>/temp" 
-Djava.library.path=/System/Library/Java/JavaVirtualMachines/1.6.0.jdk/Contents/Home/bin:"<tomcat dir>/bin" 
-Dsun.io.useCanonCaches=false 
-Xmx1024M

编辑: 感谢那些试图提供帮助的人。我应该在最初的问题中说明我正在运行 Mac OS X 10.7.3。在 Utilities -> Java Preferences -> Advanced -> Java Console 下有一个设置,一旦设置为 Show Console 就纠正了这个问题。

最佳答案

在 Tomcat 中,您的 System.out 和 System.err 将转到 catalina.out 日志文件。请在那里检查你的输出。

更新 刚刚测试了您的确切 log4j 配置后,我可以确认输出已发送至 tomcat7-stdout.<date>.log在 Tomcat 7 Windows 上。

2012-04-27 15:59:47 Commons Daemon procrun stdout initialized
2012-04-27 15:59:51,955 [http-apr-8080-exec-3] INFO  org.apache.log4j.Logger - hey log
blah

这个日志文件名对于 Tomcat 5.5 会有所不同,它应该是 catalina.out在 Linux 中,它在 Windows 中会有不同的名称(所以文档说,我不知道)。

这是代码:

Logger l = Logger.getLogger(Logger.class);
l.info("hey log");
System.out.println("blah");

UPDATE2 在 Eclipse 下,这种类型的输出应该转到 Eclipse 控制台,尝试构建您的 WAR 文件并将其部署到独立的 Tomcat 中以验证上述内容。

关于Java 不写入控制台,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10351753/

相关文章:

spring - 异常启动过滤器springSecurityFilterChain

java - 如何调用我在某人链接到的 wsdl 文件中看到的方法?

java - Eclipse 在启动时读取错误的导入

java - 使用 jdbc 在 volt-db 中创建表

java - eclipse - hibernate : No suitable driver found for jdbc:mysql://localhost:3306/hibernatedb

用于删除(非 Javadoc)@see 注释的正则表达式?

java - 无法在 NetBeans 中访问 Tomcat

mysql - Amazon Web Services - RDS IP 地址和 Tomcat

java - 在没有项目的情况下在 Eclipse 中导航导入

java - ArrayList 作为 HashMap 的值仅返回 ArrayList 的最后一个元素