1.上面我们已经将消费方和服务提供方注入到注册中心了。
- 作为服务提供方:将自己注入到注册中心,注册中心与其建立心跳机制,服务提供方每隔一段时间便会发送一次心跳来告知eureka server自己还存活,然后与其续约。正常情况下,如果eureka server在90秒没有收到服务提供方的续约,它会将实例从其注册表中删除。 建议不要更改续约间隔
- 作为服务消费方:将自己注入到注册中心,并从注册中心拉取服务列表,并将其缓存在本地。客户端会使用该信息查找其他服务,从而进行远程调用。
2.改造服务消费方:
- 在控制器下注入服务列表:
@Autowired
private DiscoveryClient discoveryClient; //包含了拉取的所有服务信息
- 在方法中调用该服务,并用getHost()和.getPort()将该服务的ip地址、端口号拼接到URL即可调用到该服务。
@GetMapping
@ResponseBody
public User queryUserById(@RequestParam("id") Long id) {
List<ServiceInstance> instances = discoveryClient.getInstances("service-provider"); //调用该服务
ServiceInstance instance = instances.get(0);
return this.restTemplate.getForObject("http://"+instance.getHost()+":"+instance.getPort()+"/user/" + id, User.class);
}
总结: 调取服务时候,只需将注册的服务名称暴露给消费方调用即可,大大方便了开发者,使代码灵活易扩展。