温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

springCloud入门学习(八):脱离Eureka使用Ribbon

发布时间:2020-08-02 08:03:06 来源:网络 阅读:569 作者:樱桃mayue 栏目:编程语言

在之前的实验中都是通过Eureka和Ribbon结合使用的,但是现实中可能不具备这样的条件。例如有些服务没有注册到注册中心,但此时需要负载均衡到该服务,所以需要一种脱离Eureka使用Ribbon。


修改movie:

1、去掉pom文件中的Eureka依赖

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

这个包其实包含ribbon相关包,由于之前的负载均衡都是基于Eureka的,所以无需单独引入Ribbon相关包。现在把这个依赖去掉并且单独引入ribbon包。

2、加入Ribbon包

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

3、修改启动类,去掉 @EnableEurekaClient  注解

@SpringBootApplication
//@EnableEurekaClient
public class MovieApplication {

    @Bean
    @LoadBalanced
    public RestTemplate restTemplate() {
        return new RestTemplate();
    }

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

}

4、了解到,ribbon和Eureka结合使用时,从Eureka获取服务提供者的服务端口及IP来调用服务,现在脱离Eureka后无法获取服务提供者的访问地址,因此需要在movie中指定服务调用者的端口及ip,修改yml文件:

user:
  ribbon:
    listOfServers: localhost:8010,localhost:8011

调用格式:<clientName.ribbon.listOfServers>,可以配置多个实例地址,通过“,”分隔


启动movie,并且启动多个user实例,访问http://localhost:8020/movie/findById?userId=1

可以获得结果。在观察user的控制台:

springCloud入门学习(八):脱离Eureka使用Ribbon

springCloud入门学习(八):脱离Eureka使用Ribbon

可见请求已经分摊到两个实例中,实现了负载均衡

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI