目录:

Ribbon负载均衡
Feign简介及应用

Ribbon负载均衡

Ribbon是Netflix发布的负载均衡器,它有助于控制HTTP和TCP的客户端的行为。为Ribbon配置服务提供者地址后,Ribbon就可基于某种负载均衡算法,自动地帮助服务消费者去请求。Ribbon默认为我们提供了很多负载均衡算法,例如轮询、随机等。当然,我们也可为Ribbon实现自定义的负载均衡算法。
在Spring Cloud中,当Ribbon与Eureka配合使用时,Ribbon可自动从Eureka Server获取服务提供者地址列表,并基于负载均衡算法,请求其中一个服务提供者实例。展示了Ribbon与Eureka配合使用时的架构。
Ribbon是客户端负载均衡,所以肯定集成再消费端,也就是consumer端

所以我们先要修改microservice-student-consumer-80

pom依赖

<!--ribbon相关依赖-->
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-eureka</artifactId>
</dependency>
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-ribbon</artifactId>
</dependency>
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-config</artifactId>
</dependency>

然后在application.yml中加上Eureka的配置


server:port: 80context-path: /
eureka:client:service-url:defaultZone: http://eureka2001.liuxia.com:2001/eureka/,http://eureka2002.liuxia.com:2002/eureka/,http://eureka2003.liuxia.com:2003/eureka/register-with-eureka: false

然后在SpringCloudConfig配置类中加上注解

package com.liuxia.microservicestudentconsumer80.config;import com.netflix.loadbalancer.IRule;
import com.netflix.loadbalancer.RetryRule;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.client.RestTemplate;@Configuration
public class SpringCloudConfig {@LoadBalanced  // 引入ribbon负载均衡@Beanpublic RestTemplate getRestTemplate() {return new RestTemplate();}/*** 自定义轮询算法* @return*/@Beanpublic IRule myRule(){return new RetryRule();}
}

这是和Eureka整合,所以在启动类还需要加上一个注解
@EnableEurekaClient

然后我们再把controller里面的请求地址改成Eureka注册中心的名称就可以了


private final static String SERVER_IP_PORT = "http://MICROSERVICE-STUDENT";

然后正常访问地址localhost/student/list一样能访问到数据加上成功了

前面搭建了初步例子,但是还没实现真正负载均衡,我们这里要先搞三个服务提供者集群,然后才能演示负载均衡,以及负载均衡策略;

然后我们再新建项目microservice-student-provider-1002,microservice-student-provider-1003,pom和其他文件都一样,只要改不同的端口即可
我这里为了方便,直接才用了一个项目复制2个启动文件就好了,主要再yml文件中配置好


---
server:port: 1001context-path: /
spring:datasource:type: com.alibaba.druid.pool.DruidDataSourcedriver-class-name: com.mysql.jdbc.Driverurl: jdbc:mysql://localhost:3306/t226_layui?useUnicode=true&characterEncoding=utf8username: rootpassword: 123jpa:hibernate:ddl-auto: updateshow-sql: trueapplication:name: microservice-studentprofiles: provider-1001eureka:instance:hostname: localhostappname: microservice-studentinstance-id: microservice-student:1001prefer-ip-address: trueclient:service-url:defaultZone: http://eureka2001.liuxia.com:2001/eureka/,http://eureka2002.liuxia.com:2002/eureka/,http://eureka2003.liuxia.com:2003/eureka/info:groupId: com.liuxia.testSpringcloudartifactId: microservice-student-provider-1001version: 1.0-SNAPSHOTuserName: http://liuxia.comphone: 123456---
server:port: 1002context-path: /
spring:datasource:type: com.alibaba.druid.pool.DruidDataSourcedriver-class-name: com.mysql.jdbc.Driverurl: jdbc:mysql://localhost:3306/t226_layui?useUnicode=true&characterEncoding=utf8username: rootpassword: 123jpa:hibernate:ddl-auto: updateshow-sql: trueapplication:name: microservice-studentprofiles: provider-1002eureka:instance:hostname: localhostappname: microservice-studentinstance-id: microservice-student:1002prefer-ip-address: trueclient:service-url:defaultZone: http://eureka2001.liuxia.com:2001/eureka/,http://eureka2002.liuxia.com:2002/eureka/,http://eureka2003.liuxia.com:2003/eureka/info:groupId: com.liuxia.testSpringcloudartifactId: microservice-student-provider-1002version: 1.0-SNAPSHOTuserName: http://liuxia.comphone: 123456---
server:port: 1003context-path: /
spring:datasource:type: com.alibaba.druid.pool.DruidDataSourcedriver-class-name: com.mysql.jdbc.Driverurl: jdbc:mysql://localhost:3306/t226_layui?useUnicode=true&characterEncoding=utf8username: rootpassword: 123jpa:hibernate:ddl-auto: updateshow-sql: trueapplication:name: microservice-studentprofiles: provider-1003eureka:instance:hostname: localhostappname: microservice-studentinstance-id: microservice-student:1003prefer-ip-address: trueclient:service-url:defaultZone: http://eureka2001.liuxia.com:2001/eureka/,http://eureka2002.liuxia.com:2002/eureka/,http://eureka2003.liuxia.com:2003/eureka/info:groupId: com.liuxia.testSpringcloudartifactId: microservice-student-provider-1003version: 1.0-SNAPSHOTuserName: http://liuxia.comphone: 123456

pom依赖


<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>com.liuxia</groupId><artifactId>t226_microservice</artifactId><version>1.0-SNAPSHOT</version></parent><artifactId>microservice-student-provider</artifactId><properties><java.version>1.8</java.version></properties><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-jpa</artifactId></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-tomcat</artifactId></dependency><dependency><groupId>com.alibaba</groupId><artifactId>druid-spring-boot-starter</artifactId></dependency><!--  修改后立即生效,热部署  --><dependency><groupId>org.springframework</groupId><artifactId>springloaded</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-devtools</artifactId></dependency><!--添加注册中心Eureka相关配置--><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-eureka</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-config</artifactId></dependency><!-- actuator监控引入 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-actuator</artifactId></dependency><dependency><groupId>com.liuxia</groupId><artifactId>microservice-common</artifactId><version>1.0-SNAPSHOT</version><scope>compile</scope></dependency><!-- actuator监控引入 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-actuator</artifactId></dependency></dependencies><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build></project>

然后在消费者microservice-student-consumer-80的controller中加上测试方法

    @RequestMapping("/ribbon")public String ribbon() {return restTemplate.getForObject(SERVER_IP_PORT + "/student/ribbon", String.class);}

生产者microservice-student-providerr的StudentProviderController中加上测试方式(如果创建了3个项目,那么在3个都要加上)

@Value("${server.port}")private String port;@RequestMapping("/ribbon")public String ribbon(){return "工号【"+port+"】正在为您服务";}

然后我们可以在页面的请求看到,我们每次刷新请求都回换一个端口,说明它的默认规则是轮回算法


但是当我们有一个服务器宕机了,当轮回到这个服务器时,它不会自动帮我们跳过(好像有新版本已经解决这个问题了),而是会出现404,所以这就需要我们更改它的默认算法
我们在SpringCloudConfig中加一个配置即可

    /*** 自定义轮询算法* @return*/@Beanpublic IRule myRule(){return new RetryRule();}

Feign简介及应用

Feign是一个声明式的Web Service客户端,它使得编写Web Serivce客户端变得更加简单。我们只需要使用Feign来创建一个接口并用注解来配置它既可完成。它具备可插拔的注解支持,包括Feign注解和JAX-RS注解。Feign也支持可插拔的编码器和解码器。Spring Cloud为Feign增加了对Spring MVC注解的支持,还整合了Ribbon和Eureka来提供均衡负载的HTTP客户端实现。
这段话看起来比较懵逼,这里说下实际使用,前面Ribbon调用服务提供者,我们通过restTemplate调用,缺点是,多个地方调用,同一个请求要写多次,不方便统一维护,这时候Feign来了,就直接把请求统一搞一个service作为FeignClient,然后其他调用Controller需要用到的,直接注入service,直接调用service方法即可;同时Feign整合了Ribbon和Eureka,所以要配置负载均衡的话,直接配置Ribbon即可,无其他特殊地方;当然Fiegn也整合了服务容错保护,断路器Hystrix,后面再说。

也就是把我们共同代码抽取出来,放入common公共部分中去,让维护更加方便

<!--引入Feign依赖-->
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-feign</artifactId>
</dependency>

我们在microservice-common这个项目新建一个StudentClienService,提取公共的请求代码


package com.liuxia.microservicecommon.service;import com.liuxia.microservicecommon.entity.Student;
import org.springframework.cloud.netflix.feign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;import java.util.List;/*** Student Feign接口客户端* @author Administrator**/
@FeignClient(value="MICROSERVICE-STUDENT")
public interface StudentClientService {/*** 根据id查询学生信息* @param id* @return*/@GetMapping(value="/student/get/{id}")public Student get(@PathVariable("id") Integer id);/*** 查询学生信息* @return*/@GetMapping(value="/student/list")public List<Student> list();/*** 添加或者修改学生信息* @param student* @return*/@PostMapping(value="/student/save")public boolean save(Student student);/*** 根据id删除学生信息* @return*/@GetMapping(value="/student/delete/{id}")public boolean delete(@PathVariable("id") Integer id);@RequestMapping("/student/ribbon")public String ribbon();
}

StudentServiceImpl

package com.liuxia.microservicestudentprovider.service.impl;import com.liuxia.microservicecommon.entity.Student;
import com.liuxia.microservicestudentprovider.repository.StudentRepository;
import com.liuxia.microservicestudentprovider.service.StudentService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;import java.util.List;@Service
public class StudentServiceImpl implements StudentService {@Autowiredprivate StudentRepository studentRepository;@Overridepublic void save(Student student) {studentRepository.save(student);}@Overridepublic Student findById(Integer id) {return studentRepository.findOne(id);}@Overridepublic List<Student> list() {return studentRepository.findAll();}@Overridepublic void delete(Integer id) {studentRepository.delete(id);}}

然后我们可以新建另外一个项目microservice-student-consumer-feign-80来,代码全部复制一遍,然后再加东西,也可以再原来基础上改就好了
需要引入的pom

<!--ribbon相关依赖--><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-eureka</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-ribbon</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-config</artifactId></dependency><!--引入Feign依赖--><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-feign</artifactId></dependency>

StudentConsumerController,这个就是需要改动的,把我们映射请求的已经移到了common里面,所以我们需要加一个方法来请求我们的通用部分

package com.liuxia.microservicestudentconsumerfeign80.controller;import com.liuxia.microservicecommon.entity.Student;
import com.liuxia.microservicecommon.service.StudentClientService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.client.RestTemplate;import java.util.List;@RestController
@RequestMapping("/student")
public class StudentConsumerController {@Autowiredprivate StudentClientService studentClientService;@Autowiredprivate RestTemplate restTemplate;@PostMapping(value = "/save")private boolean save(Student student) {return studentClientService.save(student);}@GetMapping(value = "/list")public List<Student> list() {return studentClientService.list();}@GetMapping(value = "/get/{id}")public Student get(@PathVariable("id") Integer id) {return studentClientService.get(id);}@GetMapping(value = "/delete/{id}")public boolean delete(@PathVariable("id") Integer id) {try {studentClientService.delete(id);return true;} catch (Exception e) {return false;}}@RequestMapping("/ribbon")public String ribbon(){return studentClientService.ribbon();}
}

启动类也要加上注解

package com.liuxia.microservicestudentconsumerfeign80;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration;
import org.springframework.boot.autoconfigure.orm.jpa.HibernateJpaAutoConfiguration;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.cloud.netflix.feign.EnableFeignClients;@EnableEurekaClient
@EnableFeignClients(value = "com.liuxia.*.*")
@SpringBootApplication(exclude={DataSourceAutoConfiguration.class, HibernateJpaAutoConfiguration.class})
public class MicroserviceStudentConsumerFeign80Application {public static void main(String[] args) {SpringApplication.run(MicroserviceStudentConsumerFeign80Application.class, args);}}

然后这样就算我们生产者集群有一个服务器宕机了,当Ribbon在轮回的时候就会自动跳过它这个服务器了,让拿两个继续运行

微服务调用Ribbon负载均衡、Feign的使用相关推荐

  1. 最新版Spring Cloud Alibaba微服务架构-Ribbon负载均衡篇

    文章目录 前言 一.Ribbon核心概念 二.服务器端负载均衡和Riboon客户端负载均衡 1.服务器端负载均衡: 2.Riboon客户端负载均衡: 三.Ribbon策略 四.Ribbon配置使用 五 ...

  2. SpringCloud微服务:Ribbon和Feign组件,实现服务调用的负载均衡

    一.Ribbon简介 1.基本概念 Ribbon是一个客户端的负载均衡(Load Balancer,简称LB)器,它提供对大量的HTTP和TCP客户端的访问控制. 2.负载均衡简介 目前主流的负载均衡 ...

  3. SpringCloud Feign 源码底层如何调用Ribbon实现服务调用的负载均衡

    在SpringCloud微服务中调用都不是直接用Ribbon进行服务调用,因为那样的化项目中的代码量会增加很多,微服务之间的调用是用Feign来进行调用,下面就是普通的一个接口调用例子 这样就可以进行 ...

  4. spring cloud 微服务调用--ribbon和feign调用

    这里介绍ribbon和feign调用两种通信服务调用方式,同时介绍如何引入第三方服务调用.案例包括了ribbon负载均衡和hystrix熔断--服务降级的处理,以及feign声明式服务调用.例子包括s ...

  5. 架构之美【kubernetes、Prometheus、微服务、LVS负载均衡】

                                                    kubernetes        kubernetes,简称K8s,是用8代替8个字符"ub ...

  6. 关于微服务下的负载均衡

    1.什么是负载均衡 在高并发的访问下,单一服务器性能不足以满足正常需求,我们往往会引入分布式集群服务器来提高服务质量,提高网站整体性能.那么,这时一个请求到这个服务,就需要确定访问哪一个服务器.在服务 ...

  7. Java 微服务中的负载均衡

    1.什么是负载均衡 2.注册多个服务 2.1 向注册中心注册多个服务 2.2 通过服务ID找到服务 2.2.1. DiscoveryClient 解读 2.2.2. 使用DiscoveryClient ...

  8. 微服务调用异常:error feign.RetryableException: Read timed out executing POST http://xxx.......

    最近在将nacos server版本从1.3版本升级到1.4版本,接口服务调用基础的搜索服务时出现以上异常.因为是时而正常,时而超时,推测是注册客户端的版本过低,于是升级Nacos client版本, ...

  9. Ribbon负载均衡及Feign消费者调用服务

    Ribbon负载均衡及Feign消费者调用服务 微服务调用Ribbon 简介 前面讲了eureka服务注册与发现,但是结合eureka集群的服务调用没讲. 这里的话 就要用到Ribbon,结合eure ...

  10. SpringCloud微服务-服务注册发现-负载均衡-服务调用-服务降级-服务网关-配置中心-消息总线-消息驱动-链路追踪-alibaba-nacos-sentinel-seata理论原理分析

    SpringCloud理论技术 概述 ​ Spring Cloud是一系列框架的有序集合.它利用Spring Boot的开发便利性巧妙地简化了分布式系统基础设施的开发,如服务发现注册.配置中心.消息总 ...

最新文章

  1. keepalived+nginx负载均衡+ApacheWeb实现高可用
  2. 关于子元素的margin-top对父级容器无效
  3. win7 安装PyTorch
  4. 【OS学习笔记】十五 保护模式三:保护模式下的内存访问机制
  5. sqlserver连接oracle(通过ODBC)
  6. JavaScript小效果的实现(笔记)
  7. 华为机试HJ30:字符串合并处理
  8. 验证码重新发送倒计时
  9. 基于Python的西瓜数据集 3.0α的SVM实现
  10. C罗是你人生中最好的健身教练和精神导师
  11. Tkinter GUI设计中文文档
  12. 揭秘Facebook北极圈数据中心 日处理45亿赞
  13. 2023年全国最新工会考试精选真题及答案53
  14. APP测试概念/Appium实战
  15. 解决浏览器 Microsoft Edge主页被hao123恶意篡改
  16. 在安装matlab时,报:找不到必需的文件。(要使用文件安装密钥,您必须从包含安装文件的目录运行安装程序)
  17. jQuery根据ID删除元素
  18. 语音交互设计的一点认知
  19. 找出数组中符合某些条件的对象数组
  20. ipv6地址概述——了解ipv6地址

热门文章

  1. jenkins停止僵尸作业Click here to forcibly terminate running steps
  2. 面试向:如何设计一个有容错性的微服务架构?
  3. 云服务器公网IPv4是什么意思?IPv4还是IPv6好?
  4. linux中查看rpm包位置,linux中,查看某个命令是来自哪个RPM包或者是通过哪个RPM包安装的...
  5. 大数据Hadoop入门
  6. 最新:2021年7月全国程序员平均薪资出炉!你还坐得住吗?
  7. 【Linux】linux清除ip地址命令
  8. PHP获取汉字的拼音(支持首字母和全拼)
  9. 中国裁判文书网全网最新爬虫分析
  10. jquery的keyup()事件案列——根据输入中文名称自动显示添加对应的拼音简写+时间戳