当前位置: 首页 > news >正文

盘点编程方法论中的一些思想

背景

        在日常编程开发中,虽然不同公司,业务不同,语言不同,但是工作久了,我们会发现一些编程思想几乎是不变的。这些编程思想,往往来自于大量实际问题场景的方法总结,可以很好的应对某一类问题。如果可以很好的掌握和理解他们,将为我们处理开发中的问题,提供极大的帮助,做的有的放矢。

思想方法

        接下来就结合在实际工作中的总结和思考,盘点一下一些良好的编程思想(后续将持续补充):

  • 拆分
  • 隔离
  • 补偿
  • 限流
  • 负载均衡
  • 时空置换
  • 开关
  • 防御
  • 中介

思想展开

拆分

        拆分是编程乃至生活中最常见的一种思想。比如单体拆分为微服务、分库分表、读写分离、动静分离等,都是拆分的思想。拆分是解耦合的一种具体手段

        通常,当一个组织变得越来越庞大,组织内部往往相互影响越来越严重(内耗、冲突)。这时,就可以采用拆分的方法,将单体的组织,根据业务、共性或一些其他方面的特点,拆分为多个不同的部分,来达到解耦合的目的。以此减小相互影响和代码冲突等。

        举个实际场景的案例:在曾经的一个项目中,有同事为省事,在使用消息队列时,没有很好的根据业务拆分话题和队列,大杂烩式的使用统一的话题与队列。在一次某业务,因并发突然变大导致消息积压时,由于没有拆分,导致使用该队列的整个业务都严重受影响,体验极其差。经此一役,根据业务对消息队列做了拆分,较少了不同业务之间的影响。

隔离

        隔离,顾名思义就是将不同的部分隔离开来。和拆分关联比较密切,算是拆分的一种效果或前置思想。在编程中也是很常用的,比如动静分离(将变经常动态变化的,和静态资源做隔离)、主次隔离(将核心业务、和普通业务做隔离,避免普通业务影响核心业务的流程)等。

        隔离在编程领域的主要目的是限制或控制不同部分之间的相互影响,以期达成更高的系统弹性、可靠性和可扩展性。

补偿

        我们常说的亡羊补牢就是一种补偿思想。在编程中补偿也随处可见,比如失败重试、超时后取消、定时处理不合理数据等,都是一种补偿的思想。

        在分布式事务处理中,特别是采用TCC(Try-Confirm-Cancel)或Saga等分布式事务模式时,如果某个操作未能按预期完成,系统会触发补偿动作来撤销之前已完成的操作,以恢复系统到事务开始前的状态。

        在微服务架构中,一个服务调用另一个服务后,如果被调用的服务出现故障或返回的结果不符合预期,调用方可以根据预先设定的补偿逻辑回滚或修复因调用产生的副作用。

        补偿作为一种编程思想,主要用于应对可能出现的错误、失败或不一致状态,以确保系统具备一定的容错能力和一致性保证

限流

        限流也是常见的一种控制流程的方式,生活中比如景区限流、地铁限流等。在编程领域,限流也是经常使用,以至于作为面试八股文中的常客。

        比如,对高频访问的API接口设置每秒请求数(QPS)上限,防止因短时间内大量请求而导致服务器资源耗尽,保障核心服务的稳定性和响应速度。

        限流作为一种编程思想,在软件领域主要用于控制和管理系统的资源使用、请求处理速率和系统负载等方面,以确保系统在高并发场景下依然能够稳定运行,防止过载崩溃

        

http://www.lryc.cn/news/332770.html

相关文章:

  • 通过电机转速计算主轴旋转单圈所需时间(CODESYS ST代码)
  • 多线程的入门(二)线程实现与初步使用
  • 数据结构(初阶)第二节:顺序表
  • 鸿蒙OS元服务开发:【(Stage模型)设置应用主窗口】
  • lua学习笔记6(经典问题输出99乘法表)
  • 物联网行业中,我们如何选择数据库?
  • openstack云计算(一)————openstack安装教程,创建空白虚拟机,虚拟机的环境准备
  • Linux存储的基本管理
  • Python yield解析:深入理解生成器的魔力
  • 【Linux】GCCGDB
  • InternLM2-Chat-1.8B 模型测试
  • Flutter 关键字
  • Java常用API之Collections类解读
  • KV260 BOOT.BIN更新 ubuntu22.04 netplan修改IP
  • Android 代码自定义drawble文件实现View圆角背景
  • C#实现Word文档转Markdown格式(Doc、Docx、RTF、XML、WPS等)
  • 信息系统架构设计-以服务为中心的企业整合实践
  • mysql知识点梳理
  • 版本排序,(如果 版本 是 1,1a,1.1a, 2, 2c , 1c , 1.2a, 3 , 5b , 5)进行排序
  • Google视觉机器人超级汇总:从RT、RT-2到AutoRT、SARA-RT、RT-Trajectory
  • python笔记(9)Dictionary(字典)
  • 蓝桥杯嵌入式总结
  • 渗透测试:数据库UDF提权(linux)
  • java算法day45 | 动态规划part07 ● 70. 爬楼梯 (进阶) ● 322. 零钱兑换 ● 279.完全平方数
  • HuggingFace踩坑记录-连不上,根本连不上
  • 面试题:Spring Boot Starter的功能与使用场景
  • 上位机图像处理和嵌入式模块部署(qmacvisual之n点标定)
  • Francek Chen 的128天创作纪念日
  • PyTorch之Torch Script的简单使用
  • vscode 连接远程服务器 服务器无法上网 离线配置 .vscode-server