Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/338.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 在logback中动态添加Appender_Java_Logback_Slf4j_Logback Classic - Fatal编程技术网

Java 在logback中动态添加Appender

Java 在logback中动态添加Appender,java,logback,slf4j,logback-classic,Java,Logback,Slf4j,Logback Classic,我有一个来自slf4j的记录器实例。此记录器已登录到控制台。 我想为它添加一个附加的appender,它将为每个线程分别记录到一个文件中。所以我想使用SiftingAppender 我创建了下面的utils类来向记录器实例添加一个appender package com.worksap.company.hue.com.bizcore.outputengine.devtools; import org.slf4j.LoggerFactory; import ch.qos.logback.cla

我有一个来自slf4j的记录器实例。此记录器已登录到控制台。 我想为它添加一个附加的appender,它将为每个线程分别记录到一个文件中。所以我想使用
SiftingAppender

我创建了下面的utils类来向记录器实例添加一个appender

package com.worksap.company.hue.com.bizcore.outputengine.devtools;

import org.slf4j.LoggerFactory;

import ch.qos.logback.classic.Logger;
import ch.qos.logback.classic.LoggerContext;
import ch.qos.logback.classic.encoder.PatternLayoutEncoder;
import ch.qos.logback.classic.sift.MDCBasedDiscriminator;
import ch.qos.logback.classic.sift.SiftingAppender;
import ch.qos.logback.classic.spi.ILoggingEvent;
import ch.qos.logback.core.Appender;
import ch.qos.logback.core.Context;
import ch.qos.logback.core.joran.spi.JoranException;
import ch.qos.logback.core.rolling.RollingFileAppender;
import ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP;
import ch.qos.logback.core.rolling.TimeBasedRollingPolicy;
import ch.qos.logback.core.sift.AppenderFactory;

public class Utils {

    public static Logger putNewAppender(String file, org.slf4j.Logger log) {

        LoggerContext lc = (LoggerContext)LoggerFactory.getILoggerFactory();
        Logger logger = lc.getLogger(log.getName());
        SiftingAppender sa = new SiftingAppender();
        sa.setName("SIFT");
        sa.setContext(lc);

        MDCBasedDiscriminator discriminator = new MDCBasedDiscriminator();
        discriminator.setKey("logFileName");
        discriminator.setDefaultValue("head0");
        discriminator.start();

        sa.setDiscriminator(discriminator);

        sa.setAppenderFactory(new AppenderFactory<ILoggingEvent>() {

            @Override
            public Appender<ILoggingEvent> buildAppender(Context context, String discriminatingValue)
                    throws JoranException {
                RollingFileAppender<ILoggingEvent> appender = new RollingFileAppender<>();
                appender.setName("ROLLINGFILE-" + discriminatingValue);
                appender.setContext(context);
                appender.setFile(discriminatingValue + ".log");

                TimeBasedRollingPolicy<ILoggingEvent> policy = new TimeBasedRollingPolicy<>();
                policy.setContext(context);
                policy.setMaxHistory(5);
                policy.setFileNamePattern(discriminatingValue + "-%d{yyyy-MM-dd-HH-mm}-%i.log.gz");
                policy.setParent(appender);
                policy.start();

                SizeAndTimeBasedFNATP<ILoggingEvent> innerpolicy = new SizeAndTimeBasedFNATP<>();
                innerpolicy.setContext(context);
                innerpolicy.setMaxFileSize("512KB");
                innerpolicy.setTimeBasedRollingPolicy(policy);
                innerpolicy.start();

                policy.setTimeBasedFileNamingAndTriggeringPolicy(innerpolicy);
                policy.start();

                appender.setRollingPolicy(policy);

                PatternLayoutEncoder pl = new PatternLayoutEncoder();
                pl.setContext(context);
                pl.setPattern("%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n");
                pl.start();
                appender.setEncoder(pl);

                appender.start();
                return appender;
            }
        });

        sa.start();
        logger.addAppender(sa);
        logger.setAdditive(false);

        return logger;

    }
}
但是,没有任何记录器信息实际打印在控制台或文件中。如果我不添加
siftingAppender
,它将在控制台上正确打印。如何以编程方式添加筛选附加程序

