OpenSearch/distribution
Jason Tedor 2afa7faefd
Override the JVM DNS cache policy (#36570)
When a security manager is present, the JVM will cache positive hostname
lookups indefinitely. This can be problematic, especially in the modern
world with cloud services where DNS addresses can change, or
environments using Docker containers where IP addresses could be
considered ephemeral. This behavior impacts cluster discovery,
cross-cluster replication and cross-cluster search, reindex from remote,
snapshot repositories, webhooks in Watcher, external authentication
mechanisms, and the Elastic Stack Monitoring Service. The experience of
watching a DNS lookup change yet not be reflected within Elasticsearch
is a poor experience for users. The reason the JVM has this is guard
against DNS cache posioning attacks. Yet, there is already a defense in
the modern world against such attacks: TLS. With proper certificate
validation, even if a resolver falls prey to a DNS cache poisoning
attack, using TLS would neuter the attack. Therefore we have a policy
with dubious security value that significantly impacts usability. As
such we make the usability/security tradeoff towards usability, since
the security risks are very low. This commit introduces new system
properties that Elasticsearch observes to override the JVM DNS cache
policy.
2018-12-13 10:23:45 -05:00
..
archives Deprecate types in get, exists, and multi get. (#35930) 2018-12-10 17:22:48 -08:00
bwc Upgrade to Gradle 5.0 (#34263) 2018-12-05 14:06:11 +02:00
docker Introduce Docker images build (#36246) 2018-12-06 17:06:13 -05:00
packages Upgrade to Gradle 5.0 (#34263) 2018-12-05 14:06:11 +02:00
src Override the JVM DNS cache policy (#36570) 2018-12-13 10:23:45 -05:00
tools plugin install: don't print download progress in batch mode (#36361) 2018-12-12 12:24:39 +02:00
build.gradle Fix extractjar task ci (#33272) 2018-09-03 10:18:34 +03:00