重复请求处理和幂等处理有什么共性和区别

重复请求处理和幂等处理的共性:1、目的相同;2、处理内容相同。重复请求处理和幂等处理的区别:1、应用场景不同;2、处理方式不同。目的相同是指重复请求处理和幂等处理都是为了保证接口的正确性和一致性。

一、重复请求处理和幂等处理的共性

1、目的相同

重复请求处理和幂等处理都是为了保证接口的正确性和一致性。

2、处理内容相同

重复请求处理和幂等处理都是处理重复的请求,避免在重复请求时出现不必要的数据重复提交、重复处理等问题,从而确保接口对数据的操作具有准确性和安全性。

二、重复请求处理和幂等处理的区别

1、应用场景不同

重复请求处理:是在第一次请求已经成功的情况下,人为的进行多次操作,导致不满足幂等要求的服务多次改变状态。

幂等处理:第一次请求不知道结果(比如超时)或者失败的异常情况下,发起多次请求,目的是多次确认第一次请求成功,却不会因多次请求而出现多次的状态变化。

2、处理方式不同

重复请求处理:通过限制重复请求的发送次数和时间间隔,避免对服务器端造成不必要的负担。

幂等处理:针对接口操作在执行多次时返回结果一致的需求进行设计,即使同样的操作请求被发送多次,只要第一次请求成功执行后,后续的请求都应该返回同样的结果。同时,幂等处理要求对接口操作的所有可能结果都需要具有唯一性,从而避免因为重复请求导致数据重复或者出现不符合预期的操作结果。

三、重复处理请求的三种方式

1、前端ajax处理

方式为ajax防止重复提交。优点是前端可在用户点击之后将按钮锁定,不可点击,直到后端返回数据才释放锁。前端处理是最为简单有效,且对用户比较友好的方式。可用提示语提醒用户等待;缺点是无法应对直接刷后端接口的情况,如果用户直接调后端接口,无法处理(属于特殊情况)。

2、后端AOP处理

方式为自定义注解+AOP。后端处理逻辑是需要使用额外的存储数据,记录用户访问接口次数。在重复提交时拦截请求,对于重复的请求直接返回就行,不做任何处理。

3、数据库唯一索引

数据库处理就是设置唯一索引,可设联合唯一索引用来处理重复数据。缺点是如果业务场景就是应该存储重复的数据,则该种方式不可用。

四、幂等处理简介

幂等概念来自数学,表示N次变换和1次变换的结果是相同的。这里讨论在某些场景下,客户端在调用服务没有达到预期结果时,会进行多次调用,为避免多次重复的调用对服务资源产生副作用,服务提供者会承诺满足幂等。

HTTP/1.1中对幂等性的定义是:一次和多次请求某一个资源对于资源本身应该具有同样的副作用(网络超时等问题除外)。也就是说,其任意多次执行对资源本身所产生的影响均与一次执行的影响相同。
Methods can also have the property of “idempotence” in that (aside from error or expiration issues) the side-effects of N > 0 identical requests is the same as for a single request.
这里需要关注几个重点:

  1. 幂等不仅仅只是一次(或多次)请求对资源没有副作用(比如查询数据库操作,没有增删改,因此没有对数据库有任何影响)。
  2. 幂等还包括第一次请求的时候对资源产生了副作用,但是以后的多次请求都不会再对资源产生副作用。
  3. 幂等关注的是以后的多次请求是否对资源产生的副作用,而不关注结果。
  4. 网络超时等问题,不是幂等的讨论范围。

幂等性是系统服务对外一种承诺(而不是实现),承诺只要调用接口成功,外部多次调用对系统的影响是一致的。声明为幂等的服务会认为外部调用失败是常态,并且失败之后必然会有重试。

延伸阅读

幂等的不足

幂等是为了简化客户端逻辑处理,却增加了服务提供者的逻辑和成本,是否有必要,需要根据具体场景具体分析,因此除了业务上的特殊要求外,尽量不提供幂等的接口。

  1. 增加了额外控制幂等的业务逻辑,复杂化了业务功能
  2. 把并行执行的功能改为串行执行,降低了执行效率。

文章标题:重复请求处理和幂等处理有什么共性和区别,发布者:Z, ZLW,转载请注明出处:https://worktile.com/kb/p/48316

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
Z, ZLWZ, ZLW认证作者
上一篇 2023年3月31日
下一篇 2023年3月31日

