请说一下你对分布式和微服务的理解

devtools/2025/3/4 8:45:51/

分布式系统

定义

分布式系统由多个独立计算机(节点)组成,这些节点通过网络通信协作完成任务,对外表现为一个整体。

特点

  1. 分布性:节点分布在不同的物理位置。

  2. 并发性:多个节点可以同时执行任务。

  3. 透明性:用户无需关心系统的分布细节。

  4. 容错性:部分节点故障时,系统仍能运行。

优点

  • 可扩展性:通过增加节点提升系统性能。

  • 高可用性:节点故障时,系统仍能提供服务。

  • 资源共享:节点可以共享计算和存储资源。

挑战

  • 一致性:保持数据一致性较复杂。

  • 网络延迟:节点通信可能受网络延迟影响。

  • 故障处理:节点故障的检测和恢复较为复杂。

微服务

定义
微服务是一种架构风格,将应用拆分为多个小型、独立的服务,每个服务负责特定功能,并通过轻量级协议(如HTTP)通信。

特点

  1. 独立性:每个服务独立开发、部署和扩展。

  2. 单一职责:每个服务专注于单一功能。

  3. 去中心化:服务间通过API通信,无集中控制。

  4. 技术多样性:不同服务可以使用不同的技术栈。

优点

  • 灵活性:服务可以独立更新和扩展。

  • 可维护性:代码库较小,易于维护。

  • 容错性:单个服务故障不会影响整个系统。

挑战

  • 复杂性:服务间通信和协调增加了系统复杂性。

  • 数据一致性:跨服务事务管理较为复杂。

  • 运维难度:需要管理多个服务的部署和监控。

分布式系统与微服务的关系

总结

  • 分布式系统:通过多节点协作提升性能和可用性,适合大规模、高并发的场景。

  • 微服务:通过服务拆分提升灵活性和可维护性,适合复杂、快速迭代的应用。

两者结合能构建出高性能、高可用且易于维护的系统。


http://www.ppmy.cn/devtools/164415.html

相关文章

如何将hf-mirror.com作为vllm默认的下载源? conda如何移除虚拟环境?conda 如何复制一份虚拟环境?

前言 上回咱说道,如果你没办法访问huggingface.co,则可以把modelscope作为vllm默认的下载源。 但如果你非得用你用不了的huggingface.co呢?那你可以考虑将hf-mirror.com作为vllm默认的下载源。这里,hf-mirror.com和huggingface.co的效果是一样的。 要将hf-mirror.com设为v…

实战 Elasticsearch:快速上手与深度实践-2.2.2线程池配置与写入限流

👉 点击关注不迷路 👉 点击关注不迷路 👉 点击关注不迷路 文章大纲 Elasticsearch批量写入性能调优:2.2.2 线程池配置与写入限流深度实践1. 线程池核心机制解析1.1 Elasticsearch线程池架构1.2 Bulk线程池工作模型 2. 写入场景线程…

LeetCode 21. 合并两个有序链表(Python)

将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 输入:l1 [1,2,4], l2 [1,3,4] 输出:[1,1,2,3,4,4] 示例 2: 输入:l1 [], l2 [] 输出:[] 示例 3: 输…

蓝桥备赛(六)- C/C++输入输出

一、OJ题目输入情况汇总 OJ(online judge) 接下来会有例题 , 根据一下题目 , 对这些情况进行分析 1.1 单组测试用例 单在 --> 程序运行一次 , 就处理一组 练习一:计算 (ab)/c 的值 B2009 计算 (ab)/c …

Minio搭建并在SpringBoot中使用完成用户头像的上传

Minio使用搭建并上传用户头像到服务器操作,学习笔记 Minio介绍 minio官网 MinIO是一个开源的分布式对象存储服务器,支持S3协议并且可以在多节点上实现数据的高可用和容错。它采用Go语言开发,拥有轻量级、高性能、易部署等特点,并且可以自由…

工程化与框架系列(6)--前端模块化工程详解

前端模块化工程详解 🧩 前端模块化是现代Web开发的核心理念之一,它帮助我们组织和管理日益复杂的前端代码。本文将详细探讨前端模块化工程的各个方面,从基础概念到实际应用。 模块化概述 🌟 💡 小知识:模…

每日一题——接雨水

接雨水问题详解 问题描述 给定一个非负整数数组 height,表示每个宽度为 1 的柱子的高度图。计算按此排列的柱子,下雨之后能接多少雨水。 示例 示例 1: 输入:height [0,1,0,2,1,0,1,3,2,1,2,1] 输出:6 解释&#…

Ubuntu 下 nginx-1.24.0 源码分析 - ngx_str_rbtree_insert_value

ngx_str_rbtree_insert_value 声明 在 src\core\ngx_string.h void ngx_str_rbtree_insert_value(ngx_rbtree_node_t *temp,ngx_rbtree_node_t *node, ngx_rbtree_node_t *sentinel); ngx_str_node_t *ngx_str_rbtree_lookup(ngx_rbtree_t *rbtree, ngx_str_t *name,uint32_t …