当前位置: 首页 > article >正文

分布式系统架构怎么搭建?

分布式系统架构

互联网企业的业务飞速发展,促使系统架构不断变化。总体来说,系统架构大致经历了单体应用架构垂直应用架构分布式架构SOA架构微服务架构的演变,很多互联网企业的系统架构已经向服务化网格(Service Mesh)演变。

单体应用架构:所有的模块写到一个Web项目中,再统一部署到一个Web服务器中。

分布式架构:将重复的代码抽象出来,形成统一的服务,供其他系统或者业务模块调用。

xxx-common: pojo,utils,config
xxx-system: pojo,dao,service
xxx-admin : controller

system 调用公共模块 common,控制模块 admin 调用业务模块 system。

简单举例。

创建项目

在这里插入图片描述

父级配置

<!--修改父级打包方式-->
<packaging>pom</packaging>
<!--子级都有谁-->
<modules>
    <module>boot-admin</module>
    <module>boot-common</module>
    <module>boot-system</module>
</modules>

子级配置

<!--修改子级打包方式-->
<packaging>jar</packaging>
<!--引入父级-->
<parent>
    <groupId>com.hz</groupId>
    <artifactId>boot-parent</artifactId>
    <version>0.0.1-SNAPSHOT</version>
</parent>

三者的依赖关系

<!-- boot-system -->
<dependencies>
    <dependency>
        <groupId>com.hz</groupId>
        <artifactId>boot-common</artifactId>
        <version>0.0.1-SNAPSHOT</version>
    </dependency>
</dependencies>
<!-- boot-admin -->
<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>com.hz</groupId>
        <artifactId>boot-system</artifactId>
        <version>0.0.1-SNAPSHOT</version>
    </dependency>
</dependencies>
<!-- boot-parent -->
<!-- 在 boot-parent 中引入需要的依赖 这样所有的子级都可以使用 -->
<dependencies>
    <dependency>
        <groupId>com.mysql</groupId>
        <artifactId>mysql-connector-j</artifactId>
        <scope>runtime</scope>
    </dependency>
    <dependency>
        <groupId>com.baomidou</groupId>
        <artifactId>mybatis-plus-boot-starter</artifactId>
        <version>3.5.1</version>
    </dependency>
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
</dependencies>

boot-common

模块结构:公共实体类、工具类等

在这里插入图片描述

boot-system

模块结构:数据持久化、服务接口及其实现类等

在这里插入图片描述

boot-admin

模块结构:启动类、控制器、yml配置文件等

在这里插入图片描述

打开 Maven,点击父级 boot-parent 打包

在这里插入图片描述

去到该目录下

D:\idea_workspaces\boot-parent\boot-admin\target

打开终端,输入命令

>java -jar boot-admin-0.0.1-SNAPSHOT-smbms.jar

运行项目

在这里插入图片描述

成功运行后调用接口测试,成功即可。


http://www.kler.cn/a/518593.html

相关文章:

  • Flutter_学习记录_导航和其他
  • 小程序电商运营内容真实性增强策略及开源链动2+1模式AI智能名片S2B2C商城系统源码的应用探索
  • Linux之NetLink学习笔记
  • docker Ubuntu实战
  • 计算机图形学:实验四 带纹理的OBJ文件读取和显示
  • vue3自定义表格生成动态列
  • linux系统中的 scp的使用方法
  • 【面试题】 Java 三年工作经验(2025)
  • 2025美赛数学建模C题 奥运奖牌模型保姆级教程讲解|模型讲解
  • 为AI聊天工具添加一个知识系统 之68 详细设计 之9 三种中台和时间度量 之1
  • SpringBoot打包为JAR包或WAR 包,这两种打包方式在运行时端口将如何采用?又有什么不同?这篇文章将给你解惑
  • ESP8266 NodeMCU与WS2812灯带:实现多种花样变换
  • 家政预约小程序09服务管理
  • 使用Redis缓解数据库压力+三种常见问题
  • 【C++图论 最短路】2642. 设计可以求最短路径的图类|1810
  • 蓝桥杯3519 填充 | 分类讨论
  • 大型齿轮箱健康监测与智能维护系列套件:测试台+故障诊断算法工具箱+齿轮箱智能维护系统平台+案例分析
  • 数字MIC PDM接口
  • 【探索前端技术之 React Three.js—— 简单的人脸动捕与 3D 模型表情同步应用】
  • 【Web开发】一步一步详细分析使用Bolt.new生成的简单的VUE项目