Java单独的日志文件,用于单独的程序参数

时间:2012-10-07 06:35:44

标签: java logging log4j fileappender

我有一个文件,根据传递给它的命令行参数,将SMS发送到不同的移动网络。沃达丰,3网络,T-Mobile,O2 ..等等,当争论通过时

$Run SMSDaemon 3Network  // sends sms to 3 networks's mobile users
$Run SMSDaemon Vodafone  // sends sms to Vodafone  mobile users
$Run SMSDaemon TMobile  // sends sms to TMobile  mobile users
$Run SMSDaemon O2    // sends sms to O2 mobile users

现在,我想为单独的网络创建一个单独的日志文件,这样我就可以根据移动网络分别记录日志信息,调试消息。

因为,我只有一个文件SMSDaemon我尝试了以下但它没有写任何文件。它只写入已在log4j.properties文件中定义的文件。所以,我很困惑在log4j.properties中写什么以及在这个java文件中写什么?

public static void main(String[] args) {
if( args.length != 1  {  return;}
networkUnique = args[0];
setLogProps(networkUnique);
//other codes and in setLogProps method 

private static void setLogProps(String networkUnique)
{
log = Logger.getLogger(networkUnique);
Properties logprops=new Properties();
logprops.setProperty("log4j.appender.file","org.apache.log4j.FileAppender");
logprops.setProperty("log4j.appender.file.maxFileSize","300MB");
logprops.setProperty("log4j.appender.file.maxBackupIndex","100");
logprops.setProperty("log4j.appender.file.File","/etc/sms/"+networkUnique+".log");
logprops.setProperty("log4j.appender.file.threshold","debug");
logprops.setProperty("log4j.appender.file.layout","org.apache.log4j.PatternLayout");
logprops.setProperty("log4j.appender.file.layout.ConversionPattern","%d [%t] %-5p  [%-35F : %-25M : %-6L] %-C -%m%n"); 
logprops.setProperty("log4j.appender.stdout","org.apache.log4j.FileAppender"); 
PropertyConfigurator.configure(logprops); 
log.info("Log message Starting for "+ networkUnique);
}

在log4j.properties文件中写入以下内容。所有日志都写入network.log文件,该文件在此属性中定义..这不符合我的要求。我需要在SMSDaemon setLogProps方法中定义的单独网络的单独日志。

# Define the root logger with appender file
#log = /etc/sms/
log4j.rootLogger = info, FILE

# Define the file appender
log4j.appender.FILE=org.apache.log4j.FileAppender
#log4j.appender.FILE.File=${log}/network.log

# Define the layout for file appender
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.FILE.layout.conversionPattern=%m%n

请建议。

提前致谢。

2 个答案:

答案 0 :(得分:1)

您需要创建不同的appender才能实现目标。 试试这个配置:

<appender name="3Network" class="org.apache.log4j.FileAppender">
    <param name="file" value="logs/3Network.log" />
    <param name="append" value="true" />        
</appender> 
<appender name="Vodafone" class="org.apache.log4j.FileAppender">
    <param name="file" value="logs/Vodafone.log" />
    <param name="append" value="true" />        
</appender> 
<appender name="TMobile" class="org.apache.log4j.FileAppender">
    <param name="file" value="logs/TMobile.log" />
    <param name="append" value="true" />        
</appender> 

你可以这样写:

log4j.appender.TMobile=org.apache.log4j.FileAppender
log4j.appender.TMobile.File=logs/TMobile.log.. 

依旧......

希望这可以帮助您解决问题。 另见 - reference

答案 1 :(得分:1)

我建议根据您的网络创建不同的Logger类,例如

     class com.netwrok.Network1Logger{
          public void logMessage(String className, String message, String Level);
     }

     class com.netwrok.Network2Logger{
          public void logMessage(String className, String message, String Level);
     }

然后更新log4j.properties,如下所示:

    # Root logger option
    log4j.rootLogger=INFO, RootFileAppender

    #Network1 Logger option
    log4j.logger.com.netwrok.Network1Logger=INFO,Network1FileAppender

    #Network2 Logger option
    log4j.logger.com.netwrok.Network2Logger=INFO,Network2FileAppender


    # RootFileAppender - used to log messages in the root.log file.
    log4j.appender.RootFileAppender=org.apache.log4j.FileAppender
    log4j.appender.RootFileAppender.File=root.log
    log4j.appender.RootFileAppender.MaxFileSize=100MB
    log4j.appender.RootFileAppender.layout=org.apache.log4j.PatternLayout
    log4j.appender.RootFileAppender.layout.ConversionPattern= %5p [%t] (%F:%L) - %m%n


    # Network1FileAppender- used to log messages in the shunted.log file.
    log4j.appender.Network1FileAppender=org.apache.log4j.FileAppender
    log4j.appender.Network1FileAppender.File=shunted.log
    log4j.appender.Network1FileAppender.MaxFileSize=10MB
    log4j.appender.Network1FileAppender.layout=org.apache.log4j.PatternLayout
    log4j.appender.Network1FileAppender.layout.ConversionPattern= %5p [%t] (%F:%L) - %m%n

    # Network2FileAppender- used to log messages in the shunted.log file.
    log4j.appender.Network2FileAppender=org.apache.log4j.FileAppender
    log4j.appender.Network2FileAppender.File=shunted.log
    log4j.appender.Network2FileAppender.MaxFileSize=10MB
    log4j.appender.Network2FileAppender.layout=org.apache.log4j.PatternLayout
    log4j.appender.Network2FileAppender.layout.ConversionPattern= %5p [%t] (%F:%L) - %m%n

如果您不想要,请使用root记录器将其关闭。