其他分享
首页 > 其他分享> > SpringCloud复习2-1

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

 

标签:负载,调用,复习,SpringCloud,RestTemplate,6.1,movie,Ribbon
来源: https://www.cnblogs.com/wangshikang/p/16546565.html