news 2026/2/25 2:11:51

服务架构相关知识及演进

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
服务架构相关知识及演进

1. 基本概念

  • 应用(Application)/ 系统(system)
    完成一整套服务的一个程序或一组相互配合的程序群

  • 模块(Module)/ 组件(Component)
    应用程序复杂时,会将其划分不同的部分,这种有清晰职责,内聚性强的部分,就模块。
    例如:单细胞生物只靠一个细胞就能生存,而人这样的生物,却有不同的器官和组织,分别负责不同的功能。

  • 分布式(Distributed)
    系统中的模块不在同一服务器上,就是分布式系统。

  • 集群(Cluster)
    部署于多台服务器上,实现某一特定目标的组件,的这一个整体称为集群。
    如:将多个 mysql 部署到不同服务器上,共同提供数据库相关服务,就可以称为一组数据库集群。

  • 主(Master)/ 从(Slave)
    集群中,通常有一个要承担相对更多的职责,称为主,其余承担附属职责的称为从。
    如:MySQL集群中,一台服务器上允许数据的写入,其他数据库的数据变动是从该台中同步来的,这里允许写的就是主,其余为从

  • 中间件(Middleware)
    一类用于不同应用相互通信的软件,即不同技术,工具,数据库间的桥梁。
    如:饭店的前台就是顾客和后厨的中间件,负责将顾客要的菜转达给后厨。

  • 评价指标(Metric)

    • 可用性(Availability)
      单位时间内,系统正常服务的值 / 期望值。
    • 响应时长(Response Time RT)
      用户完成输入到系统给用户响应的时长。
    • 吞吐(Throuhput)vs 并发(Concurrent)
      吞吐:单位时间段内,系统可成功处理的请求数
      并发:系统同一时刻支持的最大请求量

2. 架构演进

2.1 单机架构

所有服务全在一台服务器上

2.2 应用数据分离架构

应用和数据库部署在不同服务器上,应用服务通过网络访问数据

2.3 应用服务集群架构

将应用服务部署到多台服务器上,构成集群。
通过算法,进行流量分配给集群中的服务器。
常见算法:

  • Round—Robin 轮询算法:平等的将请求分发给不同服务器
  • Weight—Round——Robin 轮询算法:不同服务器赋不同权重,进行请求分别
  • 一致哈希散列算法:通过计算用户的特征值(如 IP 地址)得 哈希值,根据哈希值分发请求,优点:相同客户的请求总是被分给指定的服务器

2.4 读写分离/主从架构

保留⼀个主要的数据库作为写入数据库,其他的数据库作为从属。
数据库。从库的所有数据全部来自主库的数据,经过同步后,从库可以维护着与主库⼀致的数据。

2.5 引入缓存——冷热分离架构

读取频率远大于其他数据的称为热点数据,相对的则是冷数据。
将热点数据存入缓存中,一方面可以提升读取响应时间;另一方面,在请求到数据库前就被处理了,降低数库压力。

2.6 垂直分库

将不同业务的数据存储到不同的数据库中,在这一类数据放在多个数据库中。

2.7 业务拆分 — 微服务

将不同业务进行拆分,每个业务有自己的缓存和存储,不同业务间数据不能直接访问,业务间通过 Gateway,消息总线等技术,相互调用关联。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/22 16:25:25

vue基于Spring Boot框架的在线电影票购买系统的设计与实现_8xxt52nn

目录具体实现截图项目介绍论文大纲核心代码部分展示项目运行指导结论源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作具体实现截图 本系统(程序源码数据库调试部署讲解)同时还支持java、ThinkPHP、Node.js、Spring B…

作者头像 李华
网站建设 2026/2/22 17:06:52

在服务器上安装 aaPanel

aaPanel 官方文档: https://www.aapanel.com/docs/guide/quickstart.html 下载与安装脚本页: https://www.aapanel.com/new/download.html ¥7 1H1G服务器购买:https://hostvds.com/?affiliate_uuidfbff2c4f-05e9-42e0-9e16-c07…

作者头像 李华
网站建设 2026/2/22 12:54:53

Week 29: 深度学习补遗:MoE的稳定性机制与路由策略实现

文章目录Week 29: 深度学习补遗:MoE的稳定性机制与路由策略实现摘要Abstract1. Noisy Top-K Router1.1 理论背景1.2 代码实现2. Token 级与 Pooling 级路由2.1 理论背景2.2 代码实现3. Auxiliary Loss3.1 理论背景3.2 代码实现总结Week 29: 深度学习补遗&#xff1a…

作者头像 李华
网站建设 2026/2/22 4:24:05

25年12月14日复盘总结,大盘方向,操作建议,板块机会,实用干货

25年12月14日复盘总结,大盘方向,操作建议,板块机会,实用干货大盘指数经过近一个季度回调半指的风险得到了极大的释放,指数走出了三段4的调整,那在这个位置我们就不应该再看风险,三段4的调整已经…

作者头像 李华
网站建设 2026/2/24 18:04:26

what?动态规划?

动态规划入门:从原理到实战,吃透基础算法动态规划(Dynamic Programming,简称 DP)是算法领域的核心思想之一,也是面试、竞赛中的高频考点。它并非单一算法,而是一种 “化繁为简” 的解题思路 ——…

作者头像 李华
网站建设 2026/2/22 6:52:01

CommonJS 的缓存机制:为什么二次 require 得到的对象是同一个?

各位同仁,下午好!今天,我们将深入探讨 Node.js 中 CommonJS 模块系统的核心机制之一:模块缓存。这是一个看似简单却蕴含深厚设计哲学的机制,它直接决定了我们在 Node.js 应用中管理状态、优化性能以及理解模块行为的关…

作者头像 李华