All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.obs.services.Log4j2Configurator Maven / Gradle / Ivy

Go to download

The HuaweiCloud OBS Bundle SDK for Java used for accessing Object Storage Service, this SDK bundle includes third-party libraries and relocated to different namespaces

There is a newer version: 3.24.12
Show newest version
/**
 * Copyright 2019 Huawei Technologies Co.,Ltd.
 * Licensed under the Apache License, Version 2.0 (the "License"); you may not use
 * this file except in compliance with the License.  You may obtain a copy of the
 * License at
 * 
 * http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software distributed
 * under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
 * CONDITIONS OF ANY KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations under the License.
 */

package com.obs.services;

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.lang.reflect.Constructor;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.logging.Logger;

/**
 * Log configuration class integrated with Log4j2
 *
 */
public class Log4j2Configurator {

    private static volatile boolean isWatchStart = false;

    private static volatile boolean log4j2Enabled = false;

    private static final Logger logger = Logger.getLogger(Log4j2Configurator.class.getName());
    
    /**
     * Configure logs.
     * 
     * @param configPath
     *            Path to the log configuration file
     */
    public static synchronized void setLogConfig(String configPath) {
        setLogConfig(configPath, false);
    }

    /**
     * Configure logs.
     * 
     * @param configPath
     *            Path to the log configuration file
     * @param isWatchConfig
     *            Whether to monitor changes of the log configuration file
     */
    public static synchronized void setLogConfig(String configPath, boolean isWatchConfig) {
        setLogConfig(configPath, isWatchConfig, 60000);
    }

    private static Object getLogContext(String configPath) {
        Object ctx = null;
        FileInputStream configInputStream = null;
        try {
            Class configurationSource = Class.forName("org.apache.logging.log4j.core.config.ConfigurationSource");
            Class configurator = Class.forName("org.apache.logging.log4j.core.config.Configurator");
            Constructor con = configurationSource.getConstructor(InputStream.class);
            Method m = configurator.getMethod("initialize", ClassLoader.class, configurationSource);

            configInputStream = new FileInputStream(configPath);
            ctx = m.invoke(null, null, con.newInstance(configInputStream));
        } catch (ClassNotFoundException | NoSuchMethodException | SecurityException | InvocationTargetException
                | IllegalAccessException | InstantiationException | FileNotFoundException e) {
            logger.warning(e.getMessage());
        } finally {
            if (null != configInputStream) {
                try {
                    configInputStream.close();
                } catch (IOException e) {
                    logger.warning(e.getMessage());
                }
            }
        }
        return ctx;
    }

    private static class LogWatcher extends Thread {
        private Object ctx;
        private long watchInterval;
        private String configPath;

        LogWatcher(String configPath, Object ctx, long watchInterval) {
            this.configPath = configPath;
            this.ctx = ctx;
            this.watchInterval = watchInterval;

        }

        public void run() {
            try {
                Class configuration = Class.forName("org.apache.logging.log4j.core.config.Configuration");
                final Method stop = ctx.getClass().getMethod("stop");
                final Method start = ctx.getClass().getMethod("start", configuration);
                Class xmlConfiguration = Class.forName("org.apache.logging.log4j.core.config.xml.XmlConfiguration");
                Class configurationSource = Class
                        .forName("org.apache.logging.log4j.core.config.ConfigurationSource");
                Constructor configurationSourceConstructor = configurationSource.getConstructor(InputStream.class);
                Constructor xmlConfigurationConstructor = xmlConfiguration.getConstructor(ctx.getClass(),
                        configurationSource);
                while (true) {
                    Thread.sleep(this.watchInterval);
                    stop.invoke(ctx);
                    start.invoke(ctx, xmlConfigurationConstructor.newInstance(ctx,
                            configurationSourceConstructor.newInstance(new FileInputStream(this.configPath))));
                }
            } catch (ClassNotFoundException | FileNotFoundException | NoSuchMethodException | SecurityException
                    | InterruptedException | InvocationTargetException | IllegalAccessException
                    | InstantiationException e) {
                logger.warning(e.getMessage());
            }
        }
    }

    /**
     * Configure logs.
     * 
     * @param configPath
     *            Path to the log configuration file
     * @param isWatchConfig
     *            Whether to monitor changes of the log configuration file
     * @param watchInterval
     *            Interval for monitoring changes of the log configuration file,
     *            in units of ms
     */
    public static synchronized void setLogConfig(String configPath, boolean isWatchConfig, long watchInterval) {
        if (log4j2Enabled) {
            return;
        }
        Object ctx = getLogContext(configPath);
        if (isWatchConfig && ctx != null && !isWatchStart) {
            try {
                isWatchStart = true;
                long interval = watchInterval > 0 ? watchInterval : 60000;
                LogWatcher wather = new LogWatcher(configPath, ctx, interval);
                wather.setDaemon(true);
                wather.start();
            } catch (Exception e) {
                logger.warning(e.getMessage());
            }
        }
        log4j2Enabled = true;
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy