簡體   English   中英

為什么使用 gevent.joinall() 而不是 pool.imap_unordered() 來運行 Greenlets?

[英]Why Use gevent.joinall() Instead of pool.imap_unordered() to Run Greenlets?

標題說明了一切。 與 gevent.joinall() 相比,使用屬於 gevent.Pool 的方法之一在池中並行(排序)運行 greenlets 似乎更好更快。 每種方法的優缺點是什么?

我認為關鍵的區別不是原始性能,而是性能管理。 當您使用 gevent.joinall() 時,您必須自己管理一次存在多少綠葉。 天真的實現將創建計算請求可能需要的數量。

另一方面,gevent.Pool 可以很容易地配置為限制同時運行的數量,從而防止您的應用程序在資源不足的情況下運行。

像往常一樣,這是權衡。 您的池可能運行速度較慢,因為它可能不會像使用 gevent.joinall() 的幼稚實現那樣允許運行盡可能多的 greenlet,但是,您不太可能在資源不足的情況下運行應用程序(並級聯到其他錯誤)。

最終,您必須回答這樣的問題:您是否可能收到過多的請求? 你有足夠的資源可以利用嗎? 原始峰值性能比平均可靠性更重要嗎?

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM