SpringCloudalibaba

一、分布式和微服务

分布式系统和服务是现代软件开发中的两个重要概念。它们为复杂的应用程序提供了模块化和可扩展性,使其能够在多台机器上运行,并为大量用户提供服务。

分布式系统

定义: 分布式系统是由多个独立组件组成的系统,这些组件在地理上分散,但通过网络相互连接,并协同工作。

特点:

  1. 可扩展性: 分布式系统可以扩展到处理大量数据和用户请求。

  2. 灵活性: 由于组件是独立的,可以根据需要添加或删除它们。

  3. 容错性: 分布式系统中的某个组件出现问题不会影响其他组件。

4.通信: 由于组件分布在多个机器上,所以需要高效的通信机制来协调它们之间的交互。

微服务

定义: 微服务是一种软件架构风格,它将应用程序构建为一系列小型、独立的服务。

特点:

  1. 独立性: 每个微服务都是独立的,具有自己的业务逻辑和数据存储。

  2. 可扩展性: 微服务可以独立于其他服务进行扩展。

  3. 灵活性: 可以相对容易地添加或删除微服务。

  4. 技术多样性: 每个微服务可以使用最适合其需求的技术栈和语言。

  5. API 驱动: 微服务之间通过 API 进行通信。

区别

  1. 规模: 分布式系统通常涉及多个数据中心和大量的服务器,而微服务通常在单个数据中心的单个服务器上运行

  2. 复杂性: 分布式系统由于其规模和地理分布,通常更为复杂。微服务架构通过将复杂性降低到服务级别来简化问题

  3. 通信: 分布式系统侧重于系统内各个组件之间的通信,而微服务主要关注服务之间的通信。

总结

分布式系统和服务都是为了解决大规模应用程序的需求而设计的。分布式系统通过将数据和计算分布在多个位置来提供高可用性和可扩展性。微服务则通过将应用程序分解为小型、独立的服务来提高灵活性和可扩展性。在实际应用中,分布式系统和微服务经常结合使用,以充分利用两者的优势

二、简单上手

创建父工程

更改父进程的pom.xml配置

XML 复制代码
<?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">
    <!-- Maven 版本 -->
    <modelVersion>4.0.0</modelVersion>

    <!-- 父项目 -->
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.4.2</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>

    <!-- 项目信息 -->
    <groupId>com.aaa</groupId>
    <artifactId>SpringCloud</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>pom</packaging>
    <name>SpringCloud</name>
    <description>SpringCloud</description>

    <!-- 不用写,添加完子模块后idea自动添加子模块 -->
    <modules>
        <module>foundation</module>
        <module>commodity</module>
        <module>orders</module>
    </modules>

    <!-- 属性配置 -->
    <properties>
        <java.version>1.8</java.version>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>

        <spring-cloud.version>2020.0.1</spring-cloud.version>
        <spring-cloud-alibaba.version>2021.1</spring-cloud-alibaba.version>
    </properties>

    <!-- 依赖管理 -->
    <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>

    <!-- 构建配置 -->
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <configuration>
                    <image>
                        <builder>paketobuildpacks/builder-jammy-base:latest</builder>
                    </image>
                </configuration>
            </plugin>
        </plugins>
    </build>

</project>

创建子工程

创建commodity

写一个实体类

创建foundation

创建过程同上

pom.xml文件导入如下

创建配置文件

修改启动类

写一个controller类

另一个controller

相关推荐
咖啡八杯1 天前
GoF设计模式——备忘录模式
java·后端·spring·设计模式
Flittly3 天前
【AgentScope Java新手村系列】(16)从RAG到多路检索
java·spring boot·spring
咖啡八杯3 天前
GoF设计模式——中介者模式
java·后端·spring·设计模式
Flittly5 天前
【AgentScope Java新手村系列】(14)人机交互
java·spring boot·spring
唐青枫9 天前
Java Spring WebFlux 实战指南:用 Mono、Flux 和 WebClient 写响应式接口
java·spring
咖啡八杯10 天前
GoF设计模式——策略模式
java·后端·spring·设计模式
Flittly12 天前
【AgentScope Java新手村系列】(11)中断与恢复
java·spring boot·spring
dunky12 天前
Spring 的三级缓存与循环依赖
后端·spring
码云数智-园园17 天前
C++20 Modules 模块详解
java·开发语言·spring
咖啡八杯17 天前
GoF设计模式——享元模式
java·spring·设计模式·享元模式