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

分布式系统架构

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

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

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

tex 复制代码
xxx-common: pojo,utils,config
xxx-system: pojo,dao,service
xxx-admin : controller

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

简单举例。

创建项目

父级配置

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

子级配置

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

三者的依赖关系

xml 复制代码
<!-- 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

运行项目

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

相关推荐
S***26754 小时前
基于SpringBoot和Leaflet的行政区划地图掩膜效果实战
java·spring boot·后端
马剑威(威哥爱编程)4 小时前
鸿蒙6开发视频播放器的屏幕方向适配问题
java·音视频·harmonyos
JIngJaneIL4 小时前
社区互助|社区交易|基于springboot+vue的社区互助交易系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·社区互助
V***u4534 小时前
MS SQL Server partition by 函数实战二 编排考场人员
java·服务器·开发语言
这是程序猿5 小时前
基于java的ssm框架旅游在线平台
java·开发语言·spring boot·spring·旅游·旅游在线平台
i***t9195 小时前
基于SpringBoot和PostGIS的云南与缅甸的千里边境线实战
java·spring boot·spring
k***08295 小时前
【监控】spring actuator源码速读
java·spring boot·spring
麦麦鸡腿堡5 小时前
Java_网络编程_InetAddress类与Socket类
java·服务器·网络
vx_dmxq2116 小时前
【PHP考研互助系统】(免费领源码+演示录像)|可做计算机毕设Java、Python、PHP、小程序APP、C#、爬虫大数据、单片机、文案
java·spring boot·mysql·考研·微信小程序·小程序·php
5***g2986 小时前
新手如何快速搭建一个Springboot项目
java·spring boot·后端