首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >日志返回配置将为空

日志返回配置将为空
EN

Stack Overflow用户
提问于 2018-01-13 00:52:23
回答 1查看 1.2K关注 0票数 0

我使用的是logback 1.2.3。我将以-Dlogback.configurationFile=$SERVICE_PATH/restapilayer.logback.xml的身份传递登录配置

我的restapilayer.logback.xml如下所示

代码语言:javascript
复制
<configuration debug="true">

    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
            <Target>System.out</Target>
            <encoder>
               <pattern>%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n</pattern>
            </encoder>
    </appender>

    <root level="DEBUG">
        <appender-ref ref="STDOUT" />
    </root>

</configuration>

在我的日志中,我还看到配置文件正在加载。

代码语言:javascript
复制
10:51:42,695 |-INFO in ch.qos.logback.classic.LoggerContext[default] - Found resource [/home/ubuntu/build-target/restapilayer/restapilayer.logback.xml] at [file:/home/ubuntu/build-target/restapilayer/restapilayer.logback.xml]
10:51:42,860 |-INFO in ch.qos.logback.core.joran.action.AppenderAction - About to instantiate appender of type [ch.qos.logback.core.ConsoleAppender]
10:51:42,863 |-INFO in ch.qos.logback.core.joran.action.AppenderAction - Naming appender as [STDOUT]
10:51:42,869 |-INFO in ch.qos.logback.core.joran.action.NestedComplexPropertyIA - Assuming default type [ch.qos.logback.classic.encoder.PatternLayoutEncoder] for [encoder] property
10:51:42,894 |-INFO in ch.qos.logback.classic.joran.action.RootLoggerAction - Setting level of ROOT logger to DEBUG
10:51:42,895 |-INFO in ch.qos.logback.core.joran.action.AppenderRefAction - Attaching appender named [STDOUT] to Logger[ROOT]
10:51:42,895 |-INFO in ch.qos.logback.classic.joran.action.ConfigurationAction - End of configuration.
10:51:42,896 |-INFO in ch.qos.logback.classic.joran.JoranConfigurator@3fd7a715 - Registering current configuration as safe fallback point
2018-01-13 10:51:42 [main] INFO  com.vnera.common.utils.CommonUtils - adding uncaught exception handler hook...
INFO [2018-01-13 10:51:44] o.e.j.u.log:[?:?:?] - [main] - Logging initialized @1792ms    

然后,在尝试登录时,我发现logback配置为空,并且logback似乎正在使用默认配置运行

代码语言:javascript
复制
INFO [2018-01-12 16:25:34] c.v.r.c.v.r.VneraBackendService:[?:?:?] - [main] - Logback used _null_ as the configuration file_

我使用下面的代码来获取logback配置

代码语言:javascript
复制
logger.debug("Testing Debug logging");
LoggerContext loggerContext = ((ch.qos.logback.classic.Logger)logger).getLoggerContext();
URL mainURL = ConfigurationWatchListUtil.getMainWatchURL(loggerContext);
System.out.println(mainURL);
// or even
logger.info("Logback used '{}' as the configuration file.", mainURL);

有没有人能告诉我出了什么问题?如何调试此问题?

添加了Maven依赖树here

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-01-16 02:37:47

我尝试在dropwizard应用程序中使用logback (带有logback.xml)。在应用程序初始化期间,无论何时调用io.dropwizard.Application.run(BackendServiceConfiguration, Environment),它都会丢弃先前初始化的记录器,并尝试使用dropwizard配置文件(config.yaml)中定义的记录器。

为了在run()之后解决这个问题,我不得不按照解释的here调用下面的代码。

代码语言:javascript
复制
public static void relaodLogback() {
        String loggingConfig = System.getProperty("logback.configurationFile");
        if(loggingConfig == null) {
            System.out.println("Logging Config is null");
        }

        LoggerContext loggerContext = (LoggerContext) LoggerFactory.getILoggerFactory();
        loggerContext.reset();
        JoranConfigurator configurator = new JoranConfigurator();

        try {
            InputStream configStream = FileUtils.openInputStream(new File(loggingConfig));
            configurator.setContext(loggerContext);
            configurator.doConfigure(configStream); // loads logback file
            configStream.close();
            System.out.println("Loaded configuration file");
        } catch (JoranException | IOException e) {
            e.printStackTrace();
            System.out.println("Failed to log configuration file");
            System.exit(1);
        }
    }
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/48230672

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档