一、分布式和微服务
分布式系统和服务是现代软件开发中的两个重要概念。它们为复杂的应用程序提供了模块化和可扩展性,使其能够在多台机器上运行,并为大量用户提供服务。
分布式系统
定义: 分布式系统是由多个独立组件组成的系统,这些组件在地理上分散,但通过网络相互连接,并协同工作。
特点:
1. 可扩展性: 分布式系统可以扩展到处理大量数据和用户请求。
2. 灵活性: 由于组件是独立的,可以根据需要添加或删除它们。
3. 容错性: 分布式系统中的某个组件出现问题不会影响其他组件。
4. 通信: 由于组件分布在多个机器上,所以需要高效的通信机制来协调它们之间的交互。
微服务
定义: 微服务是一种软件架构风格,它将应用程序构建为一系列小型、独立的服务。
特点:
1. 独立性: 每个微服务都是独立的,具有自己的业务逻辑和数据存储。
2. 可扩展性: 微服务可以独立于其他服务进行扩展。
3. 灵活性: 可以相对容易地添加或删除微服务。
4. 技术多样性: 每个微服务可以使用最适合其需求的技术栈和语言。
5. API 驱动: 微服务之间通过 API 进行通信。
区别
1. 规模: 分布式系统通常涉及多个数据中心和大量的服务器,而微服务通常在单个数据中心的单个服务器上运行
2. 复杂性: 分布式系统由于其规模和地理分布,通常更为复杂。微服务架构通过将复杂性降低到服务级别来简化问题
3. 通信: 分布式系统侧重于系统内各个组件之间的通信,而微服务主要关注服务之间的通信。
总结
分布式系统和服务都是为了解决大规模应用程序的需求而设计的。分布式系统通过将数据和计算分布在多个位置来提供高可用性和可扩展性。微服务则通过将应用程序分解为小型、独立的服务来提高灵活性和可扩展性。在实际应用中,分布式系统和微服务经常结合使用,以充分利用两者的优势
二、简单上手
创建父工程
更改父进程的pom.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文件导入如下
创建配置文件
修改启动类