
我想调试 worker 里面的任务,找了好久还是没有找到办法。。有大佬知道么。。
1 rogwan 2018-05-30 12:37:37 +08:00 via Android 和单独启动一个 App 没区别,直接在 pycharm 命令行中启动 celery 就可以 |
4 misaka19000 2018-05-3012:52:43 +08:00 在右上角的 edit configurations 里面应该可以设置程序的启动方式吧,在里面设置好启动 celery 的命令然后使用 pycharm 来启动应用应该就可以了 |
5 darksand OP @misaka19000 我尝试过你说的方法 但是在 [Script] 那个位置 我不知道怎么写,我找不到启动 worker 的脚本 |
6 qi1070445109 2018-05-30 12:57:48 +08:00 via Android @darksand 你把命令写脚本里不就行了? |
7 darksand OP @qi1070445109 不行 Connected to pydev debugger (build 145.971) Traceback (most recent call last): File "C:\Program Files (x86)\JetBrains\PyCharm 2016.1.3\helpers\pydev\pydevd.py", line 1531, in <module> globals = debugger.run(setup['file'], None, None, is_module) File "C:\Program Files (x86)\JetBrains\PyCharm 2016.1.3\helpers\pydev\pydevd.py", line 938, in run pydev_imports.execfile(file, globals, locals) # execute the script IOError: [Errno 2] No such file or directory: 'celery -A ics.task.example.baidu_news_task worker -E -Q baidu_news_queue -n baidu_news.%h -l info' Process finished with exit code 1 |
8 darksand OP @qi1070445109 这个位置 必须是一个脚本吧。。 |
9 wcsjtu 2018-05-30 13:02:50 +08:00 via Android celery 有多线程模式的,比多进程调试要方便很多 |
10 qi1070445109 2018-05-30 13:10:29 +08:00 via Android @darksand 是这样,那个位置就是个 py 文件,然后你把用 os 来执行 celery 的启动命令。 |
| td width="auto" valign="top" align="left"> |
12 suber 2018-05-30 13:35:10 +08:00 你调试的时候,把并发方式设置为 solo https://github.com/celery/celery/blob/master/celery/concurrency/solo.py |
13 suber 2018-05-30 13:39:03 +08:00 @darksand #7,你这个报错,如果是在 Linux 下,用 celery 命令所在的全路径。如:`/usr/local/bin/celery` |
14 darksand OP @suber 我现在是在 windows 我找到了 celery.exe 那个地方我填写 E:\Python27\Scripts\celery.exe 但是还是不行 |
15 yongzhong 2018-05-30 13:43:07 +08:00 |
16 darksand OP @suber Connected to pydev debugger (build 145.971) Traceback (most recent call last): File "C:\Program Files (x86)\JetBrains\PyCharm 2016.1.3\helpers\pydev\pydevd.py", line 1531, in <module> globals = debugger.run(setup['file'], None, None, is_module) File "C:\Program Files (x86)\JetBrains\PyCharm 2016.1.3\helpers\pydev\pydevd.py", line 938, in run pydev_imports.execfile(file, globals, locals) # execute the script File "E:/Python27/Scripts/celery.exe", line 1 SyntaxError: Non-ASCII character '\x90' in file E:/Python27/Scripts/celery.exe on line 1, but no encoding declared; see http://python.org/dev/peps/pep-0263/ for details Process finished with exit code 1 这个错。。意思这个还必须是个脚本。。exe 不行 |
17 |
18 suber 2018-05-30 13:46:03 +08:00 接#12,默认的多进程调试也是可以的。但是如果一次发多个任务,每个任务都要调试的话,需要在 pycharm 里面手动找到接收了任务的进程,然后切换并调试。 |
20 darksand OP @suber 恩 明白,但是我现在不知道如何调试。。大佬能给仔细说说吗 谢谢! 我是 windows 没有 /usr/local/bin/celery 只有 E:\Python27\Scripts\celery.exe |
21 darksand OP @suber [Script] E:\Python27\Scripts\celery.exe [Script parameters] -A ics.task.example.baidu_news_task worker -E -Q baidu_news_queue -n baidu_news.%h -l info |
22 suber 2018-05-30 14:43:46 +08:00 看你的#16 报错,pycharm 解析路径的时候有点问题。 两种方法试一下。1, 不直接填写 celery 路径,用后面的按钮,直接选择你对应路径下的 celery ; 2, 把这个路径配置到你的 windows 环境变量中,然后 script 那里直接填 celery。 |
23 qdzzyb 2018-05-30 14:50:37 +08:00 换个思路, 可以直接在解释器里同步调用任务就可以了,断点用 ipdb 好了 |
24 darksand OP 谢谢大家,已经找到在 window 下面的解决办法了 https://www.e-learn.cn/content/wangluowenzhang/342882 windows 下不支持楼上说的方法来调试 所以采用曲线救国 使用 django 的 manage.py 来启动 worker 就可以调试了!!! |
25 dishonest 2018-05-30 17:32:58 +08:00 我记得 celery 已经放弃支持 windows,LZ 有大概率会碰到无法解释的 bug |
26 tonghuashuai 2018-05-30 19:03:00 +08:00 print 大法好 |
27 bilibalao 2018-05-31 00:43:52 +08:00 celery flower -A xxx --broker=redis://127.0.0.1:6379 你先 terminal 连 redis, 然后 terminal 起一个 worker celery -A xxx worker --loglevel=info, 然后正常打断点开 debug 模式调试就行了 |
28 param 2018-05-31 01:45:36 +08:00 via Android @darksand 你用 Windows ? celery 4.x 新版已经不支持 Windows。Linux 的话,pycharm 直接用 celery 的启动入口来启动是可以断电调试的,但如果 Windows 是 celery.exe 的这种二进制的话,我就不懂了。 |
29 haotianseo 2019-07-04 09:38:02 +08:00 |
30 evaseemefly 2020-05-22 11:49:11 +08:00 mac 可以调试,win 下面目前还是无法调试 |