分布式思想

1、单体架构设计存在的问题

传统项目采用单体架构设计,虽然可以在一定的程度上解决企业问题,但是如果功能模块众多,并且将来需要二次开发.由于模块都是部署到同一台tomcat服务器中,如果其中某个模块代码出现了问题,将直接影响整个tomcat服务器运行.

这样的设计耦合性太高.不便于开发和维护.

2、分布式思想(拆)

2.1 分布式计算

说明: 如果某个业务需要处理1000G的数据 如果通过一个线程.该工作几乎不可能完成...

优化方式: 同时开启多个线程 一起执行任务的计算. 理论上来说运行的速度大幅度提升.

难点: 数据如何拆分/数据如何合并

计算方式: 大数据应用.

2.2 分布式系统

说明: 分布式系统指按照某种规则,将项目按照规则进行拆分.从架构上降低了系统的耦合性.提高软件的扩展性.

2.2.1 按照模块拆分

说明:按照特定的业务规则,将项目进行拆分.

2.2.2 按照层级拆分

说明: 由于某个项目比较复杂.需要多个开发人员相互配合.这时为了提高开发的效率.采用层级拆分的方式进行.

2.3分布式系统设计问题说明

铺垫: maven项目打包方式: 1.jar包(默认值) 2.war包 3.pom(聚合工程)

1).由于项目众多 如何统一的管理?

答案: 采用聚合工程的方式统一管理项目 打包方式 POM

2).项目多了之后,如何保证jar包版本的稳定?

答案: 采用统一的方式管理jar包文件 通过父级工程定义父级jar包.之后子级项目继承父级即可.

3).工具API如何做到统一的管理?

答案: 定义核心工具API工程. 架构师/高级程序员统一维护API项目. 之后API项目被其他的项目进行依赖.

2.4关于分布式系统父子级关系说明

说明: 如果搭建了父级工程 则可以通过父级检查所有的关联项目

相关推荐
sniper_fandc3 小时前
Elasticsearch从入门到进阶——分布式特性
大数据·分布式·elasticsearch
hzp6664 小时前
spark动态分区参数spark.sql.sources.partitionOverwriteMode
大数据·hive·分布式·spark·etl·partitionover
幼儿园老大*11 小时前
什么是分布式数据库?有什么优势?
数据库·分布式
武子康12 小时前
大数据-135 ClickHouse 集群连通性自检 + 数据类型避坑实战|10 分钟跑通 ON CLUSTER
大数据·分布式·后端
有谁看见我的剑了?15 小时前
Rocky 9 安装 Elasticsearch分布式集群
分布式·elasticsearch·jenkins
你总是一副不开心的样子(´ . .̫ .1 天前
消息队列Kafka
分布式·kafka
沐浴露z1 天前
Kafka入门:基础架构讲解,安装与使用
java·分布式·kafka
wu~9701 天前
Kafka底层解析:可靠性与高性能原理
分布式·kafka·操作系统
兜兜风d'1 天前
RabbitMQ 发送方确认机制详解
spring boot·分布式·rabbitmq·java-rabbitmq·1024程序员节
也许是_1 天前
Spring Boot 3.X推荐Micrometer Tracing 分布式链路追踪
spring boot·分布式·后端