zoukankan      html  css  js  c++  java
  • rocketmq 日志问题

    今天使用rocketmq,消费者每消费一条消息都会产生info日志

    搜索无果,查看源代码

     1 public class ClientLogger {
     2     public static final String CLIENT_LOG_ROOT = "rocketmq.client.logRoot";
     3     public static final String CLIENT_LOG_MAXINDEX = "rocketmq.client.logFileMaxIndex";
     4     public static final String CLIENT_LOG_LEVEL = "rocketmq.client.logLevel";
     5     private static Logger log;
     6 
     7     static {
     8         log = createLogger(LoggerName.CLIENT_LOGGER_NAME);
     9     }
    10 
    11     private static Logger createLogger(final String loggerName) {
    12         String logConfigFilePath =
    13             System.getProperty("rocketmq.client.log.configFile",
    14                 System.getenv("ROCKETMQ_CLIENT_LOG_CONFIGFILE"));
    15         Boolean isloadconfig =
    16             Boolean.parseBoolean(System.getProperty("rocketmq.client.log.loadconfig", "true"));
    17 
    18         final String log4JResourceFile =
    19             System.getProperty("rocketmq.client.log4j.resource.fileName", "log4j_rocketmq_client.xml");
    20 
    21         final String logbackResourceFile =
    22             System.getProperty("rocketmq.client.logback.resource.fileName", "logback_rocketmq_client.xml");
    23 
    24         String clientLogRoot = System.getProperty(CLIENT_LOG_ROOT, "${user.home}/logs/rocketmqlogs");
    25         System.setProperty("client.logRoot", clientLogRoot);
    26         String clientLogLevel = System.getProperty(CLIENT_LOG_LEVEL, "INFO");
    27         System.setProperty("client.logLevel", clientLogLevel);
    28         String clientLogMaxIndex = System.getProperty(CLIENT_LOG_MAXINDEX, "10");
    29         System.setProperty("client.logFileMaxIndex", clientLogMaxIndex);
    30 
    31         if (isloadconfig) {
    32             try {
    33                 ILoggerFactory iLoggerFactory = LoggerFactory.getILoggerFactory();
    34                 Class classType = iLoggerFactory.getClass();
    35                 if (classType.getName().equals("org.slf4j.impl.Log4jLoggerFactory")) {
    36                     Class<?> domconfigurator;
    37                     Object domconfiguratorobj;
    38                     domconfigurator = Class.forName("org.apache.log4j.xml.DOMConfigurator");
    39                     domconfiguratorobj = domconfigurator.newInstance();
    40                     if (null == logConfigFilePath) {
    41                         Method configure = domconfiguratorobj.getClass().getMethod("configure", URL.class);
    42                         URL url = ClientLogger.class.getClassLoader().getResource(log4JResourceFile);
    43                         configure.invoke(domconfiguratorobj, url);
    44                     } else {
    45                         Method configure = domconfiguratorobj.getClass().getMethod("configure", String.class);
    46                         configure.invoke(domconfiguratorobj, logConfigFilePath);
    47                     }
    48 
    49                 } else if (classType.getName().equals("ch.qos.logback.classic.LoggerContext")) {
    50                     Class<?> joranConfigurator;
    51                     Class<?> context = Class.forName("ch.qos.logback.core.Context");
    52                     Object joranConfiguratoroObj;
    53                     joranConfigurator = Class.forName("ch.qos.logback.classic.joran.JoranConfigurator");
    54                     joranConfiguratoroObj = joranConfigurator.newInstance();
    55                     Method setContext = joranConfiguratoroObj.getClass().getMethod("setContext", context);
    56                     setContext.invoke(joranConfiguratoroObj, iLoggerFactory);
    57                     if (null == logConfigFilePath) {
    58                         URL url = ClientLogger.class.getClassLoader().getResource(logbackResourceFile);
    59                         Method doConfigure =
    60                             joranConfiguratoroObj.getClass().getMethod("doConfigure", URL.class);
    61                         doConfigure.invoke(joranConfiguratoroObj, url);
    62                     } else {
    63                         Method doConfigure =
    64                             joranConfiguratoroObj.getClass().getMethod("doConfigure", String.class);
    65                         doConfigure.invoke(joranConfiguratoroObj, logConfigFilePath);
    66                     }
    67 
    68                 }
    69             } catch (Exception e) {
    70                 System.err.println(e);
    71             }
    72         }
    73         return LoggerFactory.getLogger(LoggerName.CLIENT_LOGGER_NAME);
    74     }
    75 
    76     public static Logger getLog() {
    77         return log;
    78     }
    79 
    80     public static void setLog(Logger log) {
    81         ClientLogger.log = log;
    82     }
    83 }

    所有日志名定义

    public class LoggerName {
        public static final String FILTERSRV_LOGGER_NAME = "RocketmqFiltersrv";
        public static final String NAMESRV_LOGGER_NAME = "RocketmqNamesrv";
        public static final String BROKER_LOGGER_NAME = "RocketmqBroker";
        public static final String CLIENT_LOGGER_NAME = "RocketmqClient";
        public static final String TOOLS_LOGGER_NAME = "RocketmqTools";
        public static final String COMMON_LOGGER_NAME = "RocketmqCommon";
        public static final String STORE_LOGGER_NAME = "RocketmqStore";
        public static final String STORE_ERROR_LOGGER_NAME = "RocketmqStoreError";
        public static final String TRANSACTION_LOGGER_NAME = "RocketmqTransaction";
        public static final String REBALANCE_LOCK_LOGGER_NAME = "RocketmqRebalanceLock";
        public static final String ROCKETMQ_STATS_LOGGER_NAME = "RocketmqStats";
        public static final String COMMERCIAL_LOGGER_NAME = "RocketmqCommercial";
        public static final String FLOW_CONTROL_LOGGER_NAME = "RocketmqFlowControl";
        public static final String ROCKETMQ_AUTHORIZE_LOGGER_NAME = "RocketmqAuthorize";
        public static final String DUPLICATION_LOGGER_NAME = "RocketmqDuplication";
        public static final String PROTECTION_LOGGER_NAME = "RocketmqProtection";
        public static final String WATER_MARK_LOGGER_NAME = "RocketmqWaterMark";
    }

    配置

    rocketmq.client.log.loadconfig

    rocketmq.client.log.configFile

    日志级别

    <Logger name="RocketmqClient" level="WARN"/>

    问题解决

  • 相关阅读:
    进程控制
    文件、目录操作相关函数
    Linux 系统IO函数 复制文件内容
    gdb调试
    makefile的使用
    GCC编译器
    vim命令的使用
    Linux Ubuntu笔记(常用命令)
    博客搬家(CSDN->博客园)
    level 4
  • 原文地址:https://www.cnblogs.com/devilfeng/p/6869166.html
Copyright © 2011-2022 走看看