SpringCloud复习2-1
接着来
前边基本的搭建好了,接着该远程调用或者调用哪台movie
如果movie炸了我们应该怎么办,都没做呢,现在仅仅是把架构启动好了-》movie启动了四次,eureka是个集群 ,movie也是一个集群,user是一台服务器
可以看出来我们这个是三个微服务user、movie、server
按集群部署了—》
第六章 SpringCloud-Hello案例开发-Ribbon-RestTemplate(springcloud提供的)
6.1 Ribbon负载均衡,可以用于远程调用(用户服务 调用 电影服务 项目)
客户端调用客户端,所以是客户端的负载均衡(有4个电影客户端,不确定哪台,负载一下) 开整!!!
如何使用Ribbon
1)、引入Ribbon的Starter
2)、配置使用Ribbon功能;底层使用 RestTemplate 的工具来给远程发送请求
6.1.1 用户服务项目中引入Ribbon
<!-- 引入ribbon实现远程调用和负载均衡功能 -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
</dependency>
6.1.2 RestTemplate(轮询)
你都用RestTemplate,所以需要new一个配置类,实现负载均衡-》给容器中注入一个RestTemplate并使用Ribbon进行负载均衡调用
程序入口或者自己建一个配置类写一样的 (写一个就行)
6.1.3 使用RestTemplate远程调用(UserService中完善代码)
**远程调用要写在逻辑里
restTemplate的getForObject有三个参数
6.1.4 远程调用完成了,负载均衡不确定,所以测试一下
我刷了10次还是比较均匀的
代码:就加了个@Value,取了一下yml配置文件端口号,控制台输出
扩展自定义负载策略(随机)
随机策略 用了rule就是随机,不用就是你之前的负载均衡
2-1代码就这么多,接下来是eureka自我保护机制
eureka集群搭建:
https://www.cnblogs.com/yhood/p/11558636.html
eureka自我保护机制:
https://www.cnblogs.com/xishuai/p/spring-cloud-eureka-safe.html
spring cloud eureka 自我保护机制
注:如果没有eureka自我保护机制,或者说你给设置成false了(默认是true),当你的服务器出现网络波动,可能几秒没返回数据什么的,eureka会认为你这个服务器宕机了,会给你踢出去,你就算好了,正常也用不了只能重启服务器
而自我保护机制是干嘛的呢?
Eureka Server 在运行期间会去统计心跳失败比例在 15 分钟之内是否低于 85%,如果低于 85%,Eureka Server 会将这些实例保护起来,让这些实例不会过期,但是在保护期内如果服务刚好这个服务提供者非正常下线了,此时服务消费者就会拿到一个无效的服务实例,此时会调用失败,对于这个问题需要服务消费者端要有一些容错机制,如重试,断路器等。
我们在单机测试的时候很容易满足心跳失败比例在 15 分钟之内低于 85%,这个时候就会触发 Eureka 的保护机制,一旦开启了保护机制,则服务注册中心维护的服务实例就不是那么准确了,此时我们可以使用eureka.server.enable-self-preservation=false
来关闭保护机制,这样可以确保注册中心中不可用的实例被及时的剔除(不推荐)。
自我保护模式被激活的条件是:在 1 分钟后,Renews (last min) < Renews threshold
。
这两个参数的意思:
-
Renews threshold
:Eureka Server 期望每分钟收到客户端实例续约的总数。 -
Renews (last min)
:Eureka Server 最后 1 分钟收到客户端实例续约的总数。
1