zoukankan      html  css  js  c++  java
  • 脚本命令加载外部配置文件夹conf

    加载log4j配置文件 Log4iConfigurer类

    public class Log4iConfigurer {
        
        private static boolean INITIALIZED = false;
        
        public static void initLogger(){
            if(!INITIALIZED&&!isConfigured()){
                InputStream is =Log4iConfigurer.class.getClassLoader().getResourceAsStream("log4j.properties");
                PropertyConfigurator.configure(is);
                IOUtils.closeQuietly(is);
            }
        }
    
        private static boolean isConfigured() {
            if(LogManager.getRootLogger().getAllAppenders().hasMoreElements()){
                return true;
            }else{
                Enumeration<?> loggers =LogManager.getCurrentLoggers();
                while(loggers.hasMoreElements()){
                    Logger logger= (Logger)loggers.nextElement();
                    if(logger.getAllAppenders().hasMoreElements()){
                        return true;
                    }
                }
            }
            return false;
        }
        
    }

    读取配置文件类Util

    public class Util {
        
        private static final Logger logger = LoggerFactory.getLogger(Util.class);
        
        /**mapping.properties file name*/
        public static final Properties props = new Properties();
        public static final String CONF_PROPERTIES_FILE= "mapping.properties";
        public static final String CONF = "RUN_CONF";
        
        static{
            Log4iConfigurer.initLogger();
            getProperties();
        }
        
        public static String GetString(String key){
            String value = null;
            value = props.getProperty(key);
            return value;
        }
        
        //读取配置文件
        private static File getConfProperties(){
            String confHome = System.getProperty(CONF);
            if(!StringUtils.isEmpty(confHome)){
                logger.info("Use CONF="+confHome);
                return getPropertiesFile(confHome);
            }
            
            logger.warn("Conf property was not set ,will seek conf env variable");
            
            String runHome = getRunHome();
            if(StringUtils.isEmpty(runHome)){
                throw new RuntimeException("didn't find project runpath,please set");
            }
            String path = runHome+File.separator+"conf";
            return getPropertiesFile(path);
        }
        
        public static void getProperties(){
            File propFile = getConfProperties();
            if(propFile == null||!propFile.exists()){
                logger.info("fail to load properties");
                throw new RuntimeException("fail to load properties");
            }
            FileInputStream fis = null;
            try {
                fis = new FileInputStream(propFile);
                props.load(fis);
            } catch (IOException e) {
                 throw new RuntimeException(e);
            } finally {
                 IOUtils.closeQuietly(fis);
            }
        }
        
        private static File getPropertiesFile(String path){
            if(path == null){
                return null;
            }
            return new File(path,CONF_PROPERTIES_FILE);
        }
        
        private static String getRunHome(){
            String runHome = System.getProperty("runpath");
            if(StringUtils.isEmpty(runHome)){
                logger.warn("run home was not set");
            }
            return runHome;
        }
        
        
        public static void main(String[] args) {
            System.out.println(System.getenv("PATH"));
            System.out.println(System.getProperty("conf"));
            System.setProperty("run.home", "/home/dinpay/mappinghome");
            System.out.println(System.getProperty("run.home"));
        }
        
    }

    打包导出

       

    另外附上window和linux的启动脚本命令

    startup.cmd

    echo start elasticsearch-mapping
    java -Drunpath=C:Usersll-t150Desktopesmap -Dlog4j.configuration=conf/log4j.properties -cp lib/* com.dinpay.bdp.rcp.service.Start 
    pause 

    startup.sh

    echo start elasticsearch-mapping
    java -Drunpath=/home/dinpay/esmap -Dlog4j.configuration=conf/log4j.properties -classpath .:lib/* com.dinpay.bdp.rcp.service.Start
    echo "create elasticsearch mapping successfully!"
  • 相关阅读:
    第一次作业
    C语言I博客作业02
    C语言|博客作业11
    C语言I博客作业10
    C语言I博客作业09
    C语言I博客作业08
    C语言I博客作业07
    C语言I博客作业06
    C语言I博客作业05
    JDK-14 & Eclipse & Hello World!
  • 原文地址:https://www.cnblogs.com/atomicbomb/p/6625130.html
Copyright © 2011-2022 走看看