相关推荐

  • 小学生编程网课有什么用

    小学生参加编程网课主要具有三个用处:1、培养逻辑思维能力 2、提高问题解决能力 3、加强信息技术应用能力。专注于第一点,编程是解决问题的过程,在学习编程的过程中,学生会学会如何分析问题,并通过编写代码来解决问题。这一过程能大大提升他们的逻辑思维能力。通过不断地练习与尝试,学生能够学会如何将复杂的问题…

    2024年4月30日
    1200
  • 核桃编程有什么好玩的编程

    核桃编程拥有多种引人入胜的编程课程,其中之一就是以游戏化的学习过程,激发孩子们的编程兴趣。通过色彩缤纷、互动性强的编程界面,孩子们可以在解决问题和挑战中享受编程的乐趣,同时学习到计算机编程的基础知识和逻辑思维能力的提升。这种教学方法不仅能够让孩子们在游戏中轻松学习,而且还能培养他们的创造性和问题解决…

    2024年5月1日
    500
  • 项目管理有限公司怎么注册

    项目管理有限公司注册遵循流程包含:1、选定公司名称和注册地址、2、确定公司经营范围及注册资本、3、筹备公司章程及各位股东的信息、4、办理工商登记并领取营业执照、5、刻制公司印章、6、开设银行基本账户、7、进行税务登记、8、申请相关行业许可证(如果需要的话)。在这里,特别强调确定经营范围是关键步骤,因…

    2024年1月8日
    30000
  • 小学生智能编程代码是什么

    小学生智能编程代码通常是由易于理解和使用的编程语言、教育工具和环境组成,旨在激发孩子们的兴趣,培养解决问题的能力,并为进一步的编程学习打下坚实的基础。 其中,Scratch作为MIT媒体实验室开发的一种图形化编程工具,广泛用于儿童编程教育。使用Scratch,学生可以通过拖拽代码块来构建程序,无需担…

    2024年4月28日
    3000
  • 计算机编程考什么系的

    计算机编程主要考的是计算机科学与技术系。 其中,算法设计与分析是非常重要的一环。算法设计与分析不仅要求学生掌握各种算法的设计技巧,还要求能够对算法的性能进行深入分析。这一领域教授如何将复杂问题简化,并用最有效的方法解决问题。掌握良好的算法设计技巧,对于提升编程效率和程序性能至关重要,这也是软件开发和…

    2024年4月28日
    2800
  • rate编程中什么意思

    在编程中,rate常指代速率或比率,它可以是执行某个操作或事件发生的频率、数据传输的速度,或是任何两个量的比值。 比如,在网络编程中,rate可能代表数据下载或上传的速度,而在游戏开发中,它可能指游戏帧的刷新率。详细地说,如果我们考虑一个在线流媒体服务,rate可能就是指视频数据流的比特率,这直接影…

    2024年4月27日
    3000
  • 甲方如何做好工程项目安全管理

    甲方在工程项目中确保安全管理的有效实施,首要步骤包括制定全面的安全管理计划、建立健全的安全监督机制、强化安全文化的培养等。这些措施的核心在于打造一个预防为主、综合治理的安全管理体系。制定全面的安全管理计划尤为重要,它包括安全目标的设定、风险识别与评估、安全措施的实施与监控、事故应急响应计划等,为工程…

    2024年4月11日
    10700
  • mastercam铰刀什么编程

    在Mastercam中为铰刀进行编程时,1、选择正确的铰刀尺寸和2、定义适当的刀具路径策略是两个至关重要的步骤。在操作上,确保铰刀能够按照既定路径移动,并且能在材料中正确进行切削。 在铰刀编程中,一个重要的考量点是选择合适的进给速度和转速,这对于避免切削中的过热和提高表面精度至关重要。具体步骤包括设…

    2024年5月2日
    500
  • 代码编程入门先学什么语言

    对于刚入门的编程学习者而言,选择合适的语言至关重要。主流的选择可以归结为1、Python;2、JavaScript;3、Java。对于其中的Python,以其人性化的设计和简洁的语法特点,被广泛认为是初学者的最佳选择。Python的设计哲学强调代码的可读性和简洁性,这对于初学者来说意味着更容易理解和…

    2024年4月27日
    2900
  • 做界面用什么编程语言好

    界面编程推荐使用以下语言:1、HTML/CSS/JavaScript、2、Python、3、Java、4、Swift、5、C#。具体选择哪种语言取决于开发的应用类型和平台要求。以HTML/CSS/JavaScript为例,它们是构建网页和网页应用的基础技术,强大的跨平台能力使得开发者可以设计出响应迅…

    2024年4月27日
    2600

发表回复

登录后才能评论
注册PingCode 在线客服
站长微信
站长微信
电话联系

400-800-1024

工作日9:30-21:00在线

分享本页
返回顶部