浅谈系统架构中的状态
admin
2024-02-03 19:17:14
0

背景

最近在规划一个系统的无感升级,发现了之前设计中很多的不合理的地方,

其中最为代表性的就是各种有意无意的状态,所以在这里整理一下最近的一些思考还有收获,

如果能帮到其他人就太好了。

什么是状态?

对于软件领域中系统状态是什么有没有严格的定义,我这边并没有进行彻底的调研。但本文所说的状态特指对外部有影响的状态。

比如:

  • 系统在内存中保存了目前系统时间,但这个只用来打印日志,那么我们可以说这个服务是无状态的。

  • 但如果这个时间在本系统中进行业务有没完成的依据,那么我们就可以说这个服务是有状态的。

当然计算是第二种情况,也可以通过专门的授时服务器来讲这个时间状态消除。

为什么有状态不好?

理论上,有状态的服务

  1. 无法轻易的水平扩展
  2. 无法轻易实现故障恢复

具体来说:

  • 当一个服务有了状态后,你不能简单的启动多个服务,实现性能的提升,因为这样的多个服务会导致系统内存在多个不一致的状态,从而导致系统业务逻辑的混乱。

  • 由于存储的中间件状态在故障发生时丢失,修复或在其他节点重启后无法在中断时继续服务

服务状态的常见表现形式

内部保存了业务的进度或相似信息

比如:

  • 内部开启了一个线程进行多步业务流程
  • 保存了业务的调度信息,保存了访问者的信息,根据这些信息进行判断输出

内部驱动的定时修改外部数据或外部接口

比如:

  • 定时1点备份数据库

  • 每隔10s更新一次数据库中的信息

内部驱动的定时调用外部非幂等接口

  • 每隔10s计算一次最新价格,发布消息

  • 比如早上5点发送打开某个设备的闸门的指令

对外接口包含与内部强相关的信息

比如:

  • 用本机的公钥-私钥进行加解密
  • 返回下次请求中需要访问的地址
  • 返回的结果或进行的动作跟内部的某个变量的状态有关

如何应对系统中的状态

包容

这个方向最为简单,什么都不做,其实这个是大多数场景的最佳方案,虽然从技术上来讲状态是尽量避免,但有的时候无状态话的设计成本是有状态的N倍,且无状态为该系统带来的价值无法支撑起该设计,这时候包容或是容忍系统状态化是最佳方案。

去状态

想要去除系统内的状态实在不是一件轻松的事,大体的思路都是外部化。即通过外部方式记录中间的状态,好让系统不必保存这些状态。

典型的方式:

  • 使用redis保存原来在内存中数据
  • 使用数据库来保存原来的中间业务状态
  • 使用xxl-job来替换原来在Quartz的调度或定时框架
  • 使用消息中间件来实现流程在系统中流转

选主

如果一个系统中的状态确实去不掉,就需要采用退一步的思路,这个可以参考经典的数据集群方案,一般都离不开多实例选主。

典型方式:

  • 通过Raft协议来实现动态选主的复杂方案
  • 通过zk的curator实现选主的简单方案

总结

本文探讨了系统的状态,还列出了常见的系统状态的形式,最后给出了一些改造思路或建议。

系统架构都是有生命的,需要随着业务的发展进行演进,有时间的话看看你的系统架构有没有坏味道吧。

相关内容

热门资讯

【MySQL】锁 锁 文章目录锁全局锁表级锁表锁元数据锁(MDL)意向锁AUTO-INC锁...
【内网安全】 隧道搭建穿透上线... 文章目录内网穿透-Ngrok-入门-上线1、服务端配置:2、客户端连接服务端ÿ...
GCN的几种模型复现笔记 引言 本篇笔记紧接上文,主要是上一篇看写了快2w字,再去接入代码感觉有点...
数据分页展示逻辑 import java.util.Arrays;import java.util.List;impo...
Redis为什么选择单线程?R... 目录专栏导读一、Redis版本迭代二、Redis4.0之前为什么一直采用单线程?三、R...
【已解决】ERROR: Cou... 正确指令: pip install pyyaml
关于测试,我发现了哪些新大陆 关于测试 平常也只是听说过一些关于测试的术语,但并没有使用过测试工具。偶然看到编程老师...
Lock 接口解读 前置知识点Synchronized synchronized 是 Java 中的关键字,...
Win7 专业版安装中文包、汉... 参考资料:http://www.metsky.com/archives/350.htm...
3 ROS1通讯编程提高(1) 3 ROS1通讯编程提高3.1 使用VS Code编译ROS13.1.1 VS Code的安装和配置...
大模型未来趋势 大模型是人工智能领域的重要发展趋势之一,未来有着广阔的应用前景和发展空间。以下是大模型未来的趋势和展...
python实战应用讲解-【n... 目录 如何在Python中计算残余的平方和 方法1:使用其Base公式 方法2:使用statsmod...
学习u-boot 需要了解的m... 一、常用函数 1. origin 函数 origin 函数的返回值就是变量来源。使用格式如下...
常用python爬虫库介绍与简... 通用 urllib -网络库(stdlib)。 requests -网络库。 grab – 网络库&...
药品批准文号查询|药融云-中国... 药品批文是国家食品药品监督管理局(NMPA)对药品的审评和批准的证明文件...
【2023-03-22】SRS... 【2023-03-22】SRS推流搭配FFmpeg实现目标检测 说明: 外侧测试使用SRS播放器测...
有限元三角形单元的等效节点力 文章目录前言一、重新复习一下有限元三角形单元的理论1、三角形单元的形函数(Nÿ...
初级算法-哈希表 主要记录算法和数据结构学习笔记,新的一年更上一层楼! 初级算法-哈希表...
进程间通信【Linux】 1. 进程间通信 1.1 什么是进程间通信 在 Linux 系统中,进程间通信...
【Docker】P3 Dock... Docker数据卷、宿主机与挂载数据卷的概念及作用挂载宿主机配置数据卷挂载操作示例一个容器挂载多个目...