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

相关推荐
龙少95432 小时前
【深入理解@EnableCaching】
java·后端·spring
啦啦右一8 小时前
Spring Boot | (一)Spring开发环境构建
spring boot·后端·spring
荆州克莱11 小时前
mysql中局部变量_MySQL中变量的总结
spring boot·spring·spring cloud·css3·技术
zquwei11 小时前
SpringCloudGateway+Nacos注册与转发Netty+WebSocket
java·网络·分布式·后端·websocket·网络协议·spring
火烧屁屁啦12 小时前
【JavaEE进阶】初始Spring Web MVC
java·spring·java-ee
岁岁岁平安12 小时前
spring学习(spring-DI(字符串或对象引用注入、集合注入)(XML配置))
java·学习·spring·依赖注入·集合注入·基本数据类型注入·引用数据类型注入
北辰浮光12 小时前
[spring]XML配置文件标签
xml·spring
ZSYP-S13 小时前
Day 15:Spring 框架基础
java·开发语言·数据结构·后端·spring
qxlxi13 小时前
【Spring事务】深入浅出Spring事务从原理到源码
spring
路在脚下@14 小时前
Spring Boot @Conditional注解
java·spring boot·spring