SpringCloudAlibaba分布式微服务入门搭建项目框架

深藏阁楼爱情的钟 2023-09-30 13:13 93阅读 0赞

场景

SpringCloud 是若干个框架的集合,包括 spring-cloud-config、spring-cloud-bus 等近 20 个子项目,提供了服务治理、服务网关、智能路由、负载均衡、断路器、监控跟踪、分布式消息队列、配置管理等领域的解决方案。

Spring Cloud 通过 Spring Boot 风格的封装,屏蔽掉了复杂的配置和实现原理,最终给开发者留出了一套简单易懂、容易部署的分布式系统开发工具包。

Spring Cloud Alibaba 也是一套微服务解决方案,包含开发分布式应用微服务的必需组件,方便开发者通过 Spring Cloud 编程模型轻松使用这些组件来开发分布式应用服务。

依托 Spring Cloud Alibaba,您只需要添加一些注解和少量配置,就可以将 Spring Cloud 应用接入阿里微服务解决方案,通过阿里中间件来迅速搭建分布式应用系统。

Spring Cloud Alibaba中包含的组件

阿里开源组件

Nacos:一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。

Sentinel:把流量作为切入点,从流量控制、熔断降级、系统负载保护等多个维度保护服务的稳定性。

RocketMQ:开源的分布式消息系统,基于高可用分布式集群技术,提供低延时的、高可靠的消息发布与订阅服务。

Dubbo:这个就不用多说了,在国内应用非常广泛的一款高性能 Java RPC 框架。

Seata:阿里巴巴开源产品,一个易于使用的高性能微服务分布式事务解决方案。

Arthas:开源的Java动态追踪工具,基于字节码增强技术,功能非常强大。

官方说明

https://github.com/alibaba/spring-cloud-alibaba/blob/2.2.x/README-zh.md

watermark_type_d3F5LXplbmhlaQ_shadow_50_text_Q1NETiBA6Zy46YGT5rWB5rCT5rCU6LSo_size_20_color_FFFFFF_t_70_g_se_x_16

注:

博客:
霸道流氓气质的博客_CSDN博客-C#,架构之路,SpringBoot领域博主
关注公众号
霸道的程序猿
获取编程相关电子书、教程推送与免费下载。

实现

1、打开IDEA,新建Project-Spring Initializr

690c64c2d860b5d531931a3ea29f7297.png

使用默认的url如果报错

Initialization failed for ‘https://start.spring.io‘ Please check URL…

ee6f3d180b9f56b3926174196bf92cc6.png

修改URL为Custom的

https://start.aliyun.com/

5257ee85f6673abf8d523b5c8c96c13e.png

2、选择Type为Maven等项目配置

82a5b7d371cba3220b44cea5d783dbc1.png

3、这里为了从头练习,啥也不选,直接点击next

32c13341a88f1bc521a0c7903718e93f.png

4、 修改pom文件

添加版本号属性

  1. <properties>
  2. <java.version>1.8</java.version>
  3. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  4. <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
  5. <spring-boot.version>2.3.7.RELEASE</spring-boot.version>
  6. <!-- Spring Cloud Alibaba 版本 -->
  7. <spring.cloud.alibaba>2.2.7.RELEASE</spring.cloud.alibaba>
  8. <!-- Spring Cloud 版本 -->
  9. <spring.cloud>Hoxton.SR12</spring.cloud>
  10. </properties>

1548923966744dbd01621ba2b796f5dc.png

添加依赖

  1. <!-- Spring Cloud Alibaba 版本管理器 -->
  2. <dependency>
  3. <groupId>com.alibaba.cloud</groupId>
  4. <artifactId>spring-cloud-alibaba-dependencies</artifactId>
  5. <version>${spring.cloud.alibaba}</version>
  6. <type>pom</type>
  7. <scope>import</scope>
  8. </dependency>
  9. <!-- Spring Cloud 版本管理器 -->
  10. <dependency>
  11. <groupId>org.springframework.cloud</groupId>
  12. <artifactId>spring-cloud-dependencies</artifactId>
  13. <version>${spring.cloud}</version>
  14. <type>pom</type>
  15. <scope>import</scope>
  16. </dependency>

cf12d936c7612a4e40932b7adedfc3de.png

