Python的线程12 简易限流器

Posted 雷学委

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python的线程12 简易限流器相关的知识,希望对你有一定的参考价值。

正式的Python专栏第49篇,同学站住,别错过这个从0开始的文章!

前篇学委展示了Semaphore信号量,这个工具可以让开发者设置阀值,简单的控制并发的数量。

不知道读者还记得前篇设置信号量为1的时候,三个运动员只有一个先跑了。

因为一开始给了信号量为1,所以学委还没有喊完3/2/1,就有人抢跑了。

好,拉回主题 - 限流器

什么是限流器?

大家记不记得经常坐地铁(早晚)高峰期的时候,在入口的地方就有工作人员搬了一下遮挡栏,

每次就放而二三十人进入。一般4个地铁口,两个入。两个出,出口一般没有限流,除了那种对接客运站的出口,会有限流。

限流器,就是类似的概念,程序实现这样的一个遮挡栏,实现这样的定期的放入定额数量的人员执行任务。

翻译成技术话语,那就是,一个管理机制,保证了任意时间只有最大限额数量的线程,同时做事情。

这就是限流器。

另外,我们接触的软件,其实都是生活的映射。

怎么做限流器呢?

本篇说了信号量,那么我们就用它来做吧。

信号量保证了限定数额的线程,但是它是一次性的啊。

比如下面的缺陷:

threading.Semaphore(3) #运行3个线程同时acquire不阻塞,如果有4个线程acquire将有一个线程等待。

恰好,它还给我们提供了release函数。

所以我们只要知道限额生成信号量初始值,然后在程序中不断release,这样信号量就恢复。

等候的其他线程又能获得锁,执行自己的任务了。

问题不就迎刃而解了吗?

总结

先卖个关子。下篇学委会展示怎么做的代码。

编程还是挺好玩的。 喜欢Python的朋友,请关注学委的 Python基础专栏 or Python入门到精通大专栏

持续学习持续开发,我是雷学委!
编程很有趣,关键是把技术搞透彻讲明白。
欢迎关注微信,点赞支持收藏!

以上是关于Python的线程12 简易限流器的主要内容,如果未能解决你的问题,请参考以下文章

Python的线程13 简易限流器实现

Python的线程13 简易限流器实现

Python的线程13 简易限流器实现

Go 中实现用户的每日限额(比如一天只能领三次福利)

有关子线程对UI的线程更新的说法

FlinkFlink 消费 kafka 实现 限流处理 RateLimiter