Ribbon
Ribbon是一个基于HTTP和TCP的客户端负载均衡器。
Ribbon可以在通过客户端中配置的ribbonServerList服务端列表去轮询访问以达到均衡负载的作用。
1.启动之前的spring-could
2.启动服务提供方spring-cloud-provide
修改spring-cloud-provide中的server-port为2223,再启动一个服务提供方:service
使用Ribbon实现客户端负载均衡的消费者
在pom.xml中添加
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
 | <dependency>        <groupId>org.springframework.cloud</groupId>        <artifactId>spring-cloud-starter-ribbon</artifactId>    </dependency>    <dependency>        <groupId>org.springframework.cloud</groupId>        <artifactId>spring-cloud-starter-eureka</artifactId>    </dependency>    <dependencyManagement>       <dependencies>         <dependency> 	        <groupId>org.springframework.cloud</groupId> 	        <artifactId>spring-cloud-dependencies</artifactId> 	        <version>Brixton.RELEASE</version> 	        <type>pom</type> 	        <scope>import</scope>     	</dependency>     </dependencies> </dependencyManagement>
 | 
在应用主类中,通过@EnableDiscoveryClient注解来添加发现服务能力。
创建RestTemplate实例,并通过@LoadBalanced注解开启均衡负载能力。
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
 | @SpringBootApplication @EnableDiscoveryClient public class RibbonApplication {     @Bean     @LoadBalanced     RestTemplate restTemplate() {         return new RestTemplate();     }     public static void main(String[] args) {         SpringApplication.run(RibbonApplication.class, args);     } }
 | 
创建ConsumerController来消费COMPUTE-SERVICE的add服务。
通过直接RestTemplate来调用服务,计算10 + 20的值。
| 1 2 3 4 5 6 7 8 9 10 11 12
 | @RestController public class ConsumerController {     @Autowired     RestTemplate restTemplate;     @RequestMapping(value = "/add", method = RequestMethod.GET)     public String add() {         return restTemplate.getForEntity("http://COMPUTE-SERVICE/add?a=10&b=20", String.class).getBody();     } }
 | 
application.properties中配置eureka服务注册中心
| 1 2 3 4
 | spring.application.name=ribbon-consumer   server.port=3333 eureka.client.serviceUrl.defaultZone=http://localhost:1111/eureka/
 | 
然后启动该项目,在浏览器中输入http://localhost:3333/add
在2222和2223的端口总能看到有其中一个控制台有日志打出,关闭一个,还能继续运行
即通过ribbon实现了负载均衡了。