分布式系统相关概念(单体、集群、分布式、分布式集群、微服务)

目录

一、互联网项目架构相关概念。(非传统项目)

(1)网站的性能指标。(高性能)

(2)高可用。

(3)可伸缩。

(4)高可扩展。

(5)安全性。

(6)敏捷性。

二、集群和分布式。

(1)集群。

(2)分布式。

(3)集群和分布式(简单图解)。

传统项目。(单机架构)

集群。

分布式。

三、架构介绍及图解。

(1)单体架构。

(2)垂直架构。

(3)分布式架构。

(4)SOA架构。

(5)微服务架构。


一、互联网项目架构相关概念。(非传统项目)

(1)网站的性能指标。(高性能)
  1. 响应时间:执行一个请求,一直到最后收到响应数据所需全部时间。
  2. 并发数:系统同时能够处理的请求数。(并发连接数(每秒服务器连接的总TCP数)、请求数QPS(每秒请求数)、并发用户数)
  3. 吞吐量:单位时间内系统能够处理的请求数量。(每秒查询数QPS、每秒事务数TPS)
(2)高可用。
  • 保证网站的服务一直可以正常的访问。
  • 集群。
(3)可伸缩。
  • 增加/减少硬件,提供/降低服务处理能力。
(4)高可扩展。
  • 系统间耦合低,方便新增/移除,增加/减少新的功能/模块。
(5)安全性。
  • 网站的安全访问和数据加密。
  • 数据的安全存储。
(6)敏捷性。
  • 随需求变更,快速的响应上线市场。

二、集群和分布式。

(1)集群。
  • 很多"人"一起,干一样的事情。

  • 一个业务模块,部署到多台服务器上。
(2)分布式。
  • 很多"人"一起,干不一样的事情。而且这些不一样的事情,合起来是一件大事情。

  • 一个大的业务系统,拆分为小的业务模块,分别部署到不同的机器上。
(3)集群和分布式(简单图解)。
传统项目。(单机架构)


*

集群。
  • 通过负载均衡统一提供访问服务,再进行转发可用节点。高性能、高可用的体现。
  • 但是伸缩性较低,因为A、B、C、D是在一个项目里面,扩展与伸缩不容易。


*

分布式。
  • A、B放在一个项目,C、D放在一个项目。然后AB可以集群,CD也可以集群。AB、CD也是分布式。这样若A、B提供的服务性能不够,再扩展一份AB到新项目即可,继续构成一个集群的环境。这是可伸缩性体现。
  • 相互拆分后,项目间的模块的耦合降低,比如需求变更:需新增一个E模块,对其他的服务是没有影响的,只需部署一个E模块。这是高扩展性体现。

三、架构介绍及图解。

(1)单体架构。
  • 优点:简单、开发部署方便、小型项目非常适合。
  • 缺点:项目启动慢(服务/模块一多,启动自然需要很多时间)、可靠性差(若A服务挂了,肯定影响其他服务)、可伸缩性差、扩展性和可维护性差、性能较低。
(2)垂直架构。
  • 垂直架构:将原先单体架构中在一起的多个模块拆分为多个独立的项目,形成多个独立的单体架构。
  • 虽解决与缓解了一些单体架构的问题,但还是存在缺点:某些重复功能太多(因为多个单体项目间并不通信,某些组件需要重复的写)。
(3)分布式架构。
  • 分布式架构:在垂直架构的基础上,将公共的业务模块抽离出来,作为独立的服务,供其他服务调用者进行消费,这样就可以实现服务的共享和重用。
  • RPC。Remote Procedure Call(远程过程调用)。有很多协议和技术都实现
    了RPC的过程。比如:HTTP REST 风格,Java RMI(远程方法调用) 规范等等。
  • 虽解决与缓解了一些垂直架构的问题,但还是存在缺点:服务的提供方一旦发生变更,所有的消费方都需要一一变更。
(4)SOA架构。
  • 通过企业服务总线,进行相互调用。
  • SOA架构(service oriented architecture,面向服务架构)。它是一个组件模型,它将应用程序的不同功能单元(服务)进行拆分,并通过这些服务之间定义良好的接口和契约联系起来。
  • ESB(企业服务总线),可以叫服务中介。主要是提供了一个服务与服务之间的交互。ESB包含的功能如:负载均衡,流量控制,加密处理,服务的监控,异常处理,监控告急等等。
  • 解决与缓解了一些分布式架构的问题。随后就演变出微服务架构。
(5)微服务架构。
  • 微服务架构是在SOA架构上做的升华。
  • 微服务架构强调的一个重点是"业务需要彻底的组件化和服务化"。原有的单个业务系统会拆分为多个可以独立开发、设计、运行的小应用。这些小应用之间通过服务完成交互和集成。
  • 微服务架构=80%的SOA服务架构思想+100%的组件化架构思想+80%的领域建模思想。

  • 特点:
  • 1、服务实现组件化:开发者可以自由的选择开发技术,也不需要协调其他团队。因为每个服务的之间的交互可以使用 REST API 进行操作。(A服务可以使用java,B服务可以使用python等等)
  • 2、去中心化:每个微服务有自己私有的数据库持久化业务数据。
  • 3、自动化部署:把应用拆分为一个一个独立的单个服务,方便自动化部署测试和运维。

  • Dubbo是SOA架构的。
  • SpringCloud是微服务架构。
相关推荐
xiaobaishuoAI21 小时前
分布式事务实战(Seata 版):解决分布式系统数据一致性问题(含代码教学)
大数据·人工智能·分布式·深度学习·wpf·geo
这儿有个昵称1 天前
互联网大厂Java面试场景:从Spring框架到微服务架构的提问解析
java·spring boot·微服务·kafka·grafana·prometheus·数据库优化
程序猿阿伟1 天前
《异步分布式训练提速关键:梯度压缩的收敛稳定性操控指南》
分布式
廋到被风吹走1 天前
【数据库】【MongoDB】全栈深度指南:文档模型到分布式集群
数据库·分布式·mongodb
Coder_Boy_1 天前
基于SpringAI的在线考试系统-DDD(领域驱动设计)核心概念及落地架构全总结(含事件驱动协同逻辑)
java·人工智能·spring boot·微服务·架构·事件驱动·领域驱动
陌路201 天前
RPC分布式通信(3)--RPC基础框架接口
分布式·网络协议·rpc
小北方城市网1 天前
SpringBoot 集成 RabbitMQ 实战(消息队列解耦与削峰):实现高可靠异步通信
java·spring boot·python·微服务·rabbitmq·java-rabbitmq·数据库架构
陌路201 天前
RPC分布式通信(1)--分布式通信讲解
分布式·网络协议·rpc
西***63471 天前
三大一体化音视频管理平台:技术特性与场景落地全解析
分布式
少许极端1 天前
Redis入门指南(六):从零到分布式缓存-数据持久化与事务
redis·分布式·缓存·事务·持久化