spring cloud
1 基本概念
1.1 微服务
可以简单的理解为微服务就是一个一个的springboot应用。
1.2 spring cloud
分布式微服务架构的一站式解决方案是多种微服务架构落地技术的集合体,服务的发现,注册,熔断,监控等等都可以通过springcloud来解决。
2 spring cloud组件概况
- 不同的服务操作对应不同的组件
3 springboot与springcloud的匹配
- springboot与springcloud必须严格匹配,可以去官网查看
https://spring.io/projects/spring-cloud
- 如何查看详细的对应关系(访问下面这个地址会得到一个JSON串):
https://start.spring.io/actuator/info
4 关于组件的停更和替换
1)服务注册中心 停更:(Eureka) 替换:zookeeper, Consul, Nacos(非常推荐)。
2)服务调用 停更:Ribbon 替换 : LoadBalancer
3)另一个服务调用 停更:Feign 替换:OpenFeign
4)服务降级 停更:Hystrix 替换:resilience4j, sentinel(非常推荐)
5)服务网关 停更: Zuul 替换:gateway
6)服务配置 不在使用(config)替换:Nacos
7)服务总线 不在使用 (Bus) 替换:Nacos、
5 从零开始搭建项目
项目环境的搭建通常分为以下几步
具体步骤:
- 新建父工程的时候,可以按照下图进行选择
- 配置编码格式
- 注解生效激活
- java编译版本
- 设置fileTYPE,直接在setting中设置即可
特别重要:
关于dependencyManagement,Maven使用dependencyManagement元素提供了一种管理依赖版本号的方式,maven会沿着父子层向上走,直到找到一个拥有dependencyManagement元素的项目,让后就会只用这个版本号。也就是说它的子项目不用再写版本号,一般出现在父工程中。这样方便依赖的管理,父类改变版本子类都会改变版本,如果子类指定了自己的版本号则用子项目自己的。
6开启热部署,写完代码自动重启项目
添加依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<scope>runtime</scope>
<optional>true</optional>
</dependency>
然后在父工程统一设置插件
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<fork>true</fork>
<addResources>true</addResources>
</configuration>
</plugin>
开启自动编译权限
在pom插件处快捷键Ctrl shift alt + /,配置完重启一下
据说2021版本第一个配置被迁移到了这里,但是我配置了还是没有生效不知道为啥(后续排查):
夸模块的调用restTemplate
配置restTemplate
@Configuration
public class ApplicationContext {
@Bean
public RestTemplate getRestTemplate() {
return new RestTemplate();
}
}
使用restTemplate
private static final String PAYMENT_URL = "http://localhost:8001";
@Resource
private RestTemplate restTemplate;
@PostMapping("/consumer/payment/create")
public CommonResult create(Payment payment) {
return restTemplate.postForObject(PAYMENT_URL + "/payment/create", payment, CommonResult.class);
}
@GetMapping("/consumer/payment/get/{id}")
public CommonResult getPaymentById(@PathVariable("id") Long id) {
return restTemplate.getForObject(PAYMENT_URL + "/payment/create" + id, CommonResult.class);
}