• UID20908
  • 登录2018-01-22
  • 粉丝1
  • 关注0
  • 发帖42
  • 主页
  • 金币162枚
qq_h3tGVhZ15113 发布于2017-12-11 10:16
1/68

Spring Cloud构建微服务架构服务消费Ribbon

楼层直达


Spring Cloud Ribbon

Spring Cloud Ribbon是基于Netflix Ribbon实现的一套客户端负载均衡的工具。它是一个基于HTTP和TCP的客户端负载均衡器。它可以通过在客户端中配置ribbonServerList来设置服务端列表去轮询访问以达到均衡负载的作用。
当Ribbon与Eureka联合使用时,ribbonServerList会被DiscoveryEnabledNIWSServerList重写,扩展成从Eureka注册中心中获取服务实例列表。同时它也会用NIWSDiscoveryPing来取代IPing,它将职责委托给Eureka来确定服务端是否已经启动。
而当Ribbon与Consul联合使用时,ribbonServerList会被ConsulServerList来扩展成从Consul获取服务实例列表。同时由ConsulPing来作为IPing接口的实现。
我们在使用Spring Cloud Ribbon的时候,不论是与Eureka还是Consul结合,都会在引入Spring Cloud Eureka或Spring Cloud Consul依赖的时候通过自动化配置来加载上述所说的配置内容,所以我们可以快速在Spring Cloud中实现服务间调用的负载均衡。
下面我们通过具体的例子来看看如何使用Spring Cloud Ribbon来实现服务的调用以及客户端均衡负载。
我们将利用之前构建的eureka-server作为服务注册中心、eureka-client作为服务提供者作为基础。而基于Spring Cloud Ribbon实现的消费者,我们可以根据eureka-consumer实现的内容进行简单改在就能完成,具体步骤如下:
  • 根据eureka-consumer复制一个服务消费者工程,命名为:eureka-consumer-ribbon。在pom.xml中增加下面的依赖:



<<span class="name" style="box-sizing: border-box; margin: 0px; padding: 0px; font-weight: inherit; border: 0px; font-style: inherit; font-family: inherit; vertical-align: baseline; color: rgb(38, 139, 210);">dependencies>
...
<<span class="name" style="box-sizing: border-box; margin: 0px; padding: 0px; font-weight: inherit; border: 0px; font-style: inherit; font-family: inherit; vertical-align: baseline; color: rgb(38, 139, 210);">dependency>
<<span class="name" style="box-sizing: border-box; margin: 0px; padding: 0px; font-weight: inherit; border: 0px; font-style: inherit; font-family: inherit; vertical-align: baseline; color: rgb(38, 139, 210);">groupId>org.springframework.cloud</<span class="name" style="box-sizing: border-box; margin: 0px; padding: 0px; font-weight: inherit; border: 0px; font-style: inherit; font-family: inherit; vertical-align: baseline; color: rgb(38, 139, 210);">groupId>
<<span class="name" style="box-sizing: border-box; margin: 0px; padding: 0px; font-weight: inherit; border: 0px; font-style: inherit; font-family: inherit; vertical-align: baseline; color: rgb(38, 139, 210);">artifactId>spring-cloud-starter-ribbon</<span class="name" style="box-sizing: border-box; margin: 0px; padding: 0px; font-weight: inherit; border: 0px; font-style: inherit; font-family: inherit; vertical-align: baseline; color: rgb(38, 139, 210);">artifactId>
</<span class="name" style="box-sizing: border-box; margin: 0px; padding: 0px; font-weight: inherit; border: 0px; font-style: inherit; font-family: inherit; vertical-align: baseline; color: rgb(38, 139, 210);">dependency>
</<span class="name" style="box-sizing: border-box; margin: 0px; padding: 0px; font-weight: inherit; border: 0px; font-style: inherit; font-family: inherit; vertical-align: baseline; color: rgb(38, 139, 210);">dependencies>
  • 修改应用主类。为RestTemplate增加@LoadBalanced注解:



@EnableDiscoveryClient
@SpringBootApplication
public class Application {
 
@Bean
@LoadBalanced
public RestTemplate restTemplate() {
return new RestTemplate();
}
 
public static void main(String[] args) {
new SpringApplicationBuilder(Application.class).web(true).run(args);
}
}
  • 修改Controller。去掉原来通过LoadBalancerClient选取实例和拼接URL的步骤,直接通过RestTemplate发起请求。



@RestController
public class DcController {
 
@Autowired
RestTemplate restTemplate;
 
@GetMapping("/consumer")
public String dc() {
return restTemplate.getForObject( String.class);
}
 
}
可以看到这里,我们除了去掉了原来与LoadBalancerClient相关的逻辑之外,对于RestTemplate的使用,我们的第一个url参数有一些特别。这里请求的host位置并没有使用一个具体的IP地址和端口的形式,而是采用了服务名的方式组成。那么这样的请求为什么可以调用成功呢?因为Spring Cloud Ribbon有一个拦截器,它能够在这里进行实际调用的时候,自动的去选取服务实例,并将实际要请求的IP地址和端口替换这里的服务名,从而完成服务接口的调用。


从现在开始,我这边会将近期研发的springcloud微服务云架构的搭建过程和精髓记录下来,帮助更多有兴趣研发spring cloud框架的朋友,希望可以帮助更多的好学者。大家来一起探讨spring cloud架构的搭建过程及如何运用于企业项目。源码来源

