我正在编写一个简单的控制台应用程序,它通过用户命令向/从套接字发送和接收数据,例如"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
我的目标是将任何级别的所有日志条目发送到日志文件,但仅将与用户当前设置的指定日志级别匹配的日志条目发送到标准输出。示例工作流程可能如下所示:
> 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