跳至主要內容
  • Hostloc 空間訪問刷分
  • 售賣場
  • 廣告位
  • 賣站?

4563博客

全新的繁體中文 WordPress 網站
  • 首頁
  • Python 有啥对协程支持好的队列框架么 试了几个都不行 最近快被搞崩溃了 难道要自己撸一个
未分類
2 4 月 2020

Python 有啥对协程支持好的队列框架么 试了几个都不行 最近快被搞崩溃了 难道要自己撸一个

Python 有啥对协程支持好的队列框架么 试了几个都不行 最近快被搞崩溃了 难道要自己撸一个

資深大佬 : bfpiaoran 53

2333 rt

大佬有話說 (28)

  • 資深大佬 : blodside

    Python 那些协程实现最大的问题是:代码里的其他依赖可能不支持协程,打补丁偶尔会出千奇百怪的错
    ps: 我研究了一段时间,发现还是 Twisted 更好用

  • 資深大佬 : ipwx

    我觉得也只有自己撸一个了。。。

    @blodside 这个我觉得问题不大,你可以把其他代码放进 thread executor 或者 process executor 里面。反正你其他依赖不支持携程,理论上不也不支持 Twisted callback 么( doge )

  • 資深大佬 : ClutchBear

    换 golang?

  • 資深大佬 : TypeError

    @blodside #1 asyncio + concurrent.futures “其他依赖可能不支持协程”有什么关系

  • 資深大佬 : niubee1

    为啥对协程有这么大的执念?用多进程不香么?

  • 主 資深大佬 : bfpiaoran

    @ClutchBear golang 短期不想换啊

  • 主 資深大佬 : bfpiaoran

    @blodside 对 celery 总是出现些奇怪的内存泄露 worker 收不到任务的问题 然后试了下 huey 啥的对 asyncio 支持也是特别差 还有的队列本身用的就是异步 event 也会出现莫名其妙的问题

  • 主 資深大佬 : bfpiaoran

    @niubee1 有的节点没法开多进程呀 核心本身就低 效率更低了 不如多线程呢 但是多线程 lock 的问题又不想搞 所以就这样了

  • 資深大佬 : Vegetable

    你的主要诉求是?队列操作一般算不上是 io 吧

  • 資深大佬 : Vegetable

    是要任务队列不是消息队列啊..这个可能会复杂不少没有了解了

  • 資深大佬 : niubee1

    @bfpiaoran 你对多进程有什么误解唉

  • 主 資深大佬 : bfpiaoran

    @Vegetable 没啊 但是队列下的任务是 io 的

  • 主 資深大佬 : bfpiaoran

    @Vegetable 是的系统设计就有问题 任务队列每个人物需求不一样 打算重构一个了

  • 資深大佬 : hankai17

    gevent?

  • 資深大佬 : wangyzj

    虽然不是不可以,但是你这个需求是要满足多大的量?不能横向扩展么?

  • 資深大佬 : dsphper

    ???看半天看得我糊涂,celery 内存泄露 worker 收不到任务???这和协程有一毛钱的关系吗?很明显你写的代码有问题把 worker 卡死了,兄弟你得把基础打牢,最起码明白多进程多线程协程的基础原理,才能写出优质的代码。不要看网上那些乱七八糟的文章对个协程无脑吹(都是一些不经脑子跟风的),就感觉协程是个万能药。

  • 資深大佬 : flynaj

    python 入门简单,真做产品你还是 golang 高效

  • 資深大佬 : hehe12dyo

    建议换 go。。。

  • 資深大佬 : watsy0007

    不如把问题发出来.
    下面回复换 go 的是认真的吗?

  • 資深大佬 : wdf86

    能不能说一下队列和协程具体的关系?

  • 資深大佬 : lolizeppelin

    OpenStack 用 eventlet

    你说呢

  • 資深大佬 : whi147

    建议换 cpp

  • 資深大佬 : keepeye

    https://docs.python.org/3/library/asyncio-queue.html
    这个不是么?

  • 資深大佬 : sylvos

    Arq

  • 資深大佬 : hj24

    gevent 或者 asyncio 提供的 queue 不可以吗?还是说主都试过了,不满意的点在哪里?

  • 資深大佬 : wzwwzw

    rabbitmq 之类的应该有异步链接库吧,自己撸一个吧。目前看 asyncio 的库还不够生产用。

  • 資深大佬 : Leigg

    用过哪些,为什么不行?

  • 資深大佬 : guochao

    我自己闲的时候写的东西也是需要些并发啊什么的。一开始用 nodejs,用不熟,后来换 python,最近一两年又因为试着学 go 换成了 go。所以建议的话:

    能换 go 换 go,天生就是自己调度的协程,只要代码没问题效率就不会低。就跟具体用什么库没关系了。

    如果要用 python 的 tornado/asyncio 的话,建议用 aio-pika 这种库,或者用 aioredis 撸一个,新的 redis 自带 pub sub,不用 pubsub 也可以用 list 或者 sorted set 来做队列。另外就是上说的,注意一下别的库的实现,搞不好会给你阻塞一段,遇到这种了就用 ThreadExecutor,我们公司这边 python 的项目就是 patch 了很多同步的库然后自己用。

    node 理论上应该也还好,但是一个是我不熟悉 node,当时不知道为啥用 node 的 redis 会阻塞住,另一个是印象里 node 不开进程线程的话是单线程的。我就不多提这个了

文章導覽

上一篇文章
下一篇文章

AD

其他操作

  • 登入
  • 訂閱網站內容的資訊提供
  • 訂閱留言的資訊提供
  • WordPress.org 台灣繁體中文

51la

4563博客

全新的繁體中文 WordPress 網站
返回頂端
本站採用 WordPress 建置 | 佈景主題採用 GretaThemes 所設計的 Memory
4563博客
  • Hostloc 空間訪問刷分
  • 售賣場
  • 廣告位
  • 賣站?
在這裡新增小工具