各位小伙伴们大家好,欢迎来到这个小扎扎的spring cloud专栏,在这个系列专栏中我对B站尚硅谷阳哥的spring cloud教程进行一个总结,鉴于 看到就是学到、学到就是赚到 精神,这波依然是血赚 ┗|`O′|┛
💡spring cloud知识点速览
- 🌕 版本选择
- 🌕 技术选型
- 🌕 spring boot单体模块的搭建
- 🌓 创建父工程
- 🌓 父工程的pom文件
- 🌓 创建子模块
- 🌕 RestTemplate
- 🌓 使用步骤
- 🌕 系统重构(子模块间重复代码的抽取)
🌕 版本选择
学习spring cloud之前需要有一定的spring boot基础,按我现阶段的了解就是,spring boot属于是做业务开发的,所谓的微服务就是将一个大的项目分为是很多的使用spring boot进行开发的单体项目。当然如果没有后续的话,那么这一个项目也就成了一盘散沙,没有办法真正的实现它的作用,于是就需要使用spring cloud将所有的spring boot单体项目整合起来,形成一个完整的项目,从而发挥它最大的作用。
既然在一个项目中涉及到了两种框架技术的使用,那么就需要考虑这两种框架会不会产生冲突。那么我们应该如何查看这两种框架的版本适用呢?我们可以参考spring cloud官网给出的答案,这个文档是实时更新的,不用担心过时的问题。https://spring.io/projects/spring-cloud,打开链接直接向下划即可找到
官网在这里只是提供了一个相对模糊的版本对应,想要更加具体的版本对应可以参考以下网站https://start.spring.io/actuator/info,将网站返回的JSON字符串经过工具的转换即可发现其中的版本对应
当然,上述两种方法都是在boot和cloud技术版本选择时的一种参考,真正确定下来还是要看cloud官网上面的参考doc文档,点进去的Supported Boot Version才是最终敲定的依据
🌕 技术选型
前面讲到spring cloud是一个微服务的框架,既然是微服务就说明我们需要使用技术控制各个单体服务之间的通信,还有不同服务的调用等。于是就涉及到了这些不同功能的技术选型,我们都知道技术是在不停迭代更新的,有很多的技术停更淘汰,与此同时也有很多的技术更新迭代出来,于是我们应该知道不同的功能应该选用哪种可行的技术。
- 服务注册中心:
- Eureka
- Zookeeper
- Consul
- Nacos √
- 服务调用:
- Ribbon
- LoadBalancer
- Feign
- OpenFeign √
- 服务降级:
- Hystrix
- Resilience4j
- Sentinel √
- 服务网关:
- Zuul
- Zuul2
- Gateway √
- 服务配置:
- Config
- Nacos √
- 服务总线:
- Bus
- Nacos √
🌕 spring boot单体模块的搭建
🌓 创建父工程
🌒 project项目创建
修改项目名 -> 修改项目存储地址 -> 修改maven配置 -> finished
🌒 配置字符编码格式
🌒 配置注解生效激活
🌒 配置项目的Java的版本
🌓 父工程的pom文件
父pom中的并不会引入相应的jar包,而是定义了版本号供子模块使用,只有子模块导入依赖坐标的时候(如果父pom中有,可以不指定版本号)才会引入相应的jar包
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>项目的组id</groupId><artifactId>项目名称</artifactId><version>项目版本</version><packaging>pom</packaging><!--统一管理设置jar包的版本--><properties>..........</properties><!--依赖传递:父pom文件中的依赖版本会被子模块自动继承,除非子模块中自己声明版本,否则就使用父pom的版本,同理,父pom的依赖版本升级,子模块也会升级到相应的版本--><dependencyManagement><dependencies><dependency>.......</dependency>......<dependency>.......</dependency></dependencies></dependencyManagement></project>
🌓 创建子模块
在父工程上右键,新建一个model
创建之后需要配置子模块的配置文件,也就是子模块的resources文件夹下的application.yml文件,主要就是配置端口号和数据库相关
server:port: 8001spring:application:name: cloud-payment-servicedatasource:type: com.alibaba.druid.pool.DruidDataSourcedriver-class-name: org.gjt.mm.mysql.Driverurl: …… ……… ………username: …… ……password: …… …… ……mybatis:mapper-locations: classpath:mapper/*.xmltype-aliases-package: com.xiaochen.springcloud.entities
然后就是创建相应的mapper、service、serviceImpl、映射文件
🌕 RestTemplate
Rest Template就是一种对HTTPClient的封装,是Spring提供的用于访问Rest服务的客户端模板工具集,其内部提供了多种便捷的用于访问远程http服务的方法,主要就是用于实现微服务项目中几个服务之间的相互调用。
🌓 使用步骤
使用配置类向容器中注入RestTemplate对象
/*** @ClassName: ApplicationContextConfig* @Description: 程序配置类* @author: chenhao* @date: 2022/7/17*/
@Configuration
public class ApplicationContextConfig {@Beanpublic RestTemplate getRestTemplate() {return new RestTemplate();}
}
在需要使用它的地方用@Resource注入对象,然后就是调用api实现相应的功能,全部api参考以下链接:https://docs.spring.io/spring-framework/docs/5.2.2.RELEASE/javadoc-api/org/springframework/web/client/RestTemplate.html
🌕 系统重构(子模块间重复代码的抽取)
创建一个公共模块,将公共的代码和依赖全部抽取到这个公共模块中,然后别的模块如果想要使用公共模块的代码,就必须先对公共模块的maven进行clean和install,然后在pom文件中导入这个公共模块的依赖即可使用公共部分代码