簡體   English   中英

LOG4J2使用Java使用多個配置文件

[英]LOG4J2 Use multiple config files using java

可以使log4j2使用多個配置文件。 我想運行我的項目並加載一個默認配置文件-logger.xml,然后再檢查另一個文件logger_1.xml中是否存在第二個配置,並添加它而不覆蓋第一個。 這是一些偽代碼。 簡而言之,我想用文件路徑填充arrayList,然后加載所有路徑。

  public class LoggerConfiguratorManager
{
public static final String LOG4J_PATH = "etc/confs/logger.xml";

  private static LoggerContext context = null;
  private static final ConfigurationFactory factory =  XmlConfigurationFactory.getInstance();
  private static ConfigurationSource configurationSource = null;
  private static Configuration configuration = null;
  private static final ArrayList<String> registred_logger = new ArrayList<>();

  private static void loadLoggerConfig(String logger_path)
  {
    InputStream is = null;
    try
    {
      if(logger_path.endsWith(".xml"))
        is = new FileInputStream(logger_path);
      else
      {
        final ZipFile archive = new ZipFile(logger_path);
        final ZipEntry logger_entry = archive.getEntry(LOG4J_PATH);
        if(logger_entry == null) throw new IOException("Cannot find 'logger.xml' in " + logger_path);
        is = archive.getInputStream(logger_entry);
      }

      configurationSource = new ConfigurationSource(is);
      configuration = factory.getConfiguration(configurationSource);
    }
    catch(IOException ex)
    {
      System.err.println("=============================================================================");
      System.err.println("=============================== LOGGER CONFIG ===============================");
      System.err.println("=============================================================================");
      System.err.println("=== [ERROR] " + ex);
    }
    finally
    {
      if (configurationSource != null)
      {
        context = Configurator.initialize(null, configurationSource);
        context.start(configuration);
        try { is.close(); } catch(IOException ex) { }
      }
    }
  }

  public static void load()
  {
    registred_logger.add(Globals.getClassLocation(LoggerConfiguratorManager.class));

    for(final String conf : registred_logger)
      loadLoggerConfig(conf);
  }

  public static void regLoggerConf(String conf_path) { registred_logger.add(conf_path); }

我建議改為:

  public class LoggerConfiguratorManager {

     private static final String LOG4J_PATH = "etc/confs/log4j2.xml";
     private static final StringBuffer paths = new StringBuffer(LOG4J_PATH);

     public static void registerConfiguration(String confPath) {
         paths.append(",").append(confPath);
     }

     public static void initLog4j() {
         Configurator.initializer("My Config", null, paths.toString(), null);
     }
  }

有關完整的工作示例,請參見https://github.com/rgoers/CompositeConfigurationExample

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM