必威体育Betway必威体育官网
当前位置:首页 > IT技术

快速搭建 Spring Cloud Ribbon

时间:2019-10-03 07:44:36来源:IT技术作者:seo实验室小编阅读:66次「手机版」
 

ribbon

Spring Cloud Ribbon 是一个基于HTTP和TCP的客户端负载均衡工具,它基于Netflix Ribbon实现。通过 Spring Cloud 的封装, 可以让我们轻松地将面向服务的 REST 模板请求自动转换成客户端负载均衡的服务调用。在微服务架构中,业务都会被拆分成一个独立的服务,服务与服务的通讯是基于http restful的。Spring cloud有两种服务调用方式,一种是ribbon+restTemplate,另一种是feign

一般说的 负载均衡 是指 服务器端的负载均衡硬件负载均衡、软件负载均衡)

这里写图片描述

客户端负载均衡服务端负载均衡 最大的不同点在上面所提到的 服务清单所存储的位置。 在客户端负载均衡中,所有客户端节点都维护着自己要访问的服务端清单 而这些服务端的清单来自于服务注册中心(Eureka服务端)。

同服务端负载均衡的架构类似, 在客户端负载均衡中也需要心跳去维护服务端清单的健康性, 只是这个步骤需要与服务注册中心配合完成。

在Spring Cloud中我们如果想要使用客户端负载均衡,方法很简单,开启 @LoadBalanced 注解即可,这样客户端在发起请求的时候会先自行选择一个服务端,向该服务端发起请求,从而实现负载均衡。

这里写图片描述

——注册中心是高可用注册中心,两个Eureka Server相互注册;

——服务提供方即Eureka Client左右各一个实例各注册一个注册中心(因为高可用,所以在注册中心都会有这两个提供方即服务实例);

——服务消费者是Ribbon+restTemplate即是加了负载均衡的客户端,用restTemplate向服务器获取服务列表,ribbon默认是按轮询方式取得服务实例从而调用服务。

++++++++++++++++++++++++++++++++++++BEGIN+++++++++++++++++++++++++++++++++++++++++++

搭建 Ribbon

1、在上一篇 Spring Cloud Eureka 搭建的基础上继续新建 Model ,同 新建Eureka Client Model:右键 ->New -Model -> Spring Initializr -> Next -> Next ->Cloud Discovery -> Eureka Discovery-> Next ->Finish

2、pom文件增加:

<parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.0.3.RElease</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
        <spring-cloud.version>Finchley.RELEASE</spring-cloud.version>
    </properties>

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

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-web</artifactId>
            <version>5.0.2.RELEASE</version>
        </dependency>
    </dependencies>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

3、在 RibbonAPPlication应用程序中加注解和bean并开启restTemplate负载均衡:

这里写图片描述

4、新建 HelloService和Hellocontroller类作为测试:

这里写图片描述

这里写图片描述

5、appliation.yml



server:
   port: 3333

spring:
  application:
    name: service-ribbon

eureka:
  client:
    service-url:
        defaultZone: http://peer1:1122/eureka/
#      这里写一个都行,因为 Eureka Server 是相互注册,高可用注册中心

6、!启动 两个Eureka Server注册中心(active 另一个yml文件);

! 启动两个 Eureka Client 客户端(就是换一个端口){要在run配置那里把那个 Single instance only 的 √ 去掉};

! 再启动 Ribbon

浏览器输入:peer1:1122 ,peer2:1133 , localhost:3333

这里写图片描述

这里写图片描述

这里写图片描述

这里写图片描述

++++++++++++++++++++++++++++++++++++++++OVER++++++++++++++++++++++++++++++++++++

相关阅读

springbatch 批处理框架的介绍

springbatch 批处理框架整理 (还在整理中。。。。。。。。有点乱,待更新)Spring Batch 是什么? 官网中介绍 Spring Batch is a light

SpringData @Modifying注解和事务(五)

第一种方式我们可以利用Repository提供的子接口来进行添加,删除和修改。第二种方式我们可以使用定制化JPQL的方式来实现删除和修改

Spring事务管理之回滚异常rollback-for

一、业务背景业务需求:服务层调用多个dao方法,要求只要有一条数据库执行语句出错,则全部回滚。而实际情况是前面四条执行成功,第五条

spring data jpa-由mybatis切换

最近重构以前写的服务,最大的一个变动是将mybatis切换为spring data jpa,切换的原因很简单,有两点:第一、它是spring的子项目能够和sp

转-Spring的多事务配置(多个Transaction Manager)和使用

转自:http://blog.csdn.net/clementad/article/details/47275227 大多数项目只需要一个事务管理器。然而,有些项目为了提高效率、或

分享到:

栏目导航

推荐阅读

热门阅读