第七章_Ribbon负载均衡与服务调用
1.Ribbon概述
1.1Ribbon是什么
data:image/s3,"s3://crabby-images/e0e2c/e0e2cfa240b9f7d17c48dcaf1fbcb0b701b82075" alt=""
1.2官网资料
自己搜
1.3能干嘛
一句话:负载均衡+RestTemplate调用
(1)LB---负载均衡
①Nginx---负载均衡
Nginx是服务器负载均衡,客户端所有请求都会交给nginx,然后由nginx实现转发请求,即实现负载均衡
②Ribbon---负载均衡
Ribbon是本地负载均衡。在调用微服务接口时候,会在注册中心上获取注册信息服务列表之后缓存到JVM本地,从而在本地实现RPC远程服务调用技术
③集中式LB
即在服务的消费方和提供方之间使用独立的LB设施(可以是硬件,如F5,也可以是软件,如nginx),由该设施负责把访问请求通过某种策略转发至服务的提供方。
④进程内LB
将LB逻辑集成到消费方,消费方从服务注册中心获知有哪些地址可用,然后自己再从这些地址中选择出一个合适的服务器。
Ribbon属于进程内LB,只是一个类库,集成于消费方进程,消费方通过它来获取到服务提供方的地址
2.Ribbon负载均衡演示
2.1架构说明
Ribbon是一个软负载均衡的客户端组件,可以和其他所需请求的客户端结合使用,和eureka结合只是其中的一个实例
(1)Ribbon架构图
data:image/s3,"s3://crabby-images/c9201/c920161437996b59e5573f7612b48b4eba88fb4a" alt=""
(2)Ribbon的工作顺序
第一,选择EurekaServer,优先选择在同一个区域内负载较少的server
第二,根据用户指定的策略,再从server取到的服务注册列表中选择一个地址
其中用户指定的策略有:轮询、随机和根据响应时间加权
2.2POM文件
data:image/s3,"s3://crabby-images/921a1/921a1ee018016bf09a37c0a8c1cb544c4a378f71" alt=""
2.3二说RestTemplate的使用
(1)getForObject()和getForEntity()方法的区别
data:image/s3,"s3://crabby-images/e0e5e/e0e5e9a25440bfb1c47d5ce1f0e6ba415b03d646" alt=""
(2)postForObject()和postForEntity()方法的区别
postForObject()是post请求,可以携带参数,返回的对象是json格式。
调用的远程服务,返回的是什么,就是什么
postForEntity()是post请求,可以携带参数,返回的对象是Entity对象。
调用的远程服务,返回的是什么,再加上返回码。
3.Ribbon核心组件IRule
IRule:根据特定算法,从服务列表中选取一个要访问的服务
IDEA生成:
data:image/s3,"s3://crabby-images/5f766/5f766a2b5316367b45f6ed0b348247ecc5cede26" alt=""
3.1Ribbon默认自带的负载规则
data:image/s3,"s3://crabby-images/961af/961afa5cd32924c69bdcc048400f4e9d43804228" alt=""
(1)修改默认规则
-
说明:自定义配置类不能放在@ComponentScan所扫描的当前包下以及子包下,又主启动类上的注解@SpringBootApplication包含了注解@ComponentScan,所以得另起一个包放置自定义规则
data:image/s3,"s3://crabby-images/ce43e/ce43ee8010e6a1becb34adaef0fd6ef698adafac" alt=""
(2)新建MySelfRule规则类
data:image/s3,"s3://crabby-images/433db/433db020324c2f89a73ecd543e80ed92e4db88d7" alt=""
(3)主启动类添加@RibbonClient
指定重新配置的规则
data:image/s3,"s3://crabby-images/0ee85/0ee850760e43b336819eefdcefdbc50501b17449" alt=""
4.Ribbon负载均衡算法
4.1原理
data:image/s3,"s3://crabby-images/929d0/929d090390d66e2d03eb34364a59c8e7b69cf839" alt=""
4.2源码
4.3手写轮询算法
(1)ApplicationContextBean去掉注解@LoadBalanced
data:image/s3,"s3://crabby-images/1fb6c/1fb6c1f7e1cf7ce0a31468a478d543029e5994c9" alt=""
(2)主启动取消自己配置的规则
注意:是在80端口服务的主启动
data:image/s3,"s3://crabby-images/7b6f4/7b6f4be88791dd62d646ce50ebaf0fcc7507c273" alt=""
(3)编写LoadBalancer接口
data:image/s3,"s3://crabby-images/bc1a4/bc1a43fd0f68a0133cdd5da4254faaac5fc8fda1" alt=""
(4)手写轮询器
data:image/s3,"s3://crabby-images/86c8b/86c8b4b25643bbb663a7c7eccee1c4a573d65875" alt=""
(5)80服务的业务层
data:image/s3,"s3://crabby-images/d8cde/d8cdebc5152ab329f45f0e83f5475d00b01a5a0e" alt=""
(6)8001/8002服务的业务层
data:image/s3,"s3://crabby-images/5981d/5981d369f896918fc81f722e98881844acd605f6" alt=""
(7)测试
访问:localhost/consumer/payment/lb
轮询效果出现,查看后台
data:image/s3,"s3://crabby-images/7fd23/7fd23224b0652622e1b2a55a4dc0595f2053fcaf" alt=""
第八章_OpenFeign接口调用
1.OpenFeign简介
1.1OpenFeign是什么
data:image/s3,"s3://crabby-images/81df8/81df8f26edef45076324736817828396c90476ad" alt=""
官网地址:Spring Cloud
1.2Feign能干什么
总结:Feign是一个服务接口绑定器,接口加一个注解
data:image/s3,"s3://crabby-images/ec3f3/ec3f31bce6164c71bed42b20e0a00856f5cb77bc" alt=""
1.3Feign和OpenFeign的区别
data:image/s3,"s3://crabby-images/c335a/c335aab80ffbf12ffa0218d15973fe94818cb71a" alt=""
2.OpenFeign使用步骤
2.1说明
微服务调用接口+@FeignClient,即接口+注解
data:image/s3,"s3://crabby-images/2ae85/2ae85bd0bb1e598616c06a0ba39ed6c3d7b742c2" alt=""
2.2新建cloud-consumer-feign-order80
(1)POM
xml
<dependencies>
<!-- OpenFeign -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
<!-- eureka client-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<!-- 引入自己定义的api通用包,可以使用payment对象-->
<dependency>
<groupId>springcloud</groupId>
<artifactId>cloud-api-commons</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<scope>runtime</scope>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
(2)YML
data:image/s3,"s3://crabby-images/0f792/0f79251b3f7e5c4b3a560592a4cba4789f357c9b" alt=""
(3)主启动
data:image/s3,"s3://crabby-images/9be5a/9be5a54d7ca82a2b1f025932dfea9f2b0edcdb76" alt=""
(4)业务类
data:image/s3,"s3://crabby-images/d90f5/d90f5656a48eb60f481d18940c077ea523f3158d" alt=""
(5)测试
- 先启动7001/7002服务
- 再启动8001/8002订单服务
- 最后启动feign80服务
(6)小总结
data:image/s3,"s3://crabby-images/8d8b7/8d8b7db66f972265338276315ec95af0d33f1f93" alt=""
3.OpenFeign超时控制
3.1服务提供方8001/8002添加超时方法
data:image/s3,"s3://crabby-images/fe2ea/fe2ea57066515aae709ad155ea44b56912834715" alt=""
3.2服务消费方80添加超时方法
data:image/s3,"s3://crabby-images/9ed88/9ed88e52303392045a0197da0e699b600caa7b60" alt=""
3.3测试
data:image/s3,"s3://crabby-images/d048e/d048eab4d684c83f4dd3dbfd27505f347bb7a6cf" alt=""
3.4修改默认连接和超时时间
data:image/s3,"s3://crabby-images/fab73/fab730394da6c89e84f9c527a292307ef731b38e" alt=""
4.OpenFeign日志打印功能
Feign 提供了日志打印功能,我们可以通过配置来调整日志级别,从而了解 Feign 中 Http 请求的细节。
说白了就是对Feign接口的调用情况进行监控和输出
4.1日志级别
data:image/s3,"s3://crabby-images/19ae7/19ae7df35b3fa6b47a55f3275ac711d3a1c616f9" alt=""
4.2添加config配置类
data:image/s3,"s3://crabby-images/9d5eb/9d5eb7606c612b4242145dc9d4b92f876351d729" alt=""
4.3yml设置日志打印级别
data:image/s3,"s3://crabby-images/67d69/67d69add3e797eb5a25fba9e7a1e5b1aa9c42ed8" alt=""
4.4测试
data:image/s3,"s3://crabby-images/a5ac1/a5ac16c813a4094223662391d430cae4a2e0a1de" alt=""