SpringCloud Alibaba微服务工程搭建

前言

在讲微服务工程的搭建之前,我们先分析下为什么要使用微服务呢?

1、单体应用的痛点

  • 维护困难:代码臃肿,牵一发而动全身。
  • 扩展性差:无法按需扩展特定功能,只能整体扩容。
  • 技术栈僵化:难以引入新技术,升级风险高。
  • 可靠性低:单点故障导致全站瘫痪。
  • 交付慢:团队协作冲突多,发布效率低下
  • 性能瓶颈:集中式架构难以应对高并发。

2、微服务的优势

将原来的单体应用按功能进行拆分,拆分为多个模块,每个模块负责自己的业务功能。每个服务都独立运行,相互不影响。每个服务拥有单一职责,专注于一个业务功能,各个服务之间通过API(HTTP/RPC)、或者消息队列进行交互,每个服务可以独立更新维护、扩展,不影响其他的服务。

Spring Cloud Alibaba 核心组件

1、Nacos------注册中心(服务注册与发现)和配置中心

2、Ribbon------客户端负载均衡器

3、Sentinel------流量控制与熔断降级

5、Spring Cloud Gateway------服务网关

4、Seata------分布式事务

5、Feign------声明式 HTTP 客户端

6、RocketMQ/RabbitMQ------消息队列

微服务工程搭建

1、搭建父工程


删除父工程中的src等无关目录

2、引入相关依赖

java 复制代码
<?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>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.7.18</version>
        <relativePath/>
    </parent>

    <groupId>com.shop</groupId>
    <artifactId>shop-cloud-service</artifactId>
    <version>1.0-SNAPSHOT</version>
    <packaging>pom</packaging>
    <modules>
        
    </modules>
    
    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
        <spring-cloud.version>2021.0.8</spring-cloud.version>
        <spring-cloud-alibaba.version>2021.0.5.0</spring-cloud-alibaba.version>
        <nacos-client.version>2.2.3</nacos-client.version>
    </properties>
    <!--  总项目, dependencyManagement来管理,其他子项目就可以不用来管理版本了,可以直接引用 -->
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>

            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-alibaba-dependencies</artifactId>
                <version>${spring-cloud-alibaba.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>
</project>

3、创建子项目


一直下一步就好,然后修改pom.xml文件

java 复制代码
<?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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>com.shop</groupId>
        <artifactId>shop-cloud-service</artifactId>
        <version>1.0-SNAPSHOT</version>
    </parent>


    <artifactId>shop-order</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>shop-order</name>

    <properties>
        <java.version>1.8</java.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>

最后送大家一句话:须知少时凌云志,曾许人间第一流

相关推荐
小许学java23 分钟前
Spring事务和事务传播机制
java·数据库·spring·事务
这是程序猿2 小时前
基于java的ssm框架经典电影推荐网站
java·开发语言·spring boot·spring·经典电影推荐网站
jiayong232 小时前
海外求职平台与策略指南
java·spring
SadSunset3 小时前
(37)全注解式开发AOP
java·spring
子超兄3 小时前
Bean生命周期
java·spring
Mr.朱鹏4 小时前
超时订单处理方案实战指南【完整版】
java·spring boot·redis·spring·rabbitmq·rocketmq·订单
大猫和小黄4 小时前
若依微服务Cloud中Quartz-Job模块适配OpenGauss数据库
数据库·微服务·opengauss·quartz·定时任务·若依·job
用户3521802454754 小时前
🎉Spring Boot 3 + 多数据源 + Druid:监控页面 + 控制台 SQL 日志,终于搞定啦!
spring boot·微服务
Lisonseekpan4 小时前
RBAC 基于角色的访问控制模型详解与实践指南
java·服务器·网络·后端·spring·log4j
while(1){yan}5 小时前
计算器和登录界面(实现前后端互通)
spring boot·spring·servlet·java-ee·tomcat·maven