1.1 Feign简介
Feign
是简化
Java HTTP
客户端开发的工具(java-to-httpclient-binder),它的灵感 来自于
Retrofit
、
JAXRS-2.0
和
WebSocket
。
Feign
的初衷是降低统一绑定
Denominator
到 HTTP API的复杂度,不区分是否为
restful
。
1.2 快速体验
我们现在在问答微服务调用基础微服务的方法(根据
ID
查询标签)
(
1
)在
zhao588_qa
模块添加依赖
![](https://i-blog.csdnimg.cn/blog_migrate/c8bee2322f6a751ae49ae20451e55feb.png)
依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
(2)在zhao588_qa模块启动类加注解:
@EnableDiscoveryClient @EnableFeignClients
(3)在zhao588_qa模块创建 com.zhao588.qa.client
包,包下创建接口
/**
* @描述
* @创建人 zhao588
* @创建时间 14:13 2021/11/30
* zhao588-base 另一个模块的项目名称
*/
@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端口服务
多次测试就会发现他们每次请求都会轮流调用。