0人打赏
  • UID20908
  • 登录2018-01-22
  • 粉丝1
  • 关注0
  • 发帖42
  • 主页
  • 金币162枚
qq_h3tGVhZ15113 发布于2017-12-11 10:17
沙发F
喜欢文章的可以持续关注更新哦...
您需要登录后才可以回帖
发表回复
极贡献
技术问答
专题荟萃
程序人生
视觉设计
Android开发
iOS开发
编程语言
前端开发
后端开发
服务器架构
软件测试
运维方案
创业路上



最热文章墙

  • 83267/382   【精品推荐】200多种Android动画效果的强悍框架,太全了,不看这个,再有动画的问题,不理你了^@^

  • 47313/191   情人节福利,程序员表白的正确姿势:改几行代码就变成自己的表白了

  • 46315/0   Python爬虫:常用浏览器的useragent

  • 43248/261   【精品推荐】Android版产品级的音乐播放器源码,功能太强大了,最好的产品原型有木有?

  • 39879/145   省时省力的Android组件群来了,非常棒的原型参考

  • 31521/143   2016抢红包软件及源码

  • 30099/71   原创表白APP,以程序员的姿势备战新年后的7夕,持续完善中!

  • 29649/2   超全!整理常用的iOS第三方资源

  • 25632/161   Android版类似UC浏览器:非常赞,产品级的源码

  • 23382/31   麻省理工的一帮疯子,真的实现了随意操控万物!(绝对黑科技)

  • 23080/27   2016程序员跳槽全攻略

  • 23075/26   Android工程师面试题大全

  • 22289/10   GitHub上排名前50的iOS项目:总有一款你用得着

  • 21370/21   码魂:程序员的牛B漫画

  • 19856/74   【持续更新中】Android福利贴(二):资料源码大放送

  • 19735/85   Android小而全的博客源码:非常适合全面掌握开发技巧

  • 19566/43   一个绚丽的loading动效分析与实现!

  • 19273/10   2016年最全的Android面试考题+答案 精编版

  • 19139/3   吐槽那些程序员的搞笑牛逼注释

  • 18391/104   Android带弹幕的视频播放器源码,来自大名鼎鼎的Bilibili弹幕网站

  • 18310/45   惊艳的App引导页:背景图片切换加各个页面动画效果

  • 18242/82   仿京东商城客户端Android最新版,不错的原型和学习资料

  • 17965/1   iOS 动画总结

  • 17765/25   个人收集的Android 各类功能源代码

  • 17374/23   Android福利第三波【Android电子书】

  • 17243/5   新一代Android渠道打包工具:1000个渠道包只需要5秒

  • 17232/81   【精品推荐】类似360安全卫士安Android源码:非常赞的产品原型

  • 17127/1   iOS中文版资源库,非常全

  • 17032/54   基于瀑布流的美女图片浏览App,有注释的源代码

  • 16794/18   用JavaScript 来开发iOS和Android 原生应用:React Native开源框架中文版来啦

  • 16686/10   女程序员的梦,众网友的神回复

  • 16596/23   珍藏多年的素材,灵感搜寻网站

  • 16446/11   年会上现场review代码是怎么样的体验!

  • 16353/19   65条最常用正则表达式,你要的都在这里了

  • 15228/16   基于Android支付宝支付设计和开发方案

  • 14858/18   什么是真正的黑客:收获12200+Stars,人气远超微软开源VS

  • 14703/11   有木有这样一张酷图帮你集齐所有git命令超实用

  • 14618/4   46 个非常有用的 PHP 代码片段

  • 14494/47   在线音乐播放器完整版(商用级的源码):非常赞,可听免费高品质专辑

  • 14488/62   【技巧一】搭配Android Studio,如何实现App远程真机debug?

  • 14030/0   GitHub iOS 库和框架Top100 

  • 13869/7   用程序员的姿势抢过年的火车票

  • 13844/7   一张图搞定iOS学习路线,非常全面

  • 13479/10   成为Java顶尖程序员 ,看这11本书就够了

  • 13412/10   微信支付终于成功了(安卓,iOS),在此分享

  • 13335/18   一张图搞定Android学习路线,非常全面

  • 13227/29   【持续更新中】Android福利贴(一):资料源码

  • 13090/4   基于Node.js的强大爬虫,能直接发布抓取的文章哦

  • 12359/3   即时通信第三方库

  • 11827/9   流媒体视频直播方案

  • 11777/18   八个最优秀的Android Studio插件

  • 11665/1   基于node-webkit跨平台应用案例集之(一)

  • 11607/9   B站建开源工作组:APP想支持炫酷弹幕的看过来

  • 11474/2   【精品推荐】高质量PHP代码的50个实用技巧:非常值得收藏

  • 11313/9   烧了5亿美金,这家神秘的公司即将颠覆人类未来!

  • 11276/12   中国黑客的隐秘江湖:攻守对立,顶尖高手月入千万美元

  • 10517/6   开箱即用!Android四款系统架构工具

  • 10373/2   Android性能优化视频,文档以及工具

  • 10330/11   十大技巧快速提升Android应用开发性能

  • 10325/4   10款GitHub上最火爆的国产开源项目——可以媲美西半球

  • 返回顶部