celery+rabbitmq

  • Rabbitmq使用
# 设置RabbitMQ:创建一个用户,一个虚拟主机并设置权限,(需要先启动服务)
sudo rabbitmqctl add_user myuser mypassword
sudo rabbitmqctl add_vhost myvhost  # 虚拟主机
sudo rabbitmqctl set_user_tags myuser mytag  # administrator
sudo rabbitmqctl set_permissions -p myvhost myuser ".*" ".*" ".*"

#启动服务
sudo rabbitmq-server 
# 后台运行
sudo rabbitmq-server -detached
or
sudo rabbitmqctl start_app
# 不要kill(1)来停止服务器
sudo rabbitmqctl stop
查看是否启动成功
rabbitmq-server status
  • 应用
# tasks.py
from celery import Celery

app = Celery(
    'tasks',  # 当前模块的名字
    broker='amqp://guest@localhost:port//'  # 消息队列的url
)

@app.task
def add(x, y):
    return x + y
  • celery使用
    celery -A app.asynctask.tasks worker -l info
  • 调用任务
# delay
from tasks import add
add.delay(arg1,arg2,kwarg1='x',kwarg2='y')
add.delay(*args, **kwargs).apply_async(args, kwargs)

# apply_async
task.apply_async(args=[arg1,arg2], kwargs={'kwargs':'x','kwargs':'y'})
tasks.apply_async((arg,), {'kwarg': value})
# 从现在起10秒内执行
tasks.apply_async(countdown=10) 
# 从现在起10秒内执行,使用指定eta
tasks.apply_async(eta=now + timedelta(seconds=10))
# 从现在起一分钟后执行,但在2分钟后过期
tasks.apply_async(countdown=60, expires=120)
# 在2天后到期,设置使用datetime对象
T.apply_async(expires=now + timedelta(days=2))

# send_task:任务未在当前进程中注册
app.send_task('任务', args=[arg,], queue='default')

# signature用于传递任务调用签名的对象(例如通过网络发送),并且它们也支持calling api
task.s(arg1,arg2,kwarg1='x',kwargs2='y').apply_async()
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值