简陋版的springcloud即将搭建完毕;
spring:
application:
name: consumer-service
server:
port: ${port:8091}
eureka:
client:
# 默认30秒 到eureka服务端拉取一次 服务注册列表 缓存本地
registry-fetch-interval-seconds: 30
service-url:
defaultZone: http://127.0.0.1:10001/eureka
logging:
level:
com.itheima: debug
添加eureka客户端依赖,consumer-service的启动类 添加注解@EnableDiscoveryClient
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
至此,简陋版的eureka注册中心 服务提供端 和 服务消费端 的配置就都搞定了,
检测注册中心中 http://localhost;10001中是否已经有了user-service 和consumer-service的服务,
编写代码:尝试从consumer-service调用user-service的方法;
consumer-service的启动类或者配置文件类向SpringIOC中注入RestTemplate对象
在Controller中注入RestTemplate对象和基于cloud包下的DiscoveryClient接口对象
@Autowired
private RestTemplate restTemplate;
// 注册的DiscoveryClient是个cloud包下的接口类型
@Autowired
private DiscoveryClient discoveryClient;
// 从 注册中心取得user-service的信息
List<ServiceInstance> instanceList = discoveryClient.getInstances("user-service");
// 取第一个 ,现在没有做集群,只有一个
ServiceInstance serviceInstance = instanceList.get(0);
// 获得uri
URI uri = serviceInstance.getUri();
// 拼接方式1
String url = "http://localhost:8081/user/"+id;
// 拼接方式2
url = uri.toString()+"/user/"+id;
// 获取从该url得到的字符串,转化成User对象; 类似于getForEntity();
User user = restTemplate.getForObject(url,User.class);
能取到user,代表consumer-service已经能够正常访问user-service服务了!