Skip to content

Commit

Permalink
Rename static Zen1 settings (#38333)
Browse files Browse the repository at this point in the history
Renames the following settings to remove the mention of `zen` in their names:

- `discovery.zen.hosts_provider` -> `discovery.seed_providers`
- `discovery.zen.ping.unicast.concurrent_connects` -> `discovery.seed_resolver.max_concurrent_resolvers`
- `discovery.zen.ping.unicast.hosts.resolve_timeout` -> `discovery.seed_resolver.timeout`
- `discovery.zen.ping.unicast.hosts` -> `discovery.seed_addresses`
  • Loading branch information
DaveCTurner authored Feb 5, 2019
1 parent 89feaa0 commit 2d114a0
Show file tree
Hide file tree
Showing 44 changed files with 348 additions and 155 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -131,10 +131,12 @@ class ClusterFormationTasks {
writeConfigSetup = { Map esConfig ->
if (config.getAutoSetHostsProvider()) {
// Don't force discovery provider if one is set by the test cluster specs already
if (esConfig.containsKey('discovery.zen.hosts_provider') == false) {
esConfig['discovery.zen.hosts_provider'] = 'file'
final String seedProvidersSettingName =
node.nodeVersion.onOrAfter("7.0.0") ? "discovery.seed_providers" : "discovery.zen.hosts_provider";
if (esConfig.containsKey(seedProvidersSettingName) == false) {
esConfig[seedProvidersSettingName] = 'file'
}
esConfig['discovery.zen.ping.unicast.hosts'] = []
esConfig[node.nodeVersion.onOrAfter("7.0.0") ? "discovery.seed_hosts" : "discovery.zen.ping.unicast.hosts"] = []
}
boolean supportsInitialMasterNodes = hasBwcNodes == false || config.bwcVersion.onOrAfter("7.0.0")
if (esConfig['discovery.type'] == null && config.getAutoSetInitialMasterNodes() && supportsInitialMasterNodes) {
Expand Down
4 changes: 2 additions & 2 deletions distribution/src/config/elasticsearch.yml
Original file line number Diff line number Diff line change
Expand Up @@ -62,10 +62,10 @@ ${path.logs}
#
# --------------------------------- Discovery ----------------------------------
#
# Pass an initial list of hosts to perform discovery when new node is started:
# Pass an initial list of hosts to perform discovery when this node is started:
# The default list of hosts is ["127.0.0.1", "[::1]"]
#
#discovery.zen.ping.unicast.hosts: ["host1", "host2"]
#discovery.seed_hosts: ["host1", "host2"]
#
# Bootstrap the cluster using an initial set of master-eligible nodes:
#
Expand Down
2 changes: 1 addition & 1 deletion docs/plugins/discovery-azure-classic.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ cloud:
type: pkcs12
discovery:
zen.hosts_provider: azure
seed_providers: azure
----

[IMPORTANT]
Expand Down
2 changes: 1 addition & 1 deletion docs/plugins/discovery-ec2.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ provider for Zen discovery to `ec2`:

[source,yaml]
----
discovery.zen.hosts_provider: ec2
discovery.seed_providers: ec2
----

==== Settings
Expand Down
10 changes: 5 additions & 5 deletions docs/plugins/discovery-gce.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ cloud:
project_id: <your-google-project-id>
zone: <your-zone>
discovery:
zen.hosts_provider: gce
seed_providers: gce
--------------------------------------------------

The following gce settings (prefixed with `cloud.gce`) are supported:
Expand Down Expand Up @@ -232,7 +232,7 @@ cloud:
project_id: es-cloud
zone: europe-west1-a
discovery:
zen.hosts_provider: gce
seed_providers: gce
--------------------------------------------------


Expand Down Expand Up @@ -346,7 +346,7 @@ cloud:
project_id: <your-google-project-id>
zone: ["<your-zone1>", "<your-zone2>"]
discovery:
zen.hosts_provider: gce
seed_providers: gce
--------------------------------------------------


Expand Down Expand Up @@ -382,7 +382,7 @@ cloud:
project_id: es-cloud
zone: europe-west1-a
discovery:
zen.hosts_provider: gce
seed_providers: gce
gce:
tags: elasticsearch, dev
--------------------------------------------------
Expand Down Expand Up @@ -497,7 +497,7 @@ cloud:
project_id: es-cloud
zone: europe-west1-a
discovery:
zen.hosts_provider: gce
seed_providers: gce
--------------------------------------------------

Replaces `project_id` and `zone` with your settings.
Expand Down
4 changes: 2 additions & 2 deletions docs/reference/migration/migrate_7_0/discovery.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,6 @@ Production deployments of Elasticsearch now require at least one of the
following settings to be specified in the `elasticsearch.yml` configuration
file:

- `discovery.zen.ping.unicast.hosts`
- `discovery.zen.hosts_provider`
- `discovery.seed_hosts`
- `discovery.seed_providers`
- `cluster.initial_master_nodes`
4 changes: 2 additions & 2 deletions docs/reference/modules/discovery/bootstrapping.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -94,6 +94,6 @@ If any of the following settings are configured then auto-bootstrapping will not
take place, and you must configure `cluster.initial_master_nodes` as described
in the <<modules-discovery-bootstrap-cluster,section on cluster bootstrapping>>:

* `discovery.zen.hosts_provider`
* `discovery.zen.ping.unicast.hosts`
* `discovery.seed_providers`
* `discovery.seed_hosts`
* `cluster.initial_master_nodes`
20 changes: 13 additions & 7 deletions docs/reference/modules/discovery/discovery-settings.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -105,9 +105,10 @@ Discovery and cluster formation are affected by the following settings:
`discovery.cluster_formation_warning_timeout`::

Sets how long a node will try to form a cluster before logging a warning
that the cluster did not form. Defaults to `10s`. If a cluster has not
that the cluster did not form. Defaults to `10s`. If a cluster has not
formed after `discovery.cluster_formation_warning_timeout` has elapsed then
the node will log a warning message that starts with the phrase `master not discovered` which describes the current state of the discovery process.
the node will log a warning message that starts with the phrase `master not
discovered` which describes the current state of the discovery process.

`discovery.find_peers_interval`::

Expand All @@ -128,9 +129,9 @@ Discovery and cluster formation are affected by the following settings:
Sets how long a node will wait after asking its peers again before
considering the request to have failed. Defaults to `3s`.

`discovery.zen.hosts_provider`::
Specifies which type of <<built-in-hosts-providers,hosts provider>> provides
the list of seed nodes. By default, it is the
`discovery.seed_providers`::
Specifies which types of <<built-in-hosts-providers,seed provider>> provide
the addresses of seed nodes. By default, it is the
<<settings-based-hosts-provider,settings-based hosts provider>>.

[[no-master-block]]`discovery.zen.no_master_block`::
Expand All @@ -157,15 +158,20 @@ APIs are not be blocked and can run on any available node.
===============================
--

`discovery.zen.ping.unicast.hosts`::
`discovery.seed_hosts`::

Provides a list of master-eligible nodes in the cluster. The list contains
either an array of hosts or a comma-delimited string. Each value has the
format `host:port` or `host`, where `port` defaults to the setting
`transport.profiles.default.port`. Note that IPv6 hosts must be bracketed.
The default value is `127.0.0.1, [::1]`. See <<unicast.hosts>>.

`discovery.zen.ping.unicast.hosts.resolve_timeout`::
`discovery.seed_resolver.timeout`::

Sets the amount of time to wait for DNS lookups on each round of discovery.
This is specified as a <<time-units, time unit>> and defaults to `5s`.

`discovery.seed_resolver.max_concurrent_resolvers`::

Sets the number of threads with which to perform DNS lookups for seed nodes.
This defaults to `10`.
28 changes: 14 additions & 14 deletions docs/reference/modules/discovery/discovery.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ By default the cluster formation module offers two hosts providers to configure
the list of seed nodes: a _settings_-based and a _file_-based hosts provider.
It can be extended to support cloud environments and other forms of hosts
providers via {plugins}/discovery.html[discovery plugins]. Hosts providers are
configured using the `discovery.zen.hosts_provider` setting, which defaults to
configured using the `discovery.seed_providers` setting, which defaults to
the _settings_-based hosts provider. Multiple hosts providers can be specified
as a list.

Expand All @@ -49,12 +49,12 @@ round of discovery. Note that if you are in an environment where DNS resolutions
vary with time, you might need to adjust your <<networkaddress-cache-ttl,JVM
security settings>>.

The list of hosts is set using the <<unicast.hosts,`discovery.zen.ping.unicast.hosts`>> static
The list of hosts is set using the <<unicast.hosts,`discovery.seed_hosts`>> static
setting. For example:

[source,yaml]
--------------------------------------------------
discovery.zen.ping.unicast.hosts:
discovery.seed_hosts:
- 192.168.1.10:9300
- 192.168.1.11 <1>
- seeds.mydomain.com <2>
Expand All @@ -64,9 +64,9 @@ discovery.zen.ping.unicast.hosts:
<2> A hostname that resolves to multiple IP addresses will try all resolved
addresses.

Additionally, the `discovery.zen.ping.unicast.hosts.resolve_timeout` configures
the amount of time to wait for DNS lookups on each round of discovery. This is
specified as a <<time-units, time unit>> and defaults to 5s.
Additionally, the `discovery.seed_resolver.timeout` configures the amount of
time to wait for DNS lookups on each round of discovery. This is specified as a
<<time-units, time unit>> and defaults to 5s.

Unicast discovery uses the <<modules-transport,transport>> module to perform the
discovery.
Expand All @@ -87,21 +87,21 @@ in the `elasticsearch.yml` file:

[source,yml]
----------------------------------------------------------------
discovery.zen.hosts_provider: file
discovery.seed_providers: file
----------------------------------------------------------------

Then create a file at `$ES_PATH_CONF/unicast_hosts.txt` in the format described
below. Any time a change is made to the `unicast_hosts.txt` file the new changes
will be picked up by Elasticsearch and the new hosts list will be used.

Note that the file-based discovery plugin augments the unicast hosts list in
`elasticsearch.yml`. If there are valid unicast host entries in
`discovery.zen.ping.unicast.hosts`, they are used in addition to those
supplied in `unicast_hosts.txt`.
`elasticsearch.yml`. If there are valid seed addresses in
`discovery.seed_hosts` then they are used in addition to those supplied in
`unicast_hosts.txt`.

The `discovery.zen.ping.unicast.hosts.resolve_timeout` setting also applies to
DNS lookups for nodes specified by address via file-based discovery. This is
specified as a <<time-units, time unit>> and defaults to 5s.
The `discovery.seed_resolver.timeout` setting also applies to DNS lookups for
seed addresses given via file-based discovery. This is specified as a
<<time-units, time unit>> and defaults to 5s.

The format of the file is to specify one node entry per line. Each node entry
consists of the host (host name or IP address) and an optional transport port
Expand All @@ -123,7 +123,7 @@ the default port:
----------------------------------------------------------------

Host names are allowed instead of IP addresses (similar to
`discovery.zen.ping.unicast.hosts`), and IPv6 addresses must be specified in
`discovery.seed_hosts`), and IPv6 addresses must be specified in
brackets with the port coming after the brackets.

You can also add comments to this file. All comments must appear on
Expand Down
15 changes: 7 additions & 8 deletions docs/reference/modules/network.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -28,19 +28,18 @@ because `:` is a special character in YAML.
+
Defaults to `_local_`.

`discovery.zen.ping.unicast.hosts`::
`discovery.seed_hosts`::

In order to join a cluster, a node needs to know the hostname or IP address of
at least some of the other nodes in the cluster. This setting provides the
initial list of other nodes that this node will try to contact. Accepts IP
addresses or hostnames. If a hostname lookup resolves to multiple IP
addresses then each IP address will be used for discovery.
initial list of addresses this node will try to contact. Accepts IP addresses
or hostnames. If a hostname lookup resolves to multiple IP addresses then each
IP address will be used for discovery.
https://en.wikipedia.org/wiki/Round-robin_DNS[Round robin DNS] -- returning a
different IP from a list on each lookup -- can be used for discovery; non-
existent IP addresses will throw exceptions and cause another DNS lookup
on the next round of pinging (subject to JVM DNS caching).
+
Defaults to `["127.0.0.1", "[::1]"]`.
existent IP addresses will throw exceptions and cause another DNS lookup on the
next round of pinging (subject to JVM DNS caching). + Defaults to
`["127.0.0.1", "[::1]"]`.

`http.port`::

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -136,7 +136,7 @@ services:
image: {docker-image}
environment:
- node.name=es02
- discovery.zen.ping.unicast.hosts=es01
- discovery.seed_hosts=es01
- cluster.initial_master_nodes=es01,es02
- ELASTIC_PASSWORD=$ELASTIC_PASSWORD
- "ES_JAVA_OPTS=-Xms512m -Xmx512m"
Expand Down
4 changes: 2 additions & 2 deletions docs/reference/setup/bootstrap-checks.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -252,6 +252,6 @@ This bootstrap check ensures that discovery is not running with the default
configuration. It can be satisfied by setting at least one of the following
properties:

- `discovery.zen.ping.unicast.hosts`
- `discovery.zen.hosts_provider`
- `discovery.seed_hosts`
- `discovery.seed_providers`
- `cluster.initial_master_nodes`
Original file line number Diff line number Diff line change
Expand Up @@ -10,15 +10,15 @@ each other and elect a master node.

[float]
[[unicast.hosts]]
==== `discovery.zen.ping.unicast.hosts`
==== `discovery.seed_hosts`

Out of the box, without any network configuration, Elasticsearch will bind to
the available loopback addresses and will scan local ports 9300 to 9305 to try
to connect to other nodes running on the same server. This provides an auto-
clustering experience without having to do any configuration.

When the moment comes to form a cluster with nodes on other servers, you must
use the `discovery.zen.ping.unicast.hosts` setting to provide a seed list of
use the `discovery.seed_hosts` setting to provide a seed list of
other nodes in the cluster that are master-eligible and likely to be live and
contactable. This setting should normally contain the addresses of all the
master-eligible nodes in the cluster.
Expand All @@ -44,7 +44,7 @@ This list is set using the `cluster.initial_master_nodes` setting.

[source,yaml]
--------------------------------------------------
discovery.zen.ping.unicast.hosts:
discovery.seed_hosts:
- 192.168.1.10:9300
- 192.168.1.11 <1>
- seeds.mydomain.com <2>
Expand All @@ -62,4 +62,4 @@ cluster.initial_master_nodes:
<5> If multiple master nodes share an IP address then the port must be used to
disambiguate them.

For more information, see <<modules-discovery-settings>>.
For more information, see <<modules-discovery-settings>>.
2 changes: 1 addition & 1 deletion docs/reference/setup/install/docker.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -187,7 +187,7 @@ services:
container_name: es02
environment:
- node.name=es02
- discovery.zen.ping.unicast.hosts=es01
- discovery.seed_hosts=es01
- cluster.initial_master_nodes=es01,es02
- cluster.name=docker-cluster
- bootstrap.memory_lock=true
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,7 @@
import java.util.concurrent.ConcurrentHashMap;

import static org.elasticsearch.common.util.CollectionUtils.newSingletonArrayList;
import static org.elasticsearch.discovery.DiscoveryModule.DISCOVERY_SEED_PROVIDERS_SETTING;

public abstract class AbstractAzureComputeServiceTestCase extends ESIntegTestCase {

Expand All @@ -63,7 +64,7 @@ public void clearAzureNodes() {
protected Settings nodeSettings(int nodeOrdinal) {
Settings.Builder builder = Settings.builder()
.put(super.nodeSettings(nodeOrdinal))
.put("discovery.zen.hosts_provider", "azure");
.put(DISCOVERY_SEED_PROVIDERS_SETTING.getKey(), "azure");

// We add a fake subscription_id to start mock compute service
builder.put(Management.SUBSCRIPTION_ID_SETTING.getKey(), "fake")
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -116,7 +116,7 @@ protected Settings nodeSettings(int nodeOrdinal) {
throw new RuntimeException(e);
}
return Settings.builder().put(super.nodeSettings(nodeOrdinal))
.put(DiscoveryModule.DISCOVERY_HOSTS_PROVIDER_SETTING.getKey(), AzureDiscoveryPlugin.AZURE)
.put(DiscoveryModule.DISCOVERY_SEED_PROVIDERS_SETTING.getKey(), AzureDiscoveryPlugin.AZURE)
.put(Environment.PATH_LOGS_SETTING.getKey(), resolve)
.put(TransportSettings.PORT.getKey(), 0)
.put(Node.WRITE_PORTS_FILE_SETTING.getKey(), "true")
Expand Down
2 changes: 1 addition & 1 deletion plugins/discovery-ec2/qa/amazon-ec2/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@ integTestCluster {
plugin ':plugins:discovery-ec2'
keystoreSetting 'discovery.ec2.access_key', 'ec2_integration_test_access_key'
keystoreSetting 'discovery.ec2.secret_key', 'ec2_integration_test_secret_key'
setting 'discovery.zen.hosts_provider', 'ec2'
setting 'discovery.seed_providers', 'ec2'
setting 'network.host', '_ec2_'
setting 'discovery.ec2.endpoint', "http://${-> ec2Fixture.addressAndPort}"
systemProperty "com.amazonaws.sdk.ec2MetadataServiceEndpointOverride", "http://${-> ec2Fixture.addressAndPort}"
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@
public class Ec2DiscoveryUpdateSettingsTests extends AbstractAwsTestCase {
public void testMinimumMasterNodesStart() {
Settings nodeSettings = Settings.builder()
.put(DiscoveryModule.DISCOVERY_HOSTS_PROVIDER_SETTING.getKey(), "ec2")
.put(DiscoveryModule.DISCOVERY_SEED_PROVIDERS_SETTING.getKey(), "ec2")
.build();
internalCluster().startNode(nodeSettings);

Expand Down
2 changes: 1 addition & 1 deletion plugins/discovery-gce/qa/gce/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ integTestCluster {
dependsOn gceFixture
numNodes = gceNumberOfNodes
plugin ':plugins:discovery-gce'
setting 'discovery.zen.hosts_provider', 'gce'
setting 'discovery.seed_providers', 'gce'

// use gce fixture for Auth calls instead of http://metadata.google.internal
integTestCluster.environment 'GCE_METADATA_HOST', "http://${-> gceFixture.addressAndPort}"
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@
import java.util.concurrent.ConcurrentHashMap;

import static java.util.Collections.singletonList;
import static org.elasticsearch.discovery.DiscoveryModule.DISCOVERY_SEED_PROVIDERS_SETTING;
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertNoTimeout;

@ESIntegTestCase.ClusterScope(supportsDedicatedMasters = false, numDataNodes = 0, numClientNodes = 0)
Expand All @@ -62,7 +63,7 @@ protected Collection<Class<? extends Plugin>> nodePlugins() {
protected Settings nodeSettings(int nodeOrdinal) {
return Settings.builder()
.put(super.nodeSettings(nodeOrdinal))
.put("discovery.zen.hosts_provider", "gce")
.put(DISCOVERY_SEED_PROVIDERS_SETTING.getKey(), "gce")
.put("cloud.gce.project_id", "test")
.put("cloud.gce.zone", "test")
.build();
Expand Down
Loading

0 comments on commit 2d114a0

Please sign in to comment.