SpringCloud系列九:脱离Eureka使用Ribbon

1. 回顾

  在前文的示例中,是将Ribbon与Eureka配合使用的。但是现实中可能不具备这样的条件,例如一些遗留的微服务,它们可能并没有注册到Eureka Server上,

  甚至根本不是使用Spring Cloud开发的,此时要如何使用Ribbon实现负载均衡

2. 脱离Eureka使用Ribbon

  > 复制项目 microservice-consumer-movie-ribbon,将ArtifactId修改为 microservice-consumer-movie-without-eureka

  > 为了更具说服力,将Eureka的依赖替换为Ribbon依赖,即将

<dependency>
   <groupId>org.springframework.cloud</groupId>
   <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>

  替换为

<dependency>
   <groupId>org.springframework.cloud</groupId>
   <artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
</dependency>

  > 去掉启动类上的@EnableDiscoveryClient注解

package com.itmuch.cloud.microserviceconsumermoviewithouteureka;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;

@SpringBootApplication
public class MicroserviceConsumerMovieWithoutEurekaApplication {

    public static void main(String[] args) {
        SpringApplication.run(MicroserviceConsumerMovieWithoutEurekaApplication.class, args);
    }

    @Bean
    @LoadBalanced // 实现负载均衡
    public RestTemplate restTemplate() {
        return new RestTemplate();
    }
}

  > 将application.yml修改如下:

server:
  port: 8010
spring:
  application:
    name: microservice-consumer-movie
microservice-provider-user:
  ribbon:
    listOfServers: localhost:8000,localhost:8001

  其中,属性microservice-provider-user.ribbon.listOfServers用于为名为microservice-provider-user的Ribbon客户端设置请求的地址列表

  > 启动两个以上的 microservice-simple-provider-user 实例

  > 启动 microservice-consumer-without-eureka 

  > 多次访问 http://localhost:8010/log-instance,控制台打印类似如下日志

  由结果可知,尽管电影微服务和用户微服务并没有注册到Eureka上,Ribbon仍可正常工作,请求依旧会分摊到两个用户微服务节点上

3. 总结

  本文讲解了脱离Eureka使用Ribbon的情况。

  下文将讲解使用Feign实现声明式REST调用,敬请期待~~~

 4. 参考

  周立 --- 《Spring Cloud与Docker微服务架构与实战》

原文地址:https://www.cnblogs.com/jinjiyese153/p/8657717.html