在看 sentinel 源码时发现了这个
package com.alibaba.csp.sentinel.log;
import com.alibaba.csp.sentinel.util.ConfigUtil;
import com.alibaba.csp.sentinel.util.StringUtil;
import java.util.Map;
import java.util.Properties;
import java.util.concurrent.CopyOnWriteArraySet;
/**
* <p>The loader that responsible for loading Sentinel log configurations.</p>
*
* @author lianglin
* @since 1.7.0
*/
public class LogConfigLoader {
public static final String LOG_CONFIG_ENV_KEY = "CSP_SENTINEL_CONFIG_FILE";
public static final String LOG_CONFIG_PROPERTY_KEY = "csp.sentinel.config.file";
private static final String DEFAULT_LOG_CONFIG_FILE = "classpath:sentinel.properties";
private static final Properties properties = new Properties();
static {
try {
load();
} catch (Throwable t) {
// NOTE: do not use RecordLog here, or there will be circular class dependency!
System.err.println("[LogConfigLoader] Failed to initialize configuration items");
t.printStackTrace();
}
}
private static void load() {
// Order: system property -> system env -> default file (classpath:sentinel.properties) -> legacy path
String fileName = System.getProperty(LOG_CONFIG_PROPERTY_KEY);
if (StringUtil.isBlank(fileName)) {
fileName = System.getenv(LOG_CONFIG_ENV_KEY);
if (StringUtil.isBlank(fileName)) {
fileName = DEFAULT_LOG_CONFIG_FILE;
}
}
Properties p = ConfigUtil.loadProperties(fileName);
if (p != null && !p.isEmpty()) {
properties.putAll(p);
}
CopyOnWriteArraySet<Map.Entry<Object, Object>> copy = new CopyOnWriteArraySet<>(System.getProperties().entrySet());
for (Map.Entry<Object, Object> entry : copy) {
String configKey = entry.getKey().toString();
String newConfigValue = entry.getValue().toString();
properties.put(configKey, newConfigValue);
}
}
public static Properties getProperties() {
return properties;
}
}
https://blog.csdn.net/shfqbluestone/article/details/125406595
https://blog.csdn.net/dcr782195101/article/details/122000536
https://blog.csdn.net/qq_29235677/article/details/122664382
通过上面三篇文章得知
System.getProperty()
获取启动 java 程序时设置的参数,通过 key=value 的方式设置
-Dname=value
System.getenv()
获取操作系统的环境变量,可以先在操作系统中设置环境变量