go发布celery任务(RabbitMQ)

3 篇文章 0 订阅
3 篇文章 0 订阅
package main

import (
	"encoding/json"
	"fmt"
	uuid "github.com/satori/go.uuid"
	"github.com/streadway/amqp"
)

// CeleryTask 任务模型
type CeleryTask struct {
	Queue    string
	TaskName string
	Args     []interface{}
	Kwargs   map[string]interface{}
}

// NewCelery 创建任务模型
func NewCelery(hosts string) (*Celery, error) {
	var err error
	var celery = new(Celery)
	if celery.connect, err = amqp.Dial(hosts); err == nil {
		if celery.channel, err = celery.connect.Channel(); err == nil {
			return celery, err
		}
	}
	return nil, err
}

// call 调用结构
var call = map[string]interface{}{"callbacks": nil, "errbacks": nil, "chain": nil, "chord": nil}

// Celery 消息队列连接
type Celery struct {
	connect *amqp.Connection
	channel *amqp.Channel
}

// Delay 发送任务
func (c *Celery) Delay(task *CeleryTask) (taskId string, err error) {
	if task.Args == nil {
		task.Args = []interface{}{}
	}
	var payload = []interface{}{task.Args, task.Kwargs, call}
	body, err := json.Marshal(payload)
	if err != nil {
		return "", err
	}
	taskId = uuid.Must(uuid.NewV4()).String()
	return taskId, c.channel.Publish("", task.TaskName, false, false,
		amqp.Publishing{
			ContentEncoding: "utf-8",
			ContentType:     "application/json",
			DeliveryMode:    amqp.Persistent,
			CorrelationId:   taskId,
			Headers:         amqp.Table{"id": taskId, "root_id": taskId, "task": task.TaskName, "retries": 5},
			Body:            body,
		},
	)
}

func main() {
	celery, err := NewCelery("amqp://admin:123456@127.0.0.1:5672/org")
	if err != nil {
		panic(err)
	}
	if taskId, err := celery.Delay(&CeleryTask{
		Queue:    "iowork",
		TaskName: "iowork",
		Kwargs:   map[string]interface{}{"work_type": "export", "a1": 200, "a2": true},
	}); err != nil {
		panic(err)
	} else {
		fmt.Println(taskId)
	}
}
要使用 Celery 连接 RabbitMQ,需要进行以下步骤: 1. 安装 CeleryRabbitMQ 在命令行中运行以下命令以安装 CeleryRabbitMQ: ``` pip install celery sudo apt-get install rabbitmq-server ``` 2. 创建 Celery 应用 创建一个 Python 文件,例如 `celery_app.py`,并添加以下内容: ```python from celery import Celery app = Celery('celery_app', broker='amqp://guest@localhost//', backend='rpc://', include=['tasks']) ``` 这将创建一个名为 `celery_app` 的 Celery 应用,并将其连接到本地运行的 RabbitMQ 代理。还将使用 RPC 后端来存储任务结果,以便可以查询任务状态。 3. 创建任务 在同一目录下创建一个名为 `tasks.py` 的文件,并添加以下内容: ```python from celery import shared_task @shared_task def add(x, y): return x + y ``` 这将创建一个名为 `add` 的任务,它将接受两个参数并返回它们的和。 4. 启动 Celery 工作器 在命令行中运行以下命令以启动 Celery 工作器: ``` celery -A celery_app worker -l info ``` 这将启动一个 Celery 工作器,并将其连接到 RabbitMQ 代理。工作器将等待接收任务并在后台执行它们。 5. 触发任务Python 中使用以下代码触发任务: ```python from celery_app import add result = add.delay(2, 3) print(result.get()) ``` 这将异步触发 `add` 任务,并打印其结果。 以上就是连接 CeleryRabbitMQ 的基本步骤。要了解更多关于 CeleryRabbitMQ 的信息,请参阅官方文档。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值