Feign在RestTemplate的基础上对其封装,由它来帮助我们定义和实现依赖服务接口的定义。Spring Cloud Feign基于Netflix Feign 实现的,整理Spring Cloud Ribbon 与 Spring Cloud Hystrix,并且实现了声明式的Web服务客户端定义方式。
创建子项目
1.在前面的demo中,创建一个新的模块,命名为 eureka-feign-client。将porm.xml改成如下配置:
data:image/s3,"s3://crabby-images/3d09b/3d09b8495e470ab7840d1f69d2b32a5b9875795b" alt=""
修改application.yml的配置,代码如图:
data:image/s3,"s3://crabby-images/ee483/ee4838ebbca7daed3df2a2173fc6d2d491781b07" alt=""
然后在启动类加入注解@EnableFeignClients
data:image/s3,"s3://crabby-images/ab2fd/ab2fdbca78abb568c417bca4ab7e69f45ab80439" alt=""
实现简单Feign Client
新建一个EurekaClientFeign接口,并加上注解@FeignClient 声明该接口为Feign Client,参数value为远程调用client的服务名,编写一个方法sayHiFromClientEureka,该方法通过Feign来调用eureka-client服务“hi”接口,代码如下:
data:image/s3,"s3://crabby-images/4b6b9/4b6b9a9d09616e79c6e64a1f1682ca4ba65f2b01" alt=""
在service层中注入EurekaClientFeign的Bean,通过该bean调用sayHiFromClientEureka(),代码如下:
data:image/s3,"s3://crabby-images/45166/451660c3b4f9e5586bae0ed4ce616161e3c9b6a5" alt=""
在controller下创建一个HiController,加入@RestController注解,写一个方法调用远程服务器,具体如图:
data:image/s3,"s3://crabby-images/13883/13883a43c2f774041aaf61d83c7a8e591151a04b" alt=""
启动eureka-server实例,端口为8761,启动eureka-client两个实例,端口分别为8762和8763,再启动eureka-feign-client,端口为8765.
访问:http://127.0.0.1:8761如图:
data:image/s3,"s3://crabby-images/d231c/d231cfe1a21ece45f9f65dc50b04781088fd5538" alt=""
访问 http://127.0.0.1:8762/hi?name=ggg
data:image/s3,"s3://crabby-images/176e4/176e4d1ff82529b10da982a66e7cfc8e5cf3e57b" alt=""
访问 http://127.0.0.1:8763/hi?name=ggg
data:image/s3,"s3://crabby-images/b8337/b8337767917f332bdec0a5c055ead5abbbd17ab8" alt=""
轮询访问 /http://127.0.0.1:8765/hi?name=ggg,可以看到结果为上面两个结果的循环。
由此可见,feign已经可以实现负载均衡了。
网友评论