Distributed Configuration with Zookeeper
Zookeeper provides a hierarchical namespace that allows clients to store arbitrary data, such as configuration data. Spring Cloud Zookeeper Config is an alternative to the Config Server and Client. Configuration is loaded into the Spring Environment during the special "bootstrap" phase. Configuration is stored in the /config
namespace by default. Multiple PropertySource
instances are created based on the application’s name and the active profiles that mimicks the Spring Cloud Config order of resolving properties. For example, an application with the name "testApp" and with the "dev" profile will have the following property sources created:
config/testApp,dev config/testApp config/application,dev config/application
The most specific property source is at the top, with the least specific at the bottom. Properties is the config/application
namespace are applicable to all applications using zookeeper for configuration. Properties in the config/testApp
namespace are only available to the instances of the service named "testApp".
Configuration is currently read on startup of the application. Sending a HTTP POST to /refresh
will cause the configuration to be reloaded. Watching the configuration namespace (which Zookeeper supports) is not currently implemented, but will be a future addition to this project.
How to activate
Including a dependency on org.springframework.cloud:spring-cloud-starter-zookeeper-config
will enable auto-configuration that will setup Spring Cloud Zookeeper Config.
Customizing
Zookeeper Config may be customized using the following properties:
bootstrap.yml
spring: cloud: zookeeper: config: enabled: true root: configuration defaultContext: apps profileSeparator: '::'
enabled
setting this value to "false" disables Zookeeper Configroot
sets the base namespace for configuration valuesdefaultContext
sets the name used by all applicationsprofileSeparator
sets the value of the separator used to separate the profile name in property sources with profiles
Unresolved directive in spring-cloud.adoc - include::/Users/sgibb/workspace/spring/spring-cloud-samples/scripts/docs/../cli/docs/src/main/asciidoc/spring-cloud-cli.adoc[]