本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。
为 DNS 名称查找设置 JVM TTL
Java 虚拟机 (JVM) 缓存 DNS 名称查找。当 JVM 将主机名解析为 IP 地址时,它会将该 IP 地址缓存一段指定的时间,即 time-to-live(TTL)。
由于 AWS 资源使用的 DNS 名称条目偶尔会发生变化,因此我们建议您将 JVM 的 TTL 值配置为 5 秒。这可确保在资源的 IP 地址发生更改时,您的应用程序将能够通过重新查询 DNS 来接收和使用资源的新 IP 地址。
对于一些 Java 配置,将设置 JVM 默认 TTL,以便在重新启动 JVM 之前绝不 刷新 DNS 条目。因此,如果在应用程序仍在运行时 AWS 资源的 IP 地址发生变化,则在您手动重启 JVM 并刷新缓存的 IP 信息之前,它将无法使用该资源。在此情况下,设置 JVM 的 TTL,以便定期刷新其缓存的 IP 信息是极为重要的。
如何设置 JVM TTL
要修改 JVM 的 TTL,请设置 net workaddress.cache.ttlnetworkaddress.cache.ttl
属性,在 Java 11 或更高版本$JAVA_HOME/jre/lib/security/java.security
的文件中设置该属性。$JAVA_HOME/conf/security/java.security
以下是文件中的一段片段,该java.security
文件显示 TTL 缓存设置为 5 秒。
# # This is the "master security properties file". # # An alternate java.security properties file may be specified ... # The Java-level namelookup cache policy for successful lookups: # # any negative value: caching forever # any positive value: the number of seconds to cache an address for # zero: do not cache ...
networkaddress.cache.ttl=5
...
在由$JAVA_HOME
环境变量表示的 JVM 上运行的所有应用程序都使用此设置。