完整pom文件

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
  4. <modelVersion>4.0.0</modelVersion>
  5. <groupId>com.badao</groupId>
  6. <artifactId>spring-cloud-alibaba-demo</artifactId>
  7. <version>0.0.1-SNAPSHOT</version>
  8. <name>spring-cloud-alibaba-demo</name>
  9. <description>Demo project for Spring Boot</description>
  10. <properties>
  11. <java.version>1.8</java.version>
  12. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  13. <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
  14. <spring-boot.version>2.3.7.RELEASE</spring-boot.version>
  15. <!-- Spring Cloud Alibaba 版本 -->
  16. <spring.cloud.alibaba>2.2.7.RELEASE</spring.cloud.alibaba>
  17. <!-- Spring Cloud 版本 -->
  18. <spring.cloud>Hoxton.SR12</spring.cloud>
  19. </properties>
  20. <dependencies>
  21. <dependency>
  22. <groupId>org.springframework.boot</groupId>
  23. <artifactId>spring-boot-starter</artifactId>
  24. </dependency>
  25. <dependency>
  26. <groupId>org.springframework.boot</groupId>
  27. <artifactId>spring-boot-starter-test</artifactId>
  28. <scope>test</scope>
  29. <exclusions>
  30. <exclusion>
  31. <groupId>org.junit.vintage</groupId>
  32. <artifactId>junit-vintage-engine</artifactId>
  33. </exclusion>
  34. </exclusions>
  35. </dependency>
  36. <!-- Spring Cloud Alibaba 版本管理器 -->
  37. <dependency>
  38. <groupId>com.alibaba.cloud</groupId>
  39. <artifactId>spring-cloud-alibaba-dependencies</artifactId>
  40. <version>${spring.cloud.alibaba}</version>
  41. <type>pom</type>
  42. <scope>import</scope>
  43. </dependency>
  44. <!-- Spring Cloud 版本管理器 -->
  45. <dependency>
  46. <groupId>org.springframework.cloud</groupId>
  47. <artifactId>spring-cloud-dependencies</artifactId>
  48. <version>${spring.cloud}</version>
  49. <type>pom</type>
  50. <scope>import</scope>
  51. </dependency>
  52. </dependencies>
  53. <dependencyManagement>
  54. <dependencies>
  55. <dependency>
  56. <groupId>org.springframework.boot</groupId>
  57. <artifactId>spring-boot-dependencies</artifactId>
  58. <version>${spring-boot.version}</version>
  59. <type>pom</type>
  60. <scope>import</scope>
  61. </dependency>
  62. </dependencies>
  63. </dependencyManagement>
  64. <build>
  65. <plugins>
  66. <plugin>
  67. <groupId>org.apache.maven.plugins</groupId>
  68. <artifactId>maven-compiler-plugin</artifactId>
  69. <version>3.8.1</version>
  70. <configuration>
  71. <source>1.8</source>
  72. <target>1.8</target>
  73. <encoding>UTF-8</encoding>
  74. </configuration>
  75. </plugin>
  76. <plugin>
  77. <groupId>org.springframework.boot</groupId>
  78. <artifactId>spring-boot-maven-plugin</artifactId>
  79. <version>2.3.7.RELEASE</version>
  80. <configuration>
  81. <mainClass>com.badao.springcloudalibabademo.SpringCloudAlibabaDemoApplication</mainClass>
  82. </configuration>
  83. <executions>
  84. <execution>
  85. <id>repackage</id>
  86. <goals>
  87. <goal>repackage</goal>
  88. </goals>
  89. </execution>
  90. </executions>
  91. </plugin>
  92. </plugins>
  93. </build>
  94. </project>

此时父工程就搭建完成了,整个项目是由maven进行管理的,这里什么都不选,因为后面要做底座+多个子模块的架构,

这个父工程就是底座。

在搭建时尤其要注意版本兼容问题,即SpringCloud与SpringBoot的版本兼容问题。

官方版本说明

https://github.com/alibaba/spring-cloud-alibaba/wiki/%E7%89%88%E6%9C%AC%E8%AF%B4%E6%98%8E

713e31cabe080c4f31fc444770c441c2.png

发表评论

表情:
评论列表 (有 0 条评论,93人围观)

还没有评论,来说两句吧...

相关阅读