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

相关推荐
编程、小哥哥5 小时前
netty之Netty与SpringBoot整合
java·spring boot·spring
wxin_VXbishe10 小时前
springboot合肥师范学院实习实训管理系统-计算机毕业设计源码31290
java·spring boot·python·spring·servlet·django·php
OEC小胖胖10 小时前
Spring Boot + MyBatis 项目中常用注解详解(万字长篇解读)
java·spring boot·后端·spring·mybatis·web
落落落sss11 小时前
MybatisPlus
android·java·开发语言·spring·tomcat·rabbitmq·mybatis
潘多编程19 小时前
Java中的状态机实现:使用Spring State Machine管理复杂状态流转
java·开发语言·spring
_阿伟_19 小时前
SpringMVC
java·spring
杨半仙儿还未成仙儿1 天前
Spring框架:Spring Core、Spring AOP、Spring MVC、Spring Boot、Spring Cloud等组件的基本原理及使用
spring boot·spring·mvc
攸攸太上1 天前
Spring Gateway学习
java·后端·学习·spring·微服务·gateway
无理 Java1 天前
【技术详解】SpringMVC框架全面解析:从入门到精通(SpringMVC)
java·后端·spring·面试·mvc·框架·springmvc
gobeyye1 天前
spring loC&DI 详解
java·spring·rpc