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

9 篇文章 0 订阅
2 篇文章 0 订阅
本文探讨了编程中的关键思想,如拆分以解耦,隔离以减少影响,补偿以处理错误,以及限流以控制资源。通过实例阐述这些思想在微服务、分布式事务和API管理中的应用。
摘要由CSDN通过智能技术生成

背景

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

思想方法

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

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

思想展开

拆分

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

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

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

隔离

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

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

补偿

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

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

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

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

限流

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

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

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

        

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值