org.springframework.cloud spring-cloud-starter-openfeign
(2)在zhao588_qa模块启动类加注解:
@EnableDiscoveryClient @EnableFeignClients(3)在zhao588_qa模块创建 com.zhao588.qa.client 包,包下创建接口
@FeignClient("zhao588-base")
public interface baseClient {
@RequestMapping(value = "/label/{id}",method = RequestMethod.GET)
public Result findById(@PathVariable("id") String id);
}
@FeignClient
注解用于指定从哪个服务中调用功能 ,注意 里面的名称与被调用的服务
名保持一致,并且不能包含下划线。
@RequestMapping
注解用于对被调用的微服务进行地址映射。注意
@PathVariable
注
解一定要指定参数名称,否则出错
(5) 修改zhao588_qa模块的 ProblemController
@Autowired
private baseClient baseClient;//报红线不用管,idea版本造成的,不影响。
@RequestMapping(value = "/label/{id}",method = RequestMethod.GET)
public Result findByLabelId(@PathVariable String id){
Result result = baseClient.findById(id);
return result;
}
(6)测试(先启动zhao588_eureka,zhao588_qa,zhao588_base)
2.1 负载均衡通过一个服务调用多个服务,测试:同时开启多个基础微服务,看是否是轮流调用。
(1)首先启动zhao588_eureka被调用服务
(2)修改zhao588_base服务端口多次启动
a,修改端口:9101
接口
启动
b,修改端口:9201
接口
启动
(3) 启动zhao588_qa调用服务
(4)测试
第一次刷新:http://localhost:9003/problem/label/1451434101826523136
结果:发现走的9201端口服务
第二次刷新:http://localhost:9003/problem/label/1451434101826523136
结果:发现走的9101端口服务
第三次刷新:http://localhost:9003/problem/label/1451434101826523136
结果:发现走的9101端口服务
多次测试就会发现他们每次请求都会轮流调用。



