站长资源脚本专栏

GoLang之使用Context控制请求超时的实现

整理:jimmy2025/1/11浏览2
简介起因之前接触了一个需求:提供一个接口,这个接口有一个超时时间,如果超时了返回超时异常;这个接口中调用其他的接口,如果调用超时了,所有请求全部结束。在这个接口中,我使用了go协程去调用其他接口,所以不仅涉及到请求的超时控制,而且还涉及到父协程对子协程的控制问题。在翻阅了一些资料之后,了解到了Con

起因

"color: #ff0000">Context

"text-align: center">GoLang之使用Context控制请求超时的实现

context可以进行派生,创建出子context。context有四种不同的子context:
"color: #ff0000">取消超时请求的模型

调度模型

GoLang之使用Context控制请求超时的实现
"text-align: left">其中,对于超时的判断,是根据Context中的Done管道判断的。如果超时了,则Done管道可以拿到东西。

超时之后取消请求

"text-align: center">GoLang之使用Context控制请求超时的实现"text-align: left">"color: #ff0000">结论

  该调度模型亲测之后,确实可以实现请求的超时控制。只要在最外层设置超时时间时30s,只要过了30s,所有协程中的请求都会结束,对应的协程也会相应的结束;加上Client.Do方法,将超时控制变的更加简洁,后续会写专门写一篇关于http中Client的博客,详细讲解一下Client实现超时控制的原理。