常见架构类型

目录

1.单机架构

2.应用数据分离架构

3.读写分离架构

4.冷热分离架构

5.垂直分库架构

6.微服务架构

7.容器编排架构


1.单机架构

单机架构是简单的将应用服务和数据库服务部署到同一台机器上。

缺点:存在很大的性能限制。


2.应用数据分离架构

引入负载均衡,将应用负载均衡式的部署到不同的服务器上。

比起单机,多了一个负载均衡模块来平衡地分配任务给不同的主机。

缺点:硬件成本上升

数据库性能存在瓶颈


3.读写分离架构

引入数据库主从模式,将写的数据库作为主数据库(只能有一个,防止脏数据),将读的数据库作为从数据库。

缺点:由于数据库数据需要同步(从库复制主库),同步存在很大的性能限制。


4.冷热分离架构

在访问数据库之前加入一个缓存库(redis),存储经常被访问的数据(热点数据),访问冷门数据时再访问数据库,从而减少数据库负载。

缺点:缓存存在击穿问题


5.垂直分库架构

一个主从数据库集群 ==> 多个负责不同功能的主从数据库集群。

缺点:代码强耦合


6.微服务架构

将应用服务拆为多个微服务,同时实现微服务复用。

也可以解决系统升级必须重构的问题和单个项目代码强耦合的问题。

缺点:运维压力很大


7.容器编排架构

借助docker等容器化技术,将应用服务打包成镜像,通过编排工具如k8s来动态分布和部署镜像。

实现快速部署,减少运维压力,并且解决配置冲突问题。

总结:本质上架构负载的提升只有两个方向:垂直方向和水平方向。

垂直方向:

通过加上层或者下层来将请求分流。

水平方向:

增加兄弟来为自己减少压力,团结力量大。

相关推荐
Dovis(誓平步青云)2 小时前
“Cloud Native English“云原生时代下的微服务架构设计:从理论到实战全解析
经验分享·微服务·云原生·架构
再拼一次吧2 小时前
微服务初步学习
微服务·云原生·架构
IT成长日记4 小时前
【Ansible基础】Ansible设计理念与无代理架构深度解析
架构·自动化·ansible·无代理
却道天凉_好个秋8 小时前
系统架构设计(九):分布式架构与微服务
分布式·架构·系统架构
渡梦酒9 小时前
软考软件评测师——计算机组成与体系结构(分级存储架构)
架构
水花花花花花10 小时前
Transformer 架构在目标检测中的应用:YOLO 系列模型解析
目标检测·架构·transformer
喵叔哟11 小时前
22.【.NET8 实战--孢子记账--从单体到微服务--转向微服务】--单体转微服务--增加公共代码
微服务·架构·.net
EulerBlind11 小时前
【架构】RUP统一软件过程:企业级软件开发的全面指南
架构
CopyLower13 小时前
Java在微服务架构中的最佳实践:从设计到部署
java·微服务·架构
却道天凉_好个秋14 小时前
系统架构设计(十一):架构风格总结2
架构·系统架构