CELERY WindowsError:[错误6]句柄无效

时间:2016-12-16 14:51:15

标签: windows python-2.7 celery

我是芹菜的新手,我正在按照他们网站上给出的教程我得到了这个错误

 from celery import Celery
 app = Celery('tasks', broker='pyamqp://guest@localhost//')

 @app.task
 def add(x, y):
     return x + y

和cmd显示如下错误

-------------- celery@DESKTOP-O90R45G v4.0.2 (latentcall)
---- **** -----
--- * ***  * -- Windows-10-10.0.14393 2016-12-16 20:05:48
-- * - **** ---
- ** ---------- [config]
- ** ---------- .> app:         tasks:0x4591950
- ** ---------- .> transport:   amqp://guest:**@localhost:5672//
- ** ---------- .> results:     disabled://
- *** --- * --- .> concurrency: 4 (prefork)
-- ******* ---- .> task events: OFF (enable -E to monitor tasks in this worker)
--- ***** -----  -------------- [queues]
                .> celery           exchange=celery(direct) key=celery


[tasks]   . tasks.add

[2016-12-16 20:05:49,029: CRITICAL/MainProcess] Unrecoverable error:
TypeError('argument 1 must be an integer, not _subprocess_handle',)
Traceback (most recent call last):   File
"c:\python27\lib\site-packages\celery\worker\worker.py", line 203, in
start
    self.blueprint.start(self)   File "c:\python27\lib\site-packages\celery\bootsteps.py", line 119, in
start
    step.start(parent)   File "c:\python27\lib\site-packages\celery\bootsteps.py", line 370, in
start
    return self.obj.start()   File "c:\python27\lib\site-packages\celery\concurrency\base.py", line 131,
in start
    self.on_start()   File "c:\python27\lib\site-packages\celery\concurrency\prefork.py", line
112, in on_start
    **self.options)   File "c:\python27\lib\site-packages\billiard\pool.py", line 1008, in
__init__
    self._create_worker_process(i)   File "c:\python27\lib\site-packages\billiard\pool.py", line 1117, in
_create_worker_process
    w.start()   File "c:\python27\lib\site-packages\billiard\process.py", line 122, in
start
    self._popen = self._Popen(self)   File "c:\python27\lib\site-packages\billiard\context.py", line 383, in
_Popen
    return Popen(process_obj)   File "c:\python27\lib\site-packages\billiard\popen_spawn_win32.py", line
64, in __init__
    _winapi.CloseHandle(ht) TypeError: argument 1 must be an integer, not _subprocess_handle Traceback (most recent call last):   File
"<string>", line 1, in <module>   File
"c:\python27\lib\site-packages\billiard\spawn.py", line 159, in
spawn_main
    new_handle = steal_handle(parent_pid, pipe_handle)   File "c:\python27\lib\site-packages\billiard\reduction.py", line 126, in
steal_handle
    _winapi.DUPLICATE_SAME_ACCESS | _winapi.DUPLICATE_CLOSE_SOURCE) >WindowsError: [Error 6] The handle is invalid

2 个答案:

答案 0 :(得分:2)

自{4.0}以来,Windows中不再支持Celery,如Readme中所述:

  

Celery是一个资金最少的项目,因此我们不支持Microsoft Windows。请不要打开与该平台相关的任何问题。

不幸的是,这个错误似乎是副作用之一(删除了对进程句柄的支持)

你最好的选择是降级芹菜,先把它取下来然后: pip install celery==3.1.18

答案 1 :(得分:0)

看起来你的rabbitmq服务器没有运行。你运行安装并启动rabbimq服务器吗?

您可以结帐rabbitmq docs and install it。启动rabbitmq服务器,然后使用您的应用程序启动您的芹菜工作者

celery worker -l info -A tasks