不允许我更改
logback.xml

启用登录logback后,我得到以下信息:

ch.qos.logback.classic.sift.SiftingAppender[SIFT]
ch.qos.logback.core.ConsoleAppender[CONSOLE]
ch.qos.logback.core.ConsoleAppender[CONSOLE]
ch.qos.logback.core.ConsoleAppender[CONSOLE_SPRING]
16:40:08,943 |-INFO in c.q.l.core.rolling.TimeBasedRollingPolicy - Will use gz compression
16:40:08,946 |-INFO in c.q.l.core.rolling.TimeBasedRollingPolicy - Will use the pattern somename-%d{yyyy-MM-dd-HH-mm}-%i.log for the active file
16:40:08,956 |-INFO in c.q.l.core.rolling.DefaultTimeBasedFileNamingAndTriggeringPolicy - The date pattern is 'yyyy-MM-dd-HH-mm' from file name pattern 'somename-%d{yyyy-MM-dd-HH-mm}-%i.log.gz'.
16:40:08,956 |-INFO in c.q.l.core.rolling.DefaultTimeBasedFileNamingAndTriggeringPolicy - Roll-over every minute.
16:40:08,957 |-INFO in c.q.l.core.rolling.DefaultTimeBasedFileNamingAndTriggeringPolicy - Setting initial period to Tue Jun 06 16:35:47 JST 2017
16:40:08,962 |-INFO in ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP@77a4bac - The date pattern is 'yyyy-MM-dd-HH-mm' from file name pattern 'somename-%d{yyyy-MM-dd-HH-mm}-%i.log.gz'.
16:40:08,962 |-INFO in ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP@77a4bac - Roll-over every minute.
16:40:08,962 |-INFO in ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP@77a4bac - Setting initial period to Tue Jun 06 16:35:47 JST 2017
16:40:08,964 |-INFO in c.q.l.core.rolling.TimeBasedRollingPolicy - Will use gz compression
16:40:08,964 |-INFO in c.q.l.core.rolling.TimeBasedRollingPolicy - Will use the pattern somename-%d{yyyy-MM-dd-HH-mm}-%i.log for the active file
16:40:08,965 |-INFO in ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP@77a4bac - The date pattern is 'yyyy-MM-dd-HH-mm' from file name pattern 'somename-%d{yyyy-MM-dd-HH-mm}-%i.log.gz'.
16:40:08,966 |-INFO in ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP@77a4bac - Roll-over every minute.
16:40:08,966 |-INFO in ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP@77a4bac - Setting initial period to Tue Jun 06 16:35:47 JST 2017
16:40:08,969 |-INFO in ch.qos.logback.core.rolling.RollingFileAppender[ROLLINGFILE-somename] - Active log file name: somename.log
16:40:08,969 |-INFO in ch.qos.logback.core.rolling.RollingFileAppender[ROLLINGFILE-somename] - File property is set to [somename.log]
16:40:08,975 |-INFO in c.q.l.co.rolling.helper.RenameUtil - Renaming file [somename.log] to [somename.log91512733365898.tmp]
16:40:08,979 |-INFO in ch.qos.logback.core.rolling.helper.SizeAndTimeBasedArchiveRemover@96be1ae - first clean up after appender initialization
16:40:08,979 |-INFO in ch.qos.logback.core.rolling.helper.SizeAndTimeBasedArchiveRemover@96be1ae - periodsElapsed = 336
16:40:08,979 |-INFO in ch.qos.logback.core.rolling.helper.Compressor - GZ compressing [somename.log91512733365898.tmp] as [somename-2017-06-06-16-35-0.log.gz]
编辑


