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

背景

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

思想方法

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

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

思想展开

拆分

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

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

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

隔离

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

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

补偿

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

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

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

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

限流

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

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

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

        

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/795589.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

关于Linux下的进程状态(进程篇)

目录 Linux操作系统的一般进程状态 关于阻塞 关于挂起 Linux内核状态源代码: 关于僵尸进程 关于孤儿进程 Linux操作系统的一般进程状态 新建:字面意思运行:task_struct结构体在运行队列中排队,就叫做运行态阻塞:等待非…

基于springboot实现学科竞赛管理系统项目【项目源码+论文说明】计算机毕业设计

基于springboot实现学科竞赛管理系统演示 摘要 随着国家教育体制的改革,全国各地举办的竞赛活动数目也是逐年增加,面对如此大的数目的竞赛信息,传统竞赛管理方式已经无法满足需求,为了提高效率,竞赛管理系统应运而生。…

计算机语言 之【C++】入门级知识讲解(命名空间,C++输入输出,缺省参数,函数重载,引用,内敛函数,auto关键字,for循环,指针空值nullptr)

三点睡六点起,阎王夸我好身体 不到三点我不睡,太平间里抢C位 一、命名空间 1.命名空间的作用 2.命名空间定义 3.命名空间使用 二、C的输入输出 1.输入输出说明介绍 2.std命名空间的使用惯例 三、缺省参数 1.缺省参数概念 2.缺省参数分类 四、…

“Linux 三剑客”,通常指的是三个经典的命令行工具:grep、sed 和 awk

1、grep: 简介:grep 是一个强大的文本搜索工具,可以用于在文件中查找匹配特定模式的行。示例: 搜索包含特定关键词的行: grep "keyword" filename 递归搜索目录下所有文件: grep -r define zj…

C++要点细细梳理(下)(内存分配、异常处理、template和文件读写)

4. 类动态内存分配 4.1 C语言动态内存分配:malloc和free 4.2 C动态内存分配:new和delete 思考:定义一个对象和定义一个普通变量有何区别? 普通变量:分配足够空间即可存放数据对象:除了需要空间,还要构造/析构 类比:…

路由策略与路由控制之双点双向重发布(OSPF-ISIS)实验

双点双向重发布在路由协议中,特别是在OSPF(开放式最短路径优先)与IS-IS(中间系统到中间系统)等协议之间,指的是在两个协议间或者两个进程间进行路由信息共享的机制。这种机制涉及到在两个不同的协议区域使用…

isc-dhcp-server DNS配置

我遇到一个有趣的问题,我先在一台Ubuntu服务器上使用isc-dhcp-server在其其中一个网口运行DHCP服务,然后我自己的笔记本电脑直连到这个网口,来上网。 本来直接就应该能上网,但是我的电脑只有在打开Clash时才能访问互联网&#xf…

【STL】栈

笔者在做下面这道题的时候想到用栈&#xff0c;但写的很麻烦 代码&#xff1a; #include<bits/stdc.h> using namespace std; #define MAXC 255 typedef int SElemType; typedef struct StackNode {SElemType data;struct StackNode *next; }StackNode,*LinkStack; bool…

算法刷题day39:树形DP

目录 引言一、病毒溯源二、没有上司的舞会三、生命之树四、树的重心 引言 今天写了个树形DP&#xff0c;就是在树上的DP&#xff0c;其实每道题的总体是一样的&#xff0c;从代码上都能看出来&#xff0c;其实写多了感觉就是背之前写过的代码&#xff0c;其实也就是别人写过的…

手机扫码获取文件怎么做?文件活码在电脑上的制作方法

现在很多人会把文件生成二维码之后&#xff0c;将二维码图片打印或者分享给其他人&#xff0c;通过扫描二维码的方式快速在手机上查看或者下载文件内容&#xff0c;从而提升文件传输的速度和效率。 制作文件活码二维码可以长期有效的扫码显示文件&#xff0c;支持多个文件存入…

