SpringCloud复习2-1

SpringCloud复习2-1

接着来

前边基本的搭建好了,接着该远程调用或者调用哪台movie

如果movie炸了我们应该怎么办,都没做呢,现在仅仅是把架构启动好了-》movie启动了四次,eureka是个集群 ,movie也是一个集群,user是一台服务器

image-20220803095725820

可以看出来我们这个是三个微服务user、movie、server

按集群部署了—》

image-20220803095859491

 

第六章 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进行负载均衡调用

程序入口或者自己建一个配置类写一样的 (写一个就行)

image-20220803101311356

 @LoadBalanced //负载均衡

 

6.1.3 使用RestTemplate远程调用(UserService中完善代码)

**远程调用要写在逻辑里

image-20220803110355498

 

restTemplate的getForObject有三个参数

image-20220803110725244

image-20220803111112498

 

6.1.4 远程调用完成了,负载均衡不确定,所以测试一下

image-20220803111548853

我刷了10次还是比较均匀的

image-20220803112137635

代码:就加了个@Value,取了一下yml配置文件端口号,控制台输出

 @RestController
 public class MovieController {
 
     @Autowired
     MovieService movieService;
     @Value("${server.port}")
     private int port;
     /**
      * 获取最新电影
      */
     @GetMapping("/movie")
     public Movie getNewMovie() {
         System.out.println("port" + port);
         return movieService.getNewMovie();
    }
 
 }

 

扩展自定义负载策略(随机)

随机策略 用了rule就是随机,不用就是你之前的负载均衡

image-20220803114854937

 

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 thresholdEureka Server 期望每分钟收到客户端实例续约的总数

  • Renews (last min)Eureka Server 最后 1 分钟收到客户端实例续约的总数

image-20220803133500582

image-20220803133656321

1

 
posted @ 2022-08-03 11:53  为了她  阅读(17)  评论(0编辑  收藏  举报