Golang 限流器 time/rate 实现剖析

2019-11-05 13:42:26 +08:00
 cyhone

限流器是微服务中必不缺少的一环,可以起到保护下游服务,防止服务过载等作用。上一篇文章《 Golang 限流器 time/rate 使用介绍》简单介绍了 time/rate 的使用方法,本文则着重分析下其实现原理。建议在正式阅读本文之前,先阅读下上一篇文章。

上一篇文章讲到,time/rate 是基于 Token Bucket(令牌桶)算法实现的限流。本文将会基于源码,深入剖析下 Golang 是如何实现 Token Bucket 的。其代码也非常简洁,去除注释后,也就 200 行左右的代码量。

同时,我也提供了time/rate 注释版,辅助大家理解该组件的实现。

点击查看原文

3604 次点击
所在节点    Go 编程语言
5 条回复
cyhone
2019-11-05 13:43:04 +08:00
原文链接: https://www.cyhone.com/articles/usage-of-golang-rate/
同时欢迎关注公众号:编程沉思录
cyhone
2019-11-05 14:27:46 +08:00
上面链接发错了:

原文链接: https://www.cyhone.com/articles/analisys-of-golang-rate/
同时欢迎关注公众号:编程沉思录
golden0125
2019-11-05 14:45:50 +08:00
thanks + mark
54qyc
206 天前
burst 都当成桶容量的理解就别发文章误人子弟了,而且别人评论区都指出来了仍然固执己见。中文区就应该少点垃圾文章,自己写笔记自己乐呵就行了。
cyhone
191 天前
@54qyc 👍🏻

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/616449

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX