python3 rq worker 数量是多少?

2021-12-07 16:13:37 +08:00
 taomujian
def worker(listen):
    with Connection(redis_conn):
        worker = Worker(map(Queue, listen))
        worker.work()

def run ():
    listen = ['high', 'scheduler']
    try:
        cpu_num = 2
        p = Pool(cpu_num)
        for i in range(cpu_num):
            p.apply_async(worker, args=(listen,))  # 开启 worker
        p.close()
        p.join()
    except Exception as e:
        print(e)

主机为 1CPU,4 核

运行程序后,加入队列的任务有点多(500 多个),在前台看了下处于正在处理的任务有 16 个,这是怎么计算出来的啊?生产环境中用 gunicorn 部署的,fastapi 框架,gunicorn workers 为 4,threads 为 5

1402 次点击
所在节点    Python
2 条回复
deplivesb
2021-12-07 16:32:45 +08:00
gunicorn workers * cpu_core
taomujian
2021-12-07 16:34:56 +08:00
@deplivesb 这个计算方式有什么依据吗?

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/820650

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX