Feign是简化Java HTTP客户端开发的工具(java-to-httpclient-binder),它的灵感来自于Retrofit、JAXRS-2.0和WebSocket。Feign的初衷是降低统一绑定Denominator到HTTP API的复杂度,不区分是否为restful。
现在在溝通微服务调用基础微服务的方法(根据ID查询标签)
(1)在gy模块添加依赖
<!--将gy注册成eureka客户端 -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<!-- 你去掉别人别人不用动,需要在自己这里倒openfeign的依赖-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
2)修改gy模块的启动类,添加注解
@SpringBootApplication
@EnableEurekaClient
@EnableFeignClients //采用feign的方式去发现服务
@EnableDiscoveryClient //发现服务
(3)在gy模块创建 client包,包下创建接口
@FeignClient("tensquare-base")
public interface BaseClient { //调用别人在自己这里创建接口
//调用哪个接口就把哪个接口拿过来
@RequestMapping(value = "/label/{labelId}",method= RequestMethod.GET)
public Result findById(@PathVariable("labelId") String labelId);
}
@FeignClient注解用于指定从哪个服务中调用功能 ,注意 里面的名称与被调用的服务名保持一致,并且不能包含下划线。 @RequestMapping注解用于对被调用的微服务进行地址映射。注意 @PathVariable注解一定要指定参数名称,否则出错
(5)修改gy模块的 ProblemController
@Autowired
private HttpServletRequest request;
@Autowired
private BaseClient baseClient;
@RequestMapping(value = "/label/{labelId}",method= RequestMethod.GET)
public Result findByLabelId(@PathVariable String labelId){
Result result = baseClient.findById(labelId);
return result;
}
测试 能看到标签的信息
负载均衡
测试:同时开启多个基础微服务,看是否是轮流调用
修改base工程LabelController的findById方法
@RequestMapping(value = "/{labelId}",method= RequestMethod.GET)
public Result findById(@PathVariable("labelId") String labelId){
System.out.println("2222222");
int i = 1/0;
return new Result(true, StatusCode.OK,"查询成功",labelService.findById(labelId));
}
启动基础微服务后,修改端口和输出信息,依次启动基础微服务
启动沟通微服务,浏览器执行 看是否轮流启动。