SpringCloud复习2-1
作者:互联网
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进行负载均衡调用
程序入口或者自己建一个配置类写一样的 (写一个就行)
@LoadBalanced //负载均衡
6.1.3 使用RestTemplate远程调用(UserService中完善代码)
**远程调用要写在逻辑里
restTemplate的getForObject有三个参数
6.1.4 远程调用完成了,负载均衡不确定,所以测试一下
我刷了10次还是比较均匀的
代码:就加了个@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就是随机,不用就是你之前的负载均衡
2-1代码就这么多,接下来是eureka自我保护机制
标签:负载,调用,复习,SpringCloud,RestTemplate,6.1,movie,Ribbon 来源: https://www.cnblogs.com/wangshikang/p/16546565.html