分布式和微服务系统区别

一、分布式是更广泛的概念,指将计算分布在多个物理节点上的系统

适用于需要高可用性、高性能、可扩展性的系统。

应用场景分布式数据库---数据高可用存储、分布式缓存---提升数据访问速度

分布式计算框架---大规模数据计算、分布式文件系统---海量数据的存储

不一定是按业务功能划分,可能只是为了提高性能或资源分担,把功能模块拆分到不同的节点中,但模块可能较大。

部署:通常涉及多个节点的配置 ,这些节点可能是集群中的服务器,也可以是不同的物理、或虚拟机。运维主要在于集群的监控、容错和资源管理



二、微服务是专注于业务模块化将应用程序划分为多个独立的小服务,每个服务围绕单一的业务

功能构建,服务之间通过轻量级协议(如:HTTP、gRPC)进行通信,更聚焦于业务层面。

核心:是通过模块化设计提高系统的灵活性、独立性,以便能独立开发、部署、测试和扩展。

每个微服务,通常负责特定的业务功能,并且有自己独立的数据库和接口

需求:适合快速变化的业务,方便单个服务的快速迭代和独立演进

应用场景电商---用户管理、商品服务、订单处理拆分为不同的微服务

金融---支付、风险控制、账户管理,独立部署和管理

强调将系统,按业务功能切分为更细粒度的服务,每个服务尽量独立和自治

部署:更加灵活,利用**容器技术实现资源隔离和可移植性,通常打包为容器镜像,容器封装了服务运行所需的所有依赖,确保服务可以在任何环境中稳定运行。高度依赖CI/CD流水线,**使用Jenkins、GitLab CI等工具实现自动化的代码构建、测试和发布。强调自动化运维

相关推荐
XianxinMao15 分钟前
2024大模型双向突破:MoE架构创新与小模型崛起
人工智能·架构
Icoolkj1 小时前
微服务学习-SkyWalking 实时追踪服务链路
学习·微服务·skywalking
李匠20241 小时前
云计算架构学习之LNMP架构部署、架构拆分、负载均衡-会话保持
学习·架构·云计算
周杰伦_Jay3 小时前
详细介绍:Kubernetes(K8s)的技术架构(核心概念、调度和资源管理、安全性、持续集成与持续部署、网络和服务发现)
网络·ci/cd·架构·kubernetes·服务发现·ai编程
想做富婆4 小时前
大数据,Hadoop,HDFS的简单介绍
大数据·hadoop·分布式
幼儿园老大*4 小时前
【系统架构】如何设计一个秒杀系统?
java·经验分享·后端·微服务·系统架构
霍格沃兹测试开发学社测试人社区4 小时前
软件测试丨消息管道(Kafka)测试体系
软件测试·分布式·测试开发·kafka
周杰伦_Jay5 小时前
详细介绍:云原生技术细节(关键组成部分、优势和挑战、常用云原生工具)
java·云原生·容器·架构·kubernetes·jenkins·devops
weisian1516 小时前
消息队列篇--原理篇--RocketMQ和Kafka对比分析
分布式·kafka·rocketmq