Individual node configuration options can be set in three places:
Options set on the command line take precedence over all other sources. Options set in environment variables take precedence over options set in configuration files.
Cluster-wide settings are configured via the /config
admin endpoint and additionally in the configuration file. Values contained in the configuration file will seed the cluster setting with the provided value. After the cluster is running, only the admin endpoint is used.
The full documentation is contained in the API docs.
activeSize
- the maximum number of peers that can participate in the consensus protocol. Other peers will join as standbys.removeDelay
- the minimum time in seconds that a machine has been observed to be unresponsive before it is removed from the cluster.syncInterval
- the amount of time in seconds between cluster sync when it runs in standby mode.-name
- The node name. Defaults to a UUID.-addr
- The advertised public hostname:port for client communication. Defaults to 127.0.0.1:4001
.-discovery
- A URL to use for discovering the peer list. (i.e "https://discovery.etcd.io/your-unique-key"
).-http-read-timeout
- The number of seconds before an HTTP read operation is timed out.-http-write-timeout
- The number of seconds before an HTTP write operation is timed out.-bind-addr
- The listening hostname for client communication. Defaults to 0.0.0.0 and the advertised port.-peers
- A comma separated list of peers in the cluster (i.e "203.0.113.101:7001,203.0.113.102:7001"
).-peers-file
- The file path containing a comma separated list of peers in the cluster.-ca-file
- The path of the client CAFile. Enables client cert authentication when present.-cert-file
- The cert file of the client.-key-file
- The key file of the client.-config
- The path of the etcd configuration file. Defaults to /etc/etcd/etcd.conf
.-cors
- A comma separated white list of origins for cross-origin resource sharing.-cpuprofile
- The path to a file to output CPU profile data. Enables CPU profiling when present.-data-dir
- The directory to store log and snapshot. Defaults to the current working directory.-max-result-buffer
- The max size of result buffer. Defaults to 1024
.-max-retry-attempts
- The max retry attempts when trying to join a cluster. Defaults to 3
.-peer-addr
- The advertised public hostname:port for server communication. Defaults to 127.0.0.1:7001
.-peer-bind-addr
- The listening hostname for server communication. Defaults to 0.0.0.0 and the advertised peer port.-peer-ca-file
- The path of the CAFile. Enables client/peer cert authentication when present.-peer-cert-file
- The cert file of the server.-peer-key-file
- The key file of the server.-peer-election-timeout
- The number of milliseconds to wait before the leader is declared unhealthy.-peer-heartbeat-interval
- The number of milliseconds in between heartbeat requests-snapshot=false
- Disable log snapshots. Defaults to true
.-cluster-active-size
- The expected number of instances participating in the consensus protocol. Only applied if the etcd instance is the first peer in the cluster.-cluster-remove-delay
- The number of seconds before one node is removed from the cluster since it cannot be connected at all. Only applied if the etcd instance is the first peer in the cluster.-cluster-sync-interval
- The number of seconds between synchronization for standby-mode instance with the cluster. Only applied if the etcd instance is the first peer in the cluster.-v
- Enable verbose logging. Defaults to false
.-vv
- Enable very verbose logging. Defaults to false
.-version
- Print the version and exit.The etcd configuration file is written in TOML
and read from /etc/etcd/etcd.conf
by default.
addr = "127.0.0.1:4001"
bind_addr = "127.0.0.1:4001"
ca_file = ""
cert_file = ""
cors = []
cpu_profile_file = ""
data_dir = "."
discovery = "http://etcd.local:4001/v2/keys/_etcd/registry/examplecluster"
http_read_timeout = 10
http_write_timeout = 10
key_file = ""
peers = []
peers_file = ""
max_cluster_size = 9
max_result_buffer = 1024
max_retry_attempts = 3
name = "default-name"
snapshot = false
verbose = false
very_verbose = false
[peer]
addr = "127.0.0.1:7001"
bind_addr = "127.0.0.1:7001"
ca_file = ""
cert_file = ""
key_file = ""
[cluster]
active_size = 9
remove_delay = 1800.0
sync_interval = 5.0
ETCD_ADDR
ETCD_BIND_ADDR
ETCD_CA_FILE
ETCD_CERT_FILE
ETCD_CORS_ORIGINS
ETCD_CONFIG
ETCD_CPU_PROFILE_FILE
ETCD_DATA_DIR
ETCD_DISCOVERY
ETCD_CLUSTER_HTTP_READ_TIMEOUT
ETCD_CLUSTER_HTTP_WRITE_TIMEOUT
ETCD_KEY_FILE
ETCD_PEERS
ETCD_PEERS_FILE
ETCD_MAX_CLUSTER_SIZE
ETCD_MAX_RESULT_BUFFER
ETCD_MAX_RETRY_ATTEMPTS
ETCD_NAME
ETCD_SNAPSHOT
ETCD_VERBOSE
ETCD_VERY_VERBOSE
ETCD_PEER_ADDR
ETCD_PEER_BIND_ADDR
ETCD_PEER_CA_FILE
ETCD_PEER_CERT_FILE
ETCD_PEER_KEY_FILE
ETCD_PEER_ELECTION_TIMEOUT
ETCD_CLUSTER_ACTIVE_SIZE
ETCD_CLUSTER_REMOVE_DELAY
ETCD_CLUSTER_SYNC_INTERVAL