- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们的项目使用 Django 运行网络服务器,Celery/RabbitMQ 向工作人员分配任务。每当一个工作人员有能力完成任务时(例如,四个并发有四个任务),他们就会停止从花或内置的 celery 检查中出现。
ETA:worker 仍然在线,当任务完成使得 worker 低于并发值时,它再次出现在 flower 和 inspect 中。不幸的是,我正在尝试使用检查的“保留”方法来查看排队的任务,但只要我能看到工作人员,它总是空的。
这是我们在 Django 设置文件中的 Celery 设置:
BROKER_URL = 'amqp://[user]:[pw]@[host]//'
CELERY_ACCEPT_CONTENT = ['json']
CELERY_EVENT_SERIALIZER = 'json'
CELERY_TASK_SERIALIZER = 'json'
CELERY_RESULT_SERIALIZER = 'json'
CELERY_RESULT_BACKEND = 'amqp'
CELERY_TIMEZONE = 'US/Mountain'
CELERY_RESULT_PERSISTENT = True
CELERY_TASK_RESULT_EXPIRES = 3600 # seconds
CELERYBEAT_SCHEDULER = 'djcelery.schedulers.DatabaseScheduler'
CELERY_DEFAULT_QUEUE = 'tasks'
CELERY_TRACK_STARTED = True
from kombu import Queue
CELERY_QUEUES = (Queue('tasks', routing_key='task.#'),
Queue('frontend_tasks', routing_key='frontend.#'),
)
CELERY_DEFAULT_ROUTING_KEY = 'task.default'
CELERY_DEFAULT_EXCHANGE = 'tasks'
celery 版本:3.1.13
RabbitMQ 版本:3.3.4-1
海带版本:3.0.21
amqp 版本:1.4.5
Celery worker 的调用:
python manage.py celery worker -f c:\logs\celery.log -E -l info --settings=[proj].settings.production
更新:将 prefetch multiplier 设置为 1 后,即使他们有四个任务,我仍然可以看到 worker。但是,我看不到工作人员的任何待处理任务,因为它们尚未从服务器中获取。有谁知道是否有办法让工作人员(出现)在线并仍然看到队列中的待处理任务?将 prefetch multiplier 设置为 2 会使工作人员在有四个或更多任务时从我的 inspect/flower 中退出。即使将预取乘数设置为 2 并将并发设置为 1 或 2(从 4 降低)也会导致相同的“消失的工作人员”问题。
在此先感谢您的帮助,
史蒂夫
最佳答案
我找到了解决此问题的解决方案。我通过将 -P threads
参数提交给调用,将我的工作人员更改为线程化而不是 prefork:
python manage.py celery worker -f c:\logs\celery.log -E -P threads -l info --settings=[proj].settings.production
然后我能够正确地检查工作人员,即使他们以并发值运行。我确实必须确保我的所有任务都是线程安全的(shutil 是主要问题,一个简单的锁修复了它)。
希望对您有所帮助。
史蒂夫
关于django - 当达到并发值时,Celery inspect 显示 worker 离线,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25089116/
我有一个嵌套数组: array_name = [ ["Alice", "pizza", "soccer"], ["Steve", "sushi", "hockey"], ["Alex",
我正在尝试下载网页,但文件在我下载的内容、页面源和检查方面有所不同。如何下载检查中显示的内容? 最佳答案 查看页面源代码返回服务器发送并由浏览器加载的静态 html 页面。 虽然 inspect 将显
我发现自己在我的功能测试中做了很多 puts .inpsect s 以确保我知道数据是如何格式化的......但是当散列对象中的每个条目之后没有新行时散列很难读取.无论如何,也许是一个 gem ?,
所以这段代码: from inspect import * class X(object): def y(self): pass methods = getmembers(X, predi
我在 Ruby 1.9 中通过调用等于 my_hash.inspect 的 my_hash.to_s 不小心将 Ruby 哈希保存到字符串。这给了我这样的字符串: '{"foo"=>{"bar"=>"
自从升级 NodeJs 以来,我从 Visual Studio 2017 运行 Nodejs 时遇到此错误。 断点也不起作用。有任何解决这个问题的方法吗? 注意:VS版本是15.5.6NodeJS 版
我已经使用 VS 2015 在我的计算机上安装了 nodeJs 并进行了设置。当我尝试运行示例 hello world 应用程序时,它抛出以下错误: verb(node:14096) [DEP0062
当我在 Visual Studio 中运行 Node.js 应用程序时,我收到以下消息:DeprecationWarning: 'node --debug' 和 'node --debug-brk'
下面的代码无法运行 def map = [name:"Test :: ( %2f %25 \$ * & ! @ # ^)"] String s = map.inspect() println Eval
我正在尝试使用检查来查明 foo 是否是对象 test_me 的方法。我希望它返回 True 或 False。这是我试过的。 import inspect class Object: pass
这个问题在这里已经有了答案: Is there a way in git to obtain a push date for a given commit? (8 个答案) 关闭 5 年前。 我如何
描述与简介 docker inspect是docker客户端的原生命令,用于查看docker对象的底层基础信息。包括容器的id、创建时间、运行状态、启动参数、目录挂载、网路配置等等。另外,该命令也
我的问题是如何使 SASS 函数 inspect() 与数组一起工作或如何以另一种方式输出数组。 我的基本示例是这段代码: @function z($layers...) { @warn "`#{
我在 Ruby 中发现了一个奇怪的问题,我不太确定这是一个问题还是最近 Ruby 版本中引入的一个功能。 基本上当我们调用一个未定义的方法时,我们会得到一个 undefined method Ruby
Message will display here Document.getElementById("idbd").style.backgroundcolor="red"; Document
注意:我读过类似的帖子,但没有一个完全是我的问题 - 我可以右键单击它,然后它就消失了。 我发现“检查元素”是 Chrome 中非常宝贵的工具,但是我在将其用作导航栏上某个元素的子菜单时遇到了麻烦,该
使用 ionic 开发 Web 应用程序时,在 iOS 模拟器中使用命令行运行程序非常有用 ionic run ios -l -c -s --target="iPhone-5s" 然后通过选择桌面 S
JQuery 是一个非常强大的工具,但它很难调试。 看看下面的图片: 如何轻松找到包含 JQuery 代码的 *.js 文件,该代码已附加到这部分 HTML 代码? 我认为这几乎是不可能的,因为它也可
我正在尝试通过古腾堡 Inspect Control 的媒体库上传文件。我目前在 JS 中使用此代码: var el = wp.element.createElement, registerB
我正在尝试使用 Is it possible to list all functions in a module? 的答案列出一系列模块中的功能。但在我的解释器中,我得到如下信息: Python 3.
我是一名优秀的程序员,十分优秀!