V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
The Go Programming Language
http://golang.org/
Go Playground
Go Projects
Revel Web Framework
cyhone
V2EX  ›  Go 编程语言

Golang 限流器 time/rate 实现剖析

  •  
  •   cyhone · 2019-11-05 13:42:26 +08:00 · 3765 次点击
    这是一个创建于 1850 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

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

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

    点击查看原文

    5 条回复    2023-10-19 16:23:44 +08:00
    cyhone
        1
    cyhone  
    OP
       2019-11-05 13:43:04 +08:00
    原文链接: https://www.cyhone.com/articles/usage-of-golang-rate/
    同时欢迎关注公众号:编程沉思录
    cyhone
        2
    cyhone  
    OP
       2019-11-05 14:27:46 +08:00
    上面链接发错了:

    原文链接: https://www.cyhone.com/articles/analisys-of-golang-rate/
    同时欢迎关注公众号:编程沉思录
    golden0125
        3
    golden0125  
       2019-11-05 14:45:50 +08:00
    thanks + mark
    54qyc
        4
    54qyc  
       2023-10-04 15:56:06 +08:00
    burst 都当成桶容量的理解就别发文章误人子弟了,而且别人评论区都指出来了仍然固执己见。中文区就应该少点垃圾文章,自己写笔记自己乐呵就行了。
    cyhone
        5
    cyhone  
    OP
       2023-10-19 16:23:44 +08:00
    @54qyc 👍🏻
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3102 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 13:47 · PVG 21:47 · LAX 05:47 · JFK 08:47
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.