我们公司有一个 tomcat 的安全策略,如果需要任何新的安全策略,我们将不得不请求。我正在使用 spring-cloud-starter-hystrix-1.4.1.RELEASE,它正在使用 archaius-core-0.7.4.jar。我们的服务器管理员绝对不会授予以下权限,基本上要求对所有内容进行读写权限
Caused by: java.lang.ExceptionInInitializerError
at com.netflix.config.DynamicPropertyFactory.getInstance(DynamicPropertyFactory.java:277)
at com.netflix.hystrix.contrib.metrics.eventstream.HystrixMetricsStreamServlet.<clinit>(HystrixMetricsStreamServlet.java:55)
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
at java.lang.Class.newInstance(Class.java:442)
at org.springframework.web.servlet.mvc.ServletWrappingController.afterPropertiesSet(ServletWrappingController.java:144)
at org.springframework.cloud.netflix.endpoint.ServletWrappingEndpoint.afterPropertiesSet(ServletWrappingEndpoint.java:50)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory$6.run(AbstractAutowireCapableBeanFactory.java:1677)
at java.security.AccessController.doPrivileged(Native Method)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1674)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1624)
... 107 more
Caused by: java.lang.RuntimeException: Error initializing configuration
at com.netflix.config.ConfigurationManager.<clinit>(ConfigurationManager.java:109)
... 120 more
Caused by: java.security.AccessControlException: access denied ("java.util.PropertyPermission" "*" "read,write")
at java.security.AccessControlContext.checkPermission(AccessControlContext.java:472)
at java.security.AccessController.checkPermission(AccessController.java:884)
at java.lang.SecurityManager.checkPermission(SecurityManager.java:549)
at java.lang.SecurityManager.checkPropertiesAccess(SecurityManager.java:1262)
at java.lang.System.getProperties(System.java:630)
at org.apache.commons.configuration.SystemConfiguration.<init>(SystemConfiguration.java:44)
at com.netflix.config.ConfigurationManager.createDefaultConfigInstance(ConfigurationManager.java:146)
at com.netflix.config.ConfigurationManager.getConfigInstance(ConfigurationManager.java:161)
at com.netflix.config.ConfigurationManager.getConfigInstance(ConfigurationManager.java:176)
at com.netflix.config.ConfigurationBasedDeploymentContext.<init>(ConfigurationBasedDeploymentContext.java:108)
at com.netflix.config.ConfigurationManager.<clinit>(ConfigurationManager.java:104)
... 120 more
在研究了为什么 ConfigurationManager 中的 archaius.dynamicProperty.disableSystemConfig 值默认为 false 之后,这让 archaius 默认系统配置。commons-configuration jar 有一个使用 System.getProperties() 的代码,这就是我看到这个错误的原因。
我们没有使用 archaius,因此从 spring boot 应用程序类中排除了 ArchaiusAutoConfiguration.class,但它似乎仍在寻找配置。
我的问题是如何禁用archaius?从 Spring Boot 应用程序类本身排除 ArchaiusAutoConfiguration 还不够吗?如果我必须将 archaius.dynamicProperty.disableSystemConfig 值设置为 true,我该怎么做?在哪里?
在 github 上也提出了一个问题 https://github.com/Netflix/archaius/issues/539