【前面的话】书接上文,本文的某些知识依赖我的上一篇文章:SpringCloud之Eureka,如果没有看过可以先移步去看一下。另外在微服务架构中,业务都会被拆分成一个个独立的服务,服务与服务的通讯是基于http restful的。Spring cloud有两种服务调用方式,一种是ribbon+restTemplate,另一种是feign。在这一篇文章首先讲解下基于ribbon+rest。
壹、Ribbon简介
ribbon是一个负载均衡客户端,可以很好的控制htt和tcp的一些行为。Feign默认集成了ribbon。
ribbon 已经默认实现了这些配置bean:
1 |
|
贰、准备工作
- 新建一个ribbon子工程lovin-ribbon-client,用于后面的操作。下面是主要的pom依赖
1 | <parent> |
- 这里为了安全,我这里还是添加spring-boot-starter-security
1 | server: |
- 配置spring-boot-starter-security,这里为了方便我这里放开所有请求
1 | package com.eelve.lovin.cofig; |
- 然后向程序的ioc容器中注入一个bean: restTemplate;并通过@LoadBalanced注解表明这个restRemplate开启负载均衡的功能。
1 | package com.eelve.lovin; |
- 然后编写一个HelloService
1 | package com.eelve.lovin.service; |
- 再编写一个HelloController
1 | package com.eelve.lovin.controller; |
叁、启动测试
- 依次启动eureka的服务端和两个客户端,以及新建的lovin-ribbon-client
我们可以看到服务已经全部启动成功
我们可以看到已经可以通过ribbon调到我们建立的eureka客户端了
- 再次请求接口观察返回
我们可以看到我们调到了通过ribbon负载的另外一个接口了,到这里我们就已经弄好了一个简单的ribbon负载。
肆、网络架构
- 我们可以看到我们调用的服务不再是像再上一篇文章中的直接访问对应的服务,而是通过Ribbon的负载均衡的去调用的,而且这里说明一点,Ribbon的默认机制是轮询。