如果在 Ubuntu 系统中两个设备出现两个相同的端口号解决方案

问题描述&#xff1a; 自己的移动机器人在为激光雷达和IMU配置动态指定的端口时&#xff0c;发现激光雷达和深度相机配置的 idVendor 和 idProduct 相同&#xff0c;但是两个设备都具有不同的ttyUSB号&#xff0c;如下图所示 idVendor&#xff1a;代表着设备的生产商ID,由USB设…

Linux第5课 Linux目录介绍

文章目录 Linux第5课 Linux目录介绍一、打开系统目录二、查看系统目录 Linux第5课 Linux目录介绍 系统目录就是指操作系统的主要文件存放的目录&#xff0c;目录中的文件直接影响到系统是否正常工作&#xff0c;了解这些目录的功能&#xff0c;对使用系统会有很大的帮助。 一…

c# wpf XmlDataProvider 简单试验

1.概要 2.代码 <Window x:Class"WpfApp2.Window12"xmlns"http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x"http://schemas.microsoft.com/winfx/2006/xaml"xmlns:d"http://schemas.microsoft.com/expression/blend…

NIO基础知识

在学习Netty之前先要学习一下NIO相关的知识&#xff0c;因为Netty是基于NIO搭建的一套网络编程框架。 一. NIO 基础 non-blocking io 非阻塞 IO 1. 三大组件 1.1 Channel & Buffer channel 有一点类似于 stream&#xff0c;它就是读写数据的双向通道&#xff0c;可以从…

Oracle 中 where 和 on 的区别

1.Oracle 中 where 和 on 的区别 on&#xff1a;会先根据on后面的条件进行筛选&#xff0c;条件为真时返回该行&#xff0c;由于on的优先级高于left join&#xff0c;所以left join关键字会把左表中没有匹配的所有行也都返回&#xff0c;然后生成临时表返回,执行优先级高于…

计算机接口(部分实验)

;实验三&#xff1a; ;*******************************; ;* 8255方式0的C口输入,A口输出 *; ;*******************************; io8255a equ 288h io8255c equ 28ah io8255 equ 28bhcode segmentassume cs:code start: mov dx, 28bH ;设8255为…

数据大屏:现代数据分析与可视化的重要工具

数据大屏&#xff1a;现代数据分析与可视化的重要工具 随着信息技术和数据分析的不断发展&#xff0c;数据大屏作为一种高效、直观的数据展示工具&#xff0c;越来越受到各行各业的青睐。数据大屏通过大屏幕媒介&#xff0c;利用先进的显示技术&#xff0c;将大量的数据和关键…

FPGA高端项目:解码索尼IMX327 MIPI相机+2路视频融合叠加,提供开发板+工程源码+技术支持

目录 1、前言2、相关方案推荐本博主所有FPGA工程项目-->汇总目录我这里已有的 MIPI 编解码方案 3、本 MIPI CSI-RX IP 介绍4、个人 FPGA高端图像处理开发板简介5、详细设计方案设计原理框图IMX327 及其配置MIPI CSI RX图像 ISP 处理HLS多路视频融合叠加图像缓存HDMI输出工程…

【51单片机入门记录】RTC(实时时钟)-DS1302应用

目录 一、DS1302相关写函数 &#xff08;1&#xff09;Write&#xff3f;Ds1302 &#xff08;2&#xff09;Write&#xff3f;Ds1302&#xff3f;Byte 二、DS130相关数据操作流程及相关代码 &#xff08;1&#xff09;DS1302初始化数据操作流程及相关代码 (shijian[i]/10&…

null 和 undefined 的区别

1. 前言 null 和 undefined 的区别 &#xff1f;这是一道基础面试题 很多人都会说 null 是空&#xff0c;undefined 是未定义&#xff0c;这样回答太过于笼统。 面试官反问&#xff1a;null 是空代表没有值是吧&#xff0c;undefined 是未定义也是没有值是吧&#xff0c;都是…