Spring-cloud微服务实战【六】:接口服务feign

在上一篇文章中,我们使用了ribbon进行负载均衡,但是仔细思考一下,我们的请求封装和调用以及结果的返回都是我们自己编码完成的,如果需要调用的接口很多,那么无疑开发量是比较大的,那有没有比较好的方式呢?答案就是feign.让我们先通过代码来看一下feign的使用:
首先,我们需要复制一份consumer的代码,并且重命名为dhp-micro-service-consumer-feign:
Spring-cloud微服务实战【六】:接口服务feign_第1张图片

然后修改代码如下:
1.新增maven依赖:
Spring-cloud微服务实战【六】:接口服务feign_第2张图片

2.修改代码:
首先新增一个feign的接口:
Spring-cloud微服务实战【六】:接口服务feign_第3张图片

另外,如果要通过Feign进行远程调用,依然需要安全服务提供方的认证问题,所幸feign里面已经集成了这块功能:
Spring-cloud微服务实战【六】:接口服务feign_第4张图片

此时,准备工作已经做好了,修改controller的代码:
Spring-cloud微服务实战【六】:接口服务feign_第5张图片

然后启动起来试一试:
Spring-cloud微服务实战【六】:接口服务feign_第6张图片
file

说明feign已经继承成功,可以看到,和之前的代码量相比,使用feign之后代码已经简洁许多了,并且如果producer启动了集群,可以发现feign自带负载均衡功能,因为feign也集成了ribbon,我们用两张图来对比一下:
在没有集成feign之前,我们是直接走ribbon:
Spring-cloud微服务实战【六】:接口服务feign_第7张图片

集成feign之后,我们是走feign:
Spring-cloud微服务实战【六】:接口服务feign_第8张图片

我们可以新增ribbon策略试一试:
Spring-cloud微服务实战【六】:接口服务feign_第9张图片

再次启动,会发现负载均衡规则是随机访问了.

数据压缩

我们已经知道,feign最主要的作用就是将Rest服务的信息转化为接口,这其中还有其他的一些地方应该要考虑,比如:数据的压缩.Rest协议更多的传输的是文本,JSON或者XML,如果用户发送的请求很大,这个时候有必要对数据进行压缩处理,feign本身提供了对压缩的支持:
file

介绍完了feign,下一篇文章,我们会介绍服务熔断与降级hystrix,敬请期待.
本文的GitHub地址

本文由博客一文多发平台 OpenWrite 发布!

你可能感兴趣的:(Spring-cloud微服务实战【六】:接口服务feign)