Golang: 使用 WaitTimeSeconds 和 Context 参数设置 SQS ReceiveMessage 请求超时
来源:stackoverflow
时间:2024-03-26 14:27:34 268浏览 收藏
在使用 Go 语言调用 SQS ReceiveMessage 请求时,可以使用 WaitTimeSeconds 参数设置轮询超时,或者使用 Context 参数附加自定义超时。虽然 WaitTimeSeconds 专用于 SQS 队列的长轮询,但 Context 具有更广泛的用途,包括在多线程应用程序中取消请求。因此,WaitTimeSeconds 和 Context 并不重叠,根据特定场景的需求使用不同的选项是有道理的。
我可以调用 sqs receivemessage
sqs.receivemessageinput{ queueurl: &mysqr.poolqurl, maxnumberofmessages: 1, waittimeseconds: 5, }
和 context.todo(),或与
ctx := context.Background() ctx2, cfn := context.WithTimeout(ctx, time.Second * 5) defer cfn() rmo, err := svc.ReceiveMessage(ctx2, &rmi)
假设 5 秒内没有任何内容可供阅读。
在第一种情况下,它返回正常,没有消息,也没有错误,在第二种情况下,我收到 operation 错误 sqs: receivemessage, https 响应错误 statuscode: 0, requestid: ,已取消,上下文截止日期超出
。
aws 将上下文放入 go sdk 中,这很好,但我宁愿使用 waittimeseconds 参数,它感觉更简单。是否有充分的原则理由来使用 context
方法?
正确答案
AWS 将上下文放入 go SDK 中,这真是太好了
您将 WaitTimeSeconds
(ReceiveMessages
API 的一部分)与您可以可能附加到上下文的超时混为一谈。
WaitTimeSeconds 是长轮询 SQS 队列的重要组成部分。如果没有它,空队列将导致消费者尽快发出 api 请求,从而在 AWS 上带来巨大的负载。超过 WaitTimeSeconds
并不表示出现错误 - 在性能下降的网络上,该请求甚至可能需要额外花费很多秒。
上下文可用于出于 SDK 本身领域之外的原因中止 SDK 操作 - WithTimeout
只是上下文的一种此类用途。在多线程应用程序中,您还可以使用上下文来取消由于应用程序中其他地方的某些致命错误而导致的多个未完成的请求。
因此,首先,将 WaitTimeSeconds
视为超时是不正确的。其次,将 Context
视为超时也是不正确的 - 上下文不仅仅是控制最大运行时间。
但我宁愿使用 WaitTimeSeconds 参数,它感觉更简单。
他们做不同的事情。 Context.WithTimeout
不会消除 WaitTimeSeconds
。如果没有 WaitTimeSeconds
(或队列上的默认设置),ReceiveMessages
将立即返回,并且 Context.WithTimeout
将永远没有机会超时。
是否有充分的原则性理由来使用上下文方法?
所以不,当然不是。除了 WaitTimeSeconds
之外,还有充分的理由使用上下文 - 在某些情况下,甚至 Context.WithTimeout
也可能对 ReceiveMessages
请求有意义。但即使它们都需要持续时间,用例也没有重叠。无论有没有上下文,在 WaitTimeSeconds
设置为 0 的情况下运行 ReceiveMessages
几乎都不正确。
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。
-
502 收藏
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
139 收藏
-
204 收藏
-
325 收藏
-
477 收藏
-
486 收藏
-
439 收藏
-
357 收藏
-
352 收藏
-
101 收藏
-
440 收藏
-
212 收藏
-
143 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习