package com.ctrip.framework.foundation.internals.provider; import java.io.File; import java.io.FileInputStream; import java.io.InputStream; import java.io.InputStreamReader; import java.nio.charset.StandardCharsets; import java.util.Properties; import com.ctrip.framework.foundation.internals.Utils; import com.ctrip.framework.foundation.internals.io.BOMInputStream; import com.ctrip.framework.foundation.spi.provider.Provider; import com.ctrip.framework.foundation.spi.provider.ServerProvider; import org.slf4j.Logger; import org.slf4j.LoggerFactory; public class DefaultServerProvider implements ServerProvider { private static final Logger logger = LoggerFactory.getLogger(DefaultServerProvider.class); private static final String SERVER_PROPERTIES_LINUX = "/opt/settings/server.properties"; private static final String SERVER_PROPERTIES_WINDOWS = "C:/opt/settings/server.properties"; private String m_env; private String m_dc; private Properties m_serverProperties = new Properties(); @Override public void initialize() { try { String path = Utils.isOSWindows() ? SERVER_PROPERTIES_WINDOWS : SERVER_PROPERTIES_LINUX; File file = new File(path); if (file.exists() && file.canRead()) { logger.info("Loading {}", file.getAbsolutePath()); FileInputStream fis = new FileInputStream(file); initialize(fis); return; } logger.warn("{} does not exist or is not readable.", path); initialize(null); } catch (Throwable ex) { logger.error("Initialize DefaultServerProvider failed.", ex); } } @Override public void initialize(InputStream in) { try { if (in != null) { try { m_serverProperties.load(new InputStreamReader(new BOMInputStream(in), StandardCharsets.UTF_8)); } finally { in.close(); } } initEnvType(); initDataCenter(); } catch (Throwable ex) { logger.error("Initialize DefaultServerProvider failed.", ex); } } @Override public String getDataCenter() { return m_dc; } @Override public boolean isDataCenterSet() { return m_dc != null; } @Override public String getEnvType() { return m_env; } @Override public boolean isEnvTypeSet() { return m_env != null; } @Override public String getProperty(String name, String defaultValue) { if ("env".equalsIgnoreCase(name)) { String val = getEnvType(); return val == null ? defaultValue : val; } else if ("dc".equalsIgnoreCase(name)) { String val = getDataCenter(); return val == null ? defaultValue : val; } else { String val = m_serverProperties.getProperty(name, defaultValue); return val == null ? defaultValue : val.trim(); } } @Override public Class<? extends Provider> getType() { return ServerProvider.class; } private void initEnvType() { // 1. Try to get environment from JVM system property m_env = System.getProperty("env"); if (!Utils.isBlank(m_env)) { m_env = m_env.trim(); logger.info("Environment is set to [{}] by JVM system property 'env'.", m_env); return; } // 2. Try to get environment from OS environment variable m_env = System.getenv("ENV"); if (!Utils.isBlank(m_env)) { m_env = m_env.trim(); logger.info("Environment is set to [{}] by OS env variable 'ENV'.", m_env); return; } // 3. Try to get environment from file "server.properties" m_env = m_serverProperties.getProperty("env"); if (!Utils.isBlank(m_env)) { m_env = m_env.trim(); logger.info("Environment is set to [{}] by property 'env' in server.properties.", m_env); return; } // 4. Set environment to null. m_env = null; logger.warn("Environment is set to null. Because it is not available in either (1) JVM system property 'env', (2) OS env variable 'ENV' nor (3) property 'env' from the properties InputStream."); } private void initDataCenter() { // 1. Try to get environment from JVM system property m_dc = System.getProperty("idc"); if (!Utils.isBlank(m_dc)) { m_dc = m_dc.trim(); logger.info("Data Center is set to [{}] by JVM system property 'idc'.", m_dc); return; } // 2. Try to get idc from OS environment variable m_dc = System.getenv("IDC"); if (!Utils.isBlank(m_dc)) { m_dc = m_dc.trim(); logger.info("Data Center is set to [{}] by OS env variable 'IDC'.", m_dc); return; } // 3. Try to get idc from from file "server.properties" m_dc = m_serverProperties.getProperty("idc"); if (!Utils.isBlank(m_dc)) { m_dc = m_dc.trim(); logger.info("Data Center is set to [{}] by property 'idc' in server.properties.", m_dc); return; } // 4. Set Data Center to null. m_dc = null; logger.debug("Data Center is set to null. Because it is not available in either (1) JVM system property 'idc', (2) OS env variable 'IDC' nor (3) property 'idc' from the properties InputStream."); } @Override public String toString() { return "environment [" + getEnvType() + "] data center [" + getDataCenter() + "] properties: " + m_serverProperties + " (DefaultServerProvider)"; } }