Eureka客户端与服务配置
- (1)Eureka客户端工程
》1 服务提供
1 服务地址使用ip方式
2 续约
》2 服务消费:获取服务地址的频率 - (2)Eureka服务端工程 eureka-server
1 失效剔除
2 自我保护
Eureka客户端使用ip
- (1)默认注册时使用的是
主机名
或者localhost
,如果想用ip进行注册,可以在user-service 中添加配置如下:
eureka.instance.ip-address=127.0.0.1 # 设置当前的ip
eureka.instance.prefer-ip-address=true # 是否ip优名
重启,在调用服务的时候就已经变成ip地址;
需要注意的是:不是在eureka中的控制台服务实例状态显示。
//获取 provider ip与端口
List<ServiceInstance> list = discoveryClient.getInstances("demo01_provider_user_8001");//服务id
//表示运行中的服务对象
ServiceInstance serviceInstance = list.get(0);
String host = serviceInstance.getHost();
int port = serviceInstance.getPort();
log.info("host "+host);
log.info("port "+port);
Eureka客户端服务续约
- (1)什么叫服务续约
在注册服务完成以后,服务提供者会维持一个心跳
(定时向EurekaServer发起Rest请求)
告诉EurekaServer:我还活着”。这个我们称为服务的续约(renew)
有两个重要参数可以修改服务续约的行为;可以在中添加如下配置项:
lease-renewal-interval-in-seconds:服务续约(renew)的间隔,默认为30秒、
心跳包的时间间隔
lease-expiration-duration-in-seconds:服务失效时间,默认值90秒
没收到心跳包的最长时间
eureka.instance.lease-renewal-interval-in-seconds=30 # 时间间隔
eureka.instance.lease-expiration-duration-in-seconds=90 # 最长时间
Eureka获取服务列表fetch
- (1)当服务消费者启动时,会检测eureka.client.fetch-registry=true 参数的值,如果为true,则会从Eureka Server服务的列表拉取只读备份,然后缓存在本地。并且每隔30秒 会重新拉取并更新数据。
eureka.client.registry-fetch-interval-seconds=30
设置消费端可以定时获取注册中心的服务列表,并缓存时间
Eureka 服务端设置
- (1)服务下线
当服务进行正常关闭
操作时,它会触发一个服务下线的REST请求给Eureka Server,告诉服务注册中心:“我要下线了”。服务中心接受到请求之后,将该服务置为下线状态。 - (2)失效剔除
有时我们的服务可能由于内存溢出或网络故障等原因
使得服务不能正常的工作,而服务注册中心并未收到“服务下线”的请求。相对于服务提供者的“服务续约”操作,服务注册中心在启动时会创建一个定时任务,默认每隔一段时间(默认为60秒)将当前清单中超时(默认为90秒)没有续约的服务剔除,这个操作被称为失效剔除。
eureka.server.eviction-interval-timer-in-ms 参数对其进行修改,单位是毫秒。
eureka.server.eviction-interval-timer-in-ms=9000
失效讲的就是 删除非正常关闭的服务在注册中心的记录
Eureka 服务端设置
- (3)自我保护
我们关停一个服务,很可能会在Eureka面板看到一条警告:
eureka.server.enable-self-preservation=false
这是触发了Eureka的自我保护机制
eureka.server.enable-self-preservation=false
关闭自我保护模式(缺省为打开)