![]() | 1 blodside 2020-01-20 10:39:10 +08:00 Python 那些协程实现最大的问题是:代码里的其他依赖可能不支持协程,打补丁偶尔会出千奇百怪的错 ps: 我研究了一段时间,发现还是 Twisted 更好用 |
![]() | 2 ipwx 2020-01-20 10:46:09 +08:00 我觉得也只有自己撸一个了。。。 @blodside 这个我觉得问题不大,你可以把其他代码放进 thread executor 或者 process executor 里面。反正你其他依赖不支持携程,理论上不也不支持 Twisted callback 么( doge ) |
![]() | 3 ClutchBear 2020-01-20 10:46:12 +08:00 换 golang? |
![]() |   4 TypeError 2020-01-20 10:47:29 +08:00 @blodside #1 asyncio + concurrent.futures "其他依赖可能不支持协程"有什么关系 |
![]() | 5 niubee1 2020-01-20 10:48:02 +08:00 为啥对协程有这么大的执念?用多进程不香么? |
6 bfpiaoran OP @ClutchBear golang 短期不想换啊 |
7 bfpiaoran OP @blodside 对 celery 总是出现些奇怪的内存泄露 worker 收不到任务的问题 然后试了下 huey 啥的对 asyncio 支持也是特别差 还有的队列本身用的就是异步 event 也会出现莫名其妙的问题 |
8 bfpiaoran OP @niubee1 有的节点没法开多进程呀 核心本身就低 效率更低了 不如多线程呢 但是多线程 lock 的问题又不想搞 所以就这样了 |
![]() | 9 Vegetable 2020-01-20 10:52:07 +08:00 你的主要诉求是?队列操作一般算不上是 io 吧 |
![]() | 10 Vegetable 2020-01-20 10:57:14 +08:00 是要任务队列不是消息队列啊..这个可能会复杂不少没有了解了 |
14 hankai17 2020-01-20 11:11:47 +08:00 gevent? |
![]() | 15 wangyzj 2020-01-20 11:12:24 +08:00 虽然不是不可以,但是你这个需求是要满足多大的量?不能横向扩展么? |
![]() | 16 dsphper 2020-01-20 11:16:04 +08:00 ???看半天看得我糊涂,celery 内存泄露 worker 收不到任务???这和协程有一毛钱的关系吗?很明显你写的代码有问题把 worker 卡死了,兄弟你得把基础打牢,最起码明白多进程多线程协程的基础原理,才能写出优质的代码。不要看网上那些乱七八糟的文章对个协程无脑吹(都是一些不经脑子跟风的),就感觉协程是个万能药。 |
![]() | 17 flynaj 2020-01-20 11:21:37 +08:00 via Android python 入门简单,真做产品你还是 golang 高效 |
18 hehe12dyo 2020-01-20 11:22:16 +08:00 建议换 go。。。 |
19 watsy0007 2020-01-20 11:37:53 +08:00 不如把问题发出来. 下面回复换 go 的是认真的吗? |
20 wdf86 2020-01-20 11:50:13 +08:00 能不能说一下队列和协程具体的关系? |
21 lolizeppelin 2020-01-20 12:23:01 +08:00 via Android OpenStack 用 eventlet 你说呢 |
22 whi147 2020-01-20 15:04:54 +08:00 建议换 cpp |
![]() | 23 keepeye 2020-01-20 15:34:41 +08:00 |
24 sylvos 2020-01-20 17:20:31 +08:00 via iPhone Arq |
![]() | 25 hj24 2020-01-20 17:45:40 +08:00 via iPhone gevent 或者 asyncio 提供的 queue 不可以吗?还是说楼主都试过了,不满意的点在哪里? |
![]() | 26 wzwwzw 2020-01-21 12:54:29 +08:00 rabbitmq 之类的应该有异步链接库吧,自己撸一个吧。目前看 asyncio 的库还不够生产用。 |
![]() | 27 Leigg 2020-01-21 14:13:46 +08:00 via Android 用过哪些,为什么不行? |
28 guochao 2020-01-22 09:57:48 +08:00 我自己闲的时候写的东西也是需要些并发啊什么的。一开始用 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 不开进程线程的话是单线程的。我就不多提这个了 |