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>

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

相关推荐
云烟成雨TD44 分钟前
Spring AI Alibaba 1.x 系列【18】Hook 接口和四大抽象类
java·人工智能·spring
StackNoOverflow1 小时前
Spring Cloud的注册中心和配置中心(Nacos)
后端·spring cloud
Flittly3 小时前
【SpringSecurity新手村系列】(2)整合 MyBatis 实现数据库认证
java·安全·spring·springboot·安全架构
devilnumber4 小时前
java中Redisson ,jedis,Lettuce和Spring Data Redis的四种深度对比和优缺点详解
java·redis·spring
砍材农夫4 小时前
spring-ai 第十一mcp server调用入门(stdio协议)
人工智能·spring·microsoft
码农阿豪4 小时前
一次 AI 调用 15 万 Token 只花了 $0.058?彻底搞懂 Token、缓存读、补全计费机制!(附完整架构图)
人工智能·spring·缓存
awljwlj4 小时前
黑马点评复习—缓存相关【包含可能的问题和基础知识复习】
java·后端·spring·缓存
庞轩px5 小时前
反射与动态代理——Java语言动态性的核心
java·spring·反射·aop·动态代理·类型
数字化顾问5 小时前
(88页PPT)DG1092D1S4培训课件EASGERP总体架构基础(附下载方式)
微服务·云原生·架构
一叶飘零_sweeeet5 小时前
Spring AI 核心架构、抽象模型与四大核心组件设计精髓
spring·spring ai