Eureka:客户端配置信息
eureka 客户端向 Eureka 服务器注册实例所需的配置信息。
默认配置 DefaultEurekaClientConfig 提供了大多数必需信息。用户只需要提供 eureka 服务器服务 URL。可以通过2种机制配置 Eureka 服务器服务 URL:
通过在 DNS 中注册信息。
通过在配置中指定它。
注册客户端后,用户可以根据最常见的 虚拟主机名(也称为 VIPAddress)从 EurekaClient 查找信息,也可以通过其他方式来获取必要的信息。与在 Eureka 中注册的其他实例进行对话。
请注意,除非另有说明,否则所有配置在运行时均无效。

属性:eureka.client.registry-fetch-interval-seconds
默认:30s
说明:指示从 eureka 服务器获取注册表信息的频率(以秒为单位)。
属性:eureka.client.enabled
默认:true
说明:指示已启用 Eureka 客户端的标志。
属性:eureka.client.instance-info-replication-interval-seconds
默认:30s
说明:指示将实例更改复制到 eureka 服务器的频率(以秒为单位);
属性:eureka.client.initial-instance-info-replication-interval-seconds
默认:40s
说明:指示最初将实例信息复制到 eureka 服务器的时间(以秒为单位)。
属性:eureka.client.eureka-service-url-poll-interval-seconds
默认:5min
说明:指示轮询 eureka 服务器信息更改的频率(以秒为单位);可以添加或删除 Eureka 服务器,此设置控制 eureka 客户端应该多久知道一次;轮询 eureka 服务 URL 时间间隔更改。
属性:eureka.client.proxy-host
默认:""
说明:获取到 eureka 服务器的代理主机(如果有)。
属性:eureka.client.proxy-port
默认:""
说明:获取到 eureka 服务器的代理端口(如果有)。
属性:eureka.client.proxy-user-name
默认:""
说明:获取代理用户名(如果有)。
属性:eureka.client.proxy-password
默认:""
说明:获取代理密码(如果有)。
属性:eureka.client.eureka-server-read-timeout-seconds
默认:8s
说明:指示从 eureka 服务器读取需要等待多长时间(以秒为单位)。
属性:eureka.client.eureka-server-connect-timeout-seconds
默认:5s
说明:指示与 eureka 服务器的连接需要超时之前要等待的时间(以秒为单位);请注意,客户端中的连接由org.apache.http.client.HttpClient 池化,此设置影响实际的连接创建以及从池中获取连接的等待时间。
属性:
eureka.client.backup-registry-impl
默认:""
说明:获取实现的名称,该实现实现 BackupRegistry 以仅当 eureka 客户端启动时首次将注册表信息作为回退选项来获取;对于需要附加的注册表信息弹性而无法运行的应用程序可能需要这样做。
属性:eureka.client.eureka-server-total-connections
默认:200
说明:获取从 eureka 客户端到所有 eureka 服务器的允许的连接总数。
属性:eureka.client.eureka-server-total-connections-per-host
默认:50
说明:获取从 eureka 客户端到 eureka 服务器主机的允许的连接总数。
属性:eureka.client.eureka-server-u-r-l-context
默认:""
说明;当 eureka 服务器列表来自 DNS 时,获取用于构造服务 URL 以便与 eureka 服务器联系的 URL 上下文。如果合同从 eurekaServerServiceUrls 返回服务 URL,则不需要此信息;当useDnsForFetchingServiceUrls 设置为 true 且 eureka 客户端希望 DNS 以某种方式配置时,将使用 DNS 机制,以便它可以动态获取更改 eureka 服务器。这些更改在运行时有效。
属性:eureka.client.eureka-server-port
默认:""
说明:当 eureka 服务器列表来自 DNS 时,获取用于构建服务 URL 以便与 eureka 服务器联系的端口。如果合同返回服务 URL eurekaServerServiceUrls(String),则不需要此信息;当useDnsForFetchingServiceUrls 设置为 true 且 eureka 客户端期望 DNS 以某种方式配置时,将使用 DNS 机制,以便它可以动态获取更改 eureka 服务器;指示 eureka 服务器正在监听端口的字符串;这些更改在运行时有效。
属性:eureka.client.eureka-server-d-n-s-name
默认:""
说明:获取要查询获取 eureka 服务器列表的 DNS 名称。如果合同通过实现 serviceUrls 返回服务 URL,则不需要此信息;当useDnsForFetchingServiceUrls 设置为 true 且 eureka 客户端期望 DNS 以某种方式配置时,将使用 DNS 机制,以便它可以动态获取更改的 eureka 服务器;这些更改在运行时有效。
属性:eureka.client.use-dns-for-fetching-service-urls
默认:false
说明:指示 eureka 客户端是否应使用 DNS 机制来获取要交谈的 eureka 服务器列表。当 DNS名称更新为具有其他服务器时,该信息将在 eureka 客户端轮询
eurekaServiceUrlPollIntervalSeconds 中指定的信息后立即使用;或者,可以将服务 url 返回为 serviceUrls,但是用户应实现自己的机制,以在发生更改的情况下返回更新的列表;如果应该将 DNS 机制用于获取网址,则为 true,否则为 false;这些更改在运行时有效。
属性:eureka.client.register-with-eureka
默认:true
说明:指示此实例是否应在 eureka 服务器上注册其信息以供他人发现;在某些情况下,您不希望发现实例,而只希望发现其他实例;如果此实例应向 eureka 注册,则为 true,否则为 false。
属性:eureka.client.should-unregister-on-shutdown
默认:true
说明:指示客户端关闭时客户端是否应从远程服务器上显式注销自己;如果此实例应在客户端关闭时向 eureka 注销,则为 true,否则为 false。
属性:eureka.client.prefer-same-zone-eureka
默认:true
说明:指示此实例是否应出于延迟和/或其他原因尝试在同一区域中使用 eureka 服务器;理想情况下,将 eureka 客户端配置为与同一区域中的服务器通信;这些更改在运行时在下一个注册表获取周期生效,如registryFetchIntervalSeconds 所指定;如果 eureka 客户端应首选同一区域中的服务器,则为 true,否则为 false。
属性:eureka.client.allow-redirects
默认:false
说明:指示服务器是否可以将客户端请求重定向到备份服务器群集。如果设置为 false,则服务器将直接处理请求。如果设置为 true,则服务器可能会使用新的服务器位置将 HTTP 重定向发送到客户端。
属性:eureka.client.log-delta-diff
默认:false
说明:指示是否在注册表信息方面记录 eureka 服务器与 eureka 客户端之间的差异;Eureka 客户端尝试从 Eureka 服务器仅检索增量更改,以最大程度地减少网络流量。收到增量后, eureka 客户端会协调来自服务器的信息,以确认它没有丢失某些信息。当客户端与服务器通信时出现网络问题时,对帐可能会失败。如果对帐失败,则 eureka 客户端会获取完整的注册表信息;在获取完整的注册表信息时, eureka 客户端可以记录客户端和服务器之间的差异,此设置对此进行控制;这些更改在运行时在下一个注册表获取周期生效,如
registryFetchIntervalSecondsr 所指定;如果在对帐失败的情况下 eureka 客户应记录差额差异,则为 true。
属性:eureka.client.disable-delta
默认:false
说明:指示 eureka 客户端是否应禁用获取增量,而应诉诸于获取完整的注册表信息;请注意,增量获取可以极大地减少通信量,因为 eureka 服务器的更改率通常远低于获取率;这些更改在运行时在下一个注册表获取周期生效,如registryFetchIntervalSeconds 所指定;如果为 true,则启用获取注册表的增量信息;如果为 false,则获取完整的注册表。
属性:eureka.client.fetch-remote-regions-registry
默认:""
说明:以逗号分隔的区域列表,将获取其 eureka 注册表信息。必须定义由 availabilityZones 返回的每个区域的可用区。否则,将导致发现客户端启动失败;以逗号分隔的区域列表,将获取其 eureka 注册表信息。如果无需获取任何远程区域,则为 null 。
属性:eureka.client.filter-only-up-instances
默认:true
说明:指示在仅针对具有 InstanceStatus UP 状态的实例的应用程序进行筛选之后,是否获取应用程序;这些更改在运行时在eureka.client.registry-fetch-interval-seconds 指定的下一个注册表获取周期有效;过滤为 true,否则为 false。
属性:eureka.client.service-url
默认:HashMap() {"defaultZone" :"http://localhost:8761/eureka/"}
说明:可用区映射到与 eureka 服务器通信的标准URL列表。每个值可以是单个 URL 或用逗号分隔的替代位置列表;通常, eureka 服务器 URL 包含协议,主机,端口,上下文和版本信息(如果有);这些更改将在运行时在eurekaServiceUrlPollIntervalSeconds 指定的下一个服务 URL 刷新周期生效。
属性:eureka.client.filter-only-up-instances
默认:true
说明:指示在仅针对具有 InstanceStatus UP 状态的实例的应用程序进行筛选之后,是否获取应用程序;这些更改在运行时在eureka.client.registry-fetch-interval-seconds 指定的下一个注册表获取周期有效;过滤为 true,否则为 false。
属性:eureka.client.eureka-connection-idle-timeout-seconds
默认:30s
说明:指示与 eureka 服务器的 HTTP 连接在关闭之前可以保持空闲状态的时间(以秒为单位);在 AWS 环境中,建议将该值设置为30秒或更短,因为防火墙会在几分钟后清除连接信息,从而使连接处于死角状态。
属性:eureka.client.fetch-registry
默认:true
说明:指示此客户端是否应从 eureka 服务器获取 eureka 注册表信息;如果必须获取注册表信息,则为 true,否则为 false。
属性:eureka.client.registry-refresh-single-vip-address
默认:""
说明:指示客户端是否仅对单个 VIP 的注册表信息感兴趣;VIP 的地址(名称:端口)。如果没有单个 VIP 兴趣,则 null 。
属性:eureka.client.heartbeat-executor-thread-pool-size
默认:2
说明:用于心跳执行器初始化的线程池大小。
属性:eureka.client.heartbeat-executor-exponential-back-off-bound
默认:10
说明:心跳执行器指数回退相关属性。在发生一系列超时的情况下,它是重试延迟的最大乘数。
属性:eureka.client.cache-refresh-executor-thread-pool-size
默认:2
说明:cacheRefreshExecutor 要初始化的线程池大小。
属性:eureka.client.cache-refresh-executor-exponential-back-off-bound
默认:10
说明:缓存刷新执行器指数回退相关属性。在发生一系列超时的情况下,它是重试延迟的最大乘数。
属性:eureka.client.dollar-replacement
默认:_-
说明:在 eureka 服务器中序列化反序列化信息期间,获取美元符号 $ 的替换字符串。
属性:eureka.client.escape-char-replacement
默认:_ _
说明:在 eureka 服务器中序列化反序列化信息期间,获取下划线符号 _ 的替换字符串。
属性:eureka.client.on-demand-update-status-change
默认:true
说明:如果设置为 true,则通过 ApplicationInfoManager 进行的本地状态更新将触发对远程 eureka 服务器的按需(但速率受限制)的寄存器更新;对本地状态更新是否应按需更新到远程服务器为真或假
属性:eureka.client.should-enforce-registration-at-init
默认:false
说明:指示客户端在初始化期间是否应强制注册。默认为 false。
属性:eureka.client.encoder-name
默认:“”
说明:这是一个临时配置,一旦最新的编解码器稳定下来,就可以删除它(因为只有一个);客户端使用的编码编解码器的类名称。如果未设置,将使用默认编解码器。
属性:eureka.client.decoder-name
默认:""
说明:这是一个临时配置,一旦最新的编解码器稳定下来,就可以删除它(因为只有一个);客户端使用的解码编解码器的类名称。如果未设置,将使用默认编解码器。
属性:eureka.client.client-data-accept
默认:EurekaAccept.full.name()
说明:客户数据接受的 EurekaAccept 名称。
属性:eureka.client.fetch-remote-regions-registry
默认:""
说明:以逗号分隔的区域列表,将获取其 eureka 注册表信息。必须定义由 availabilityZones 返回的每个区域的可用区。否则,将导致发现客户端启动失败。
属性:eureka.client.order
默认:0
说明:由 CompositeDiscoveryClient 用来对可用客户端进行排序的发现客户端的顺序。
属性:eureka.client.region
默认:us-east-1
说明:获取此实例所在的区域(用于AWS数据中心)。

写在最后
好兄弟,记得点赞,关注,谢谢。
