Dynamic Configuration Consul Implementation
Consul is also supported as a Dynamic Configuration Center (DCC). To use it, please configure it as follows:
configuration:
selector: ${SW_CONFIGURATION:consul}
consul:
# Consul host and ports, separated by comma, e.g. 1.2.3.4:8500,2.3.4.5:8500
hostAndPorts: ${SW_CONFIG_CONSUL_HOST_AND_PORTS:1.2.3.4:8500}
# Sync period in seconds. Defaults to 60 seconds.
period: ${SW_CONFIG_CONSUL_PERIOD:1}
# Consul aclToken
aclToken: ${SW_CONFIG_CONSUL_ACL_TOKEN:""}
Config Storage
Single Config
Single configs in Consul are key/value pairs:
Key | Value |
---|---|
configKey | configVaule |
e.g. The config is:
{agent-analyzer.default.slowDBAccessThreshold}:{default:200,mongodb:50}
The config in Consul is:
Key | Value |
---|---|
agent-analyzer.default.slowDBAccessThreshold | default:200,mongodb:50 |
… | … |
Group Config
Group config in Consul are key/value pairs as well, but according to the level keys organized by /
, see: https://www.consul.io/docs/dynamic-app-config/kv#using-consul-kv
Key | Value |
---|---|
configKey/subItemkey1 | subItemValue1 |
configKey/subItemkey2 | subItemValue2 |
… | … |
If we use Consul UI, we can see keys organized like a folder:
configKey
-- subItemkey1
-- subItemkey2
...
e.g. The config is:
{core.default.endpoint-name-grouping-openapi}:|{customerAPI-v1}:{value of customerAPI-v1}
|{productAPI-v1}:{value of productAPI-v1}
|{productAPI-v2}:{value of productAPI-v2}
The config in Consul is:
Key | Value |
---|---|
core.default.endpoint-name-grouping-openapi/customerAPI-v1 | value of customerAPI-v1 |
core.default.endpoint-name-grouping-openapi/productAPI-v1 | value of productAPI-v1 |
core.default.endpoint-name-grouping-openapi/productAPI-v2 | value of productAPI-v2 |