删除此行
logger.setadditional(false)后,日志将打印在控制台上。但是,我看不到创建的文件。

您在appender factory中构建appender的方式似乎存在一些问题。不确定,到底是什么问题,但我尝试了下面的代码,它工作了。 `

sa.setAppenderFactory(新AppenderFactory(){

public Appender buildAppender(上下文上下文,字符串判别值)
抛出一个例外{
PatternLayoutCoder ple=新的PatternLayoutCoder();
ple.setPattern(“%date[%thread][%file:%line]%msg%n”);
ple.setContext(context);
ple.start();
RollingFileAppender logFileAppender=新的RollingFileAppender();
logFileAppender.setContext(上下文);
setName(“文件-”+DecritingValue);
logFileAppender.setEncoder(ple);
logFileAppender.setFile(文件名+“-”+discritingvalue+“.txt”);
SizeAndTimeBasedRollingPolicy logFilePolicy=新的SizeAndTimeBasedRollingPolicy();
logFilePolicy.setContext(context);
setParent(logFileAppender);
logFilePolicy.setFileNamePattern(filename+“-”+discritingvalue+“-%d{yyyy-MM-dd}.%i.txt”);
logFilePolicy.setMaxHistory(5);
logFilePolicy.setMaxFileSize(FileSize.valueOf(“512kb”);
logFilePolicy.setTotalSizeCap(FileSize.valueOf(“1gb”);
logFilePolicy.start();
logFileAppender.setRollingPolicy(logFilePolicy);
logFileAppender.start();
logFileAppender.start();
返回logFileAppender;
}
});

`

您在appender工厂中构建appender的方式似乎存在一些问题。不确定,到底是什么问题,但我尝试了下面的代码,它工作了。 `

sa.setAppenderFactory(新AppenderFactory(){

public Appender buildAppender(上下文上下文,字符串判别值)
抛出一个例外{
PatternLayoutCoder ple=新的PatternLayoutCoder();
ple.setPattern(“%date[%thread][%file:%line]%msg%n”);
ple.setContext(context);
ple.start();
RollingFileAppender logFileAppender=新的RollingFileAppender();
logFileAppender.setContext(上下文);
setName(“文件-”+DecritingValue);
logFileAppender.setEncoder(ple);
logFileAppender.setFile(文件名+“-”+discritingvalue+“.txt”);
SizeAndTimeBasedRollingPolicy logFilePolicy=新的SizeAndTimeBasedRollingPolicy();
logFilePolicy.setContext(context);
setParent(logFileAppender);
logFilePolicy.setFileNamePattern(filename+“-”+discritingvalue+“-%d{yyyy-MM-dd}.%i.txt”);
logFilePolicy.setMaxHistory(5);
logFilePolicy.setMaxFileSize(FileSize.valueOf(“512kb”);
logFilePolicy.setTotalSizeCap(FileSize.valueOf(“1gb”);
logFilePolicy.start();
logFileAppender.setRollingPolicy(logFilePolicy);
logFileAppender.start();
logFileAppender.start();
返回logFileAppender;
}
});
`

16:40:08,943 |-INFO in c.q.l.core.rolling.TimeBasedRollingPolicy - Will use gz compression
16:40:08,946 |-INFO in c.q.l.core.rolling.TimeBasedRollingPolicy - Will use the pattern somename-%d{yyyy-MM-dd-HH-mm}-%i.log for the active file
16:40:08,956 |-INFO in c.q.l.core.rolling.DefaultTimeBasedFileNamingAndTriggeringPolicy - The date pattern is 'yyyy-MM-dd-HH-mm' from file name pattern 'somename-%d{yyyy-MM-dd-HH-mm}-%i.log.gz'.
16:40:08,956 |-INFO in c.q.l.core.rolling.DefaultTimeBasedFileNamingAndTriggeringPolicy - Roll-over every minute.
16:40:08,957 |-INFO in c.q.l.core.rolling.DefaultTimeBasedFileNamingAndTriggeringPolicy - Setting initial period to Tue Jun 06 16:35:47 JST 2017
16:40:08,962 |-INFO in ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP@77a4bac - The date pattern is 'yyyy-MM-dd-HH-mm' from file name pattern 'somename-%d{yyyy-MM-dd-HH-mm}-%i.log.gz'.
16:40:08,962 |-INFO in ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP@77a4bac - Roll-over every minute.
16:40:08,962 |-INFO in ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP@77a4bac - Setting initial period to Tue Jun 06 16:35:47 JST 2017
16:40:08,964 |-INFO in c.q.l.core.rolling.TimeBasedRollingPolicy - Will use gz compression
16:40:08,964 |-INFO in c.q.l.core.rolling.TimeBasedRollingPolicy - Will use the pattern somename-%d{yyyy-MM-dd-HH-mm}-%i.log for the active file
16:40:08,965 |-INFO in ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP@77a4bac - The date pattern is 'yyyy-MM-dd-HH-mm' from file name pattern 'somename-%d{yyyy-MM-dd-HH-mm}-%i.log.gz'.
16:40:08,966 |-INFO in ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP@77a4bac - Roll-over every minute.
16:40:08,966 |-INFO in ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP@77a4bac - Setting initial period to Tue Jun 06 16:35:47 JST 2017
16:40:08,969 |-INFO in ch.qos.logback.core.rolling.RollingFileAppender[ROLLINGFILE-somename] - Active log file name: somename.log
16:40:08,969 |-INFO in ch.qos.logback.core.rolling.RollingFileAppender[ROLLINGFILE-somename] - File property is set to [somename.log]
16:40:08,975 |-INFO in c.q.l.co.rolling.helper.RenameUtil - Renaming file [somename.log] to [somename.log91512733365898.tmp]
16:40:08,979 |-INFO in ch.qos.logback.core.rolling.helper.SizeAndTimeBasedArchiveRemover@96be1ae - first clean up after appender initialization
16:40:08,979 |-INFO in ch.qos.logback.core.rolling.helper.SizeAndTimeBasedArchiveRemover@96be1ae - periodsElapsed = 336
16:40:08,979 |-INFO in ch.qos.logback.core.rolling.helper.Compressor - GZ compressing [somename.log91512733365898.tmp] as [somename-2017-06-06-16-35-0.log.gz]
                 public Appender<ILoggingEvent> buildAppender(Context context, String discriminatingValue)
                         throws JoranException {
                     PatternLayoutEncoder ple = new PatternLayoutEncoder();

                    ple.setPattern("%date [%thread] [%file:%line] %msg%n");
                    ple.setContext(context);
                    ple.start();


                    RollingFileAppender<ILoggingEvent> logFileAppender = new RollingFileAppender();
                            logFileAppender.setContext(context);
                            logFileAppender.setName("File-"+discriminatingValue);
                            logFileAppender.setEncoder(ple);
                            logFileAppender.setFile(filename+"-"+discriminatingValue+".txt");

                            SizeAndTimeBasedRollingPolicy<ILoggingEvent> logFilePolicy = new SizeAndTimeBasedRollingPolicy();
                            logFilePolicy.setContext(context);
                            logFilePolicy.setParent(logFileAppender);
                            logFilePolicy.setFileNamePattern(filename+"-"+discriminatingValue+"-%d{yyyy-MM-dd}.%i.txt");
                            logFilePolicy.setMaxHistory(5);
                            logFilePolicy.setMaxFileSize(FileSize.valueOf("512kb"));
                            logFilePolicy.setTotalSizeCap(FileSize.valueOf("1gb"));
                            logFilePolicy.start();

                            logFileAppender.setRollingPolicy(logFilePolicy);
                            logFileAppender.start();

                          logFileAppender.start();
                     return logFileAppender;
                 }
             });