locust之greenlet介绍(11)

16 篇文章 11 订阅 ¥19.90 ¥99.00
本文深入介绍了locust性能测试中的greenlet概念,解释了greenlet如何通过协程实现并发,避免了IO阻塞带来的性能损失。通过示例展示了greenlet的switch机制,强调了switch不是函数调用,并讨论了greenlet在实际使用中的局限性和gevent的必要性。
摘要由CSDN通过智能技术生成

根据源码,我们来到了下面这一段代码:

main_greenlet = runner.greenlet

OK,终于来到了我们的greenlet了。这是locust灵魂所在,没它,就没所谓的并发了。runner从它的父类Runner继承而来的greenlet属性,就是Group()。至于Group类的源码我们就不一一呈现在此了。

我们先简单介绍一下gevent:

由于之前我们介绍过yield和yield from,所以这里就不长篇大论copy文章了。总结一句话就是,通过它,使得我们的线程变成了协程,遇到IO阻塞的时候我们的cpu马上去干别的事情,等IO工作结束了,我们再回来接收下一步工作。这样我们就可以充分利用我们的cpu,并且减少了内核切换引起的性能开销。而yield显得太过低级了,所以我们就用上了gevent,它能给予我们更多的支持。

gevent的核心来自类Greenlet,而它继承greenlet。所以我们首先介绍一下greenlet的基本用法吧。

 

  • greenlet

greenlet是一个python的c扩展,我们之前通过yield 只能将结果返回给调用者&

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值