通过用户输入动态更改Log4J的阈值

时间:2013-11-01 13:41:01

标签: java sockets logging log4j

我正在编写一个简单的控制台应用程序,它通过用户命令(例如"send hello" - >)向套接字发送数据和从套接字接收数据。从套接字接收"hello"。其中一个可用的命令应该是logLevel (ALL|WARN|DEBUG|etc.),它允许用户设置我在整个应用程序中使用的Log4J记录器的日志级别。

现在,我在属性文件中指定了两个Appender:

# Root logger option
log4j.rootLogger=INFO, file, stdout

# Direct log messages to a log file
log4j.appender.file=org.apache.log4j.RollingFileAppender
log4j.appender.file.File=./logs/client.log
log4j.appender.file.MaxFileSize=10MB
log4j.appender.file.MaxBackupIndex=1
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n

# Direct log messages to stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
# info and above messages are printed to stdout
log4j.appender.stdout.Threshold=INFO
log4j.appender.stdout.Target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n

我的目标是将所有日志条目从任何级别发送到日志文件,但只发送与用户当前为stdout设置的指定日志级别匹配的日志条目。示例工作流程可能如下所示:

> INFO: current log level is INFO and above.
> send hello
> INFO: sending hello to server
> INFO: receiving "hello" from server
> logLevel WARN
> INFO: log level set to warn
> send hello
> # no info here, but its still sent to the logfile

2 个答案:

答案 0 :(得分:6)

  

我的目标是将所有日志条目从任何级别发送到日志文件,但只发送与用户当前为stdout设置的指定日志级别匹配的日志条目。

基本上你想以编程方式更改stdout appender的阈值。这很容易做到,皱纹是阈值属性是AppenderSkeleton抽象类(ConsoleAppender扩展)的一部分,而不是Appender接口本身。

((AppenderSkeleton)Logger.getRootLogger().getAppender("stdout"))
   .setThreshold(Level.toLevel(levelNameProvidedByUser));

如果您确实希望所有日志消息转到该文件,那么您应该将根记录器级别配置为ALL而不是log4j.properties中的INFO,并依赖阈值过滤标准输出。

答案 1 :(得分:1)

我的要求是将特定日志添加到我的一个日志文件中。我有两个日志文件。一个正常情况和其他我只需要添加特定的日志。意味着我必须默认关闭阈值。一旦需要,我必须创建阈值INFO并将日志添加到我的日志文件,然后再次使阈值关闭。 这是我的java代码

org.apache.log4j.Logger logger = org.apache.log4j.Logger.getRootLogger();
Appender appender = logger.getAppender("logFileName");
((AppenderSkeleton)appender).setThreshold(Level.INFO);
logger.info(myString.toString());
((AppenderSkeleton)appender).setThreshold(Level.OFF);

因此只有myString会记录到我的logFileName文件。