千家信息网

dubbo中LogbackContainer的作用是什么

发表于:2024-11-26 作者:千家信息网编辑
千家信息网最后更新 2024年11月26日,这篇文章给大家介绍dubbo中LogbackContainer的作用是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。LogbackContainerdubbo-2.7.2/d
千家信息网最后更新 2024年11月26日dubbo中LogbackContainer的作用是什么

这篇文章给大家介绍dubbo中LogbackContainer的作用是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

LogbackContainer

dubbo-2.7.2/dubbo-container/dubbo-container-logback/src/main/java/org/apache/dubbo/container/logback/LogbackContainer.java

public class LogbackContainer implements Container {    public static final String LOGBACK_FILE = "dubbo.logback.file";    public static final String LOGBACK_LEVEL = "dubbo.logback.level";    public static final String LOGBACK_MAX_HISTORY = "dubbo.logback.maxhistory";    public static final String DEFAULT_LOGBACK_LEVEL = "ERROR";    @Override    public void start() {        String file = ConfigUtils.getProperty(LOGBACK_FILE);        if (file != null && file.length() > 0) {            String level = ConfigUtils.getProperty(LOGBACK_LEVEL);            if (StringUtils.isEmpty(level)) {                level = DEFAULT_LOGBACK_LEVEL;            }            // maxHistory=0 Infinite history            int maxHistory = StringUtils.parseInteger(ConfigUtils.getProperty(LOGBACK_MAX_HISTORY));            doInitializer(file, level, maxHistory);        }    }    @Override    public void stop() {    }    /**     * Initializer logback     *     * @param file     * @param level     * @param maxHistory     */    private void doInitializer(String file, String level, int maxHistory) {        LoggerContext loggerContext = (LoggerContext) LoggerFactory.getILoggerFactory();        Logger rootLogger = loggerContext.getLogger(Logger.ROOT_LOGGER_NAME);        rootLogger.detachAndStopAllAppenders();        // appender        RollingFileAppender fileAppender = new RollingFileAppender();        fileAppender.setContext(loggerContext);        fileAppender.setName("application");        fileAppender.setFile(file);        fileAppender.setAppend(true);        // policy        TimeBasedRollingPolicy policy = new TimeBasedRollingPolicy();        policy.setContext(loggerContext);        policy.setMaxHistory(maxHistory);        policy.setFileNamePattern(file + ".%d{yyyy-MM-dd}");        policy.setParent(fileAppender);        policy.start();        fileAppender.setRollingPolicy(policy);        // encoder        PatternLayoutEncoder encoder = new PatternLayoutEncoder();        encoder.setContext(loggerContext);        encoder.setPattern("%date [%thread] %-5level %logger (%file:%line\\) - %msg%n");        encoder.start();        fileAppender.setEncoder(encoder);        fileAppender.start();        rootLogger.addAppender(fileAppender);        rootLogger.setLevel(Level.toLevel(level));        rootLogger.setAdditive(false);    }}
  • LogbackContainer实现了Container接口,其start方法判断是否有指定dubbo.logback.file,如果有则进一步获取dubbo.logback.level,如果为空则默认为ERROR级别,然后再获取dubbo.logback.maxhistory,最后调用doInitializer;doInitializer方法先获取rootLogger,然后执行detachAndStopAllAppenders,然后配置RollingFileAppender,并指定policy为TimeBasedRollingPolicy,并设置PatternLayoutEncoder,然后启动fileAppender,并添加到rootLogger中

实例

dubbo-2.7.2/dubbo-container/dubbo-container-logback/src/test/java/org/apache/dubbo/container/logback/LogbackContainerTest.java

public class LogbackContainerTest {    private static final Logger logger = LoggerFactory.getLogger(LogbackContainerTest.class);    @Test    public void testContainer() {        LogbackContainer container = (LogbackContainer) ExtensionLoader.getExtensionLoader(Container.class)                .getExtension("logback");        container.start();        logger.debug("Test debug:" + this.getClass().getName());        logger.warn("Test warn:" + this.getClass().getName());        logger.info("Test info:" + this.getClass().getName());        logger.error("Test error:" + this.getClass().getName());        container.stop();    }}
  • 这里通过启动logback的container然后再使用logger输出进行验证

小结

LogbackContainer实现了Container接口,其start方法判断是否有指定dubbo.logback.file,如果有则进一步获取dubbo.logback.level,如果为空则默认为ERROR级别,然后再获取dubbo.logback.maxhistory,最后调用doInitializer;doInitializer方法先获取rootLogger,然后执行detachAndStopAllAppenders,然后配置RollingFileAppender,并指定policy为TimeBasedRollingPolicy,并设置PatternLayoutEncoder,然后启动fileAppender,并添加到rootLogger中

关于dubbo中LogbackContainer的作用是什么就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

方法 作用 内容 接口 更多 级别 进一 帮助 配置 不错 兴趣 实例 小伙 小伙伴 小结 文章 知识 篇文章 中关 参考 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 我的世界纯净神奇宝贝服务器 移动端软件开发属于哪一类 小学生网络安全教育简洁发言稿 服务器被攻击如何阻断ip 天津专业软件开发过程品质保障 网络安全行业编程能力 指定模式数据库 爱数数据库实时备份软件下载 崇明区营销软件开发信息中心 华为服务器还能回来吗 软件开发商业画布 网络安全钓鱼工具 如何找到新建数据库的位置 论文全文数据库 出售 车辆运维管理服务器 珠海格力电器 软件开发 软件开发 劳务派遣 奉贤区网络技术开发质量保证 吉林时代网络技术服务代理商 计算机网络技术综合题大全 预付软件开发款分录 深圳可搜网络技术有现公司 少年绘画软件开发 大众导航数据库怎么下载 美国软件开发年薪 数据库对时间失败 云宝盒成都网络技术有限公司 化工模拟软件开发横向合同 服务器缺少参数是什么意思 木鱼跳跳网络技术
0