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自我保护机制

 

相关文章

本篇文章为大家展示了如何解决Spring Cloud 服务冲突问题,内...
本篇内容主要讲解“spring cloud服务的注册与发现怎么实现”...
本篇内容介绍了“Dubbo怎么实现Spring Cloud服务治理 ”的有...
本篇内容主要讲解“SpringCloud相关面试题有哪些”,感兴趣的...
如何分析Spring Cloud Ribbon、Spring Cloud Feign以及断路器...
这篇文章主要讲解了“springcloud微服务的组成部分有哪些”,...