JAVA 通过rabbitMQ调用celery 任务的代码示例

时间: 2023-09-17 12:08:49 浏览: 56
以下是通过 RabbitMQ 调用 Celery 任务的 Java 代码示例: ```java import java.io.IOException; import com.rabbitmq.client.Channel; import com.rabbitmq.client.Connection; import com.rabbitmq.client.ConnectionFactory; import com.rabbitmq.client.QueueingConsumer; public class RabbitMQClient { private final static String QUEUE_NAME = "celery"; public static void main(String[] argv) throws Exception { ConnectionFactory factory = new ConnectionFactory(); factory.setHost("localhost"); Connection connection = factory.newConnection(); Channel channel = connection.createChannel(); channel.queueDeclare(QUEUE_NAME, false, false, false, null); System.out.println(" [*] Waiting for messages. To exit press CTRL+C"); QueueingConsumer consumer = new QueueingConsumer(channel); channel.basicConsume(QUEUE_NAME, true, consumer); while (true) { QueueingConsumer.Delivery delivery = consumer.nextDelivery(); String message = new String(delivery.getBody()); System.out.println(" [x] Received '" + message + "'"); // 调用 Celery 任务 CeleryClient.runTask(message); } } } ``` 在这个示例中,我们使用 RabbitMQ 的 Java 客户端库创建了一个消费者,等待来自名为 "celery" 的队列的消息。当收到消息时,我们将其传递给 Celery 客户端的 runTask() 方法进行处理。 以下是 Celery 客户端的示例代码: ```java import io.github.cdimascio.dotenv.Dotenv; import io.github.cdimascio.dotenv.DotenvBuilder; import org.json.JSONObject; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import java.util.HashMap; import java.util.Map; import java.util.UUID; import com.rabbitmq.client.Channel; import com.rabbitmq.client.Connection; import com.rabbitmq.client.ConnectionFactory; public class CeleryClient { private static final Logger logger = LoggerFactory.getLogger(CeleryClient.class); private static final String TASK_QUEUE_NAME = "celery"; private static final String APP_NAME = "myapp"; private static final String DEFAULT_EXCHANGE = "celery"; private static final String DEFAULT_ROUTING_KEY = "celery"; private static final String DEFAULT_BACKEND = "rpc://"; private static final String DEFAULT_RESULT_EXPIRES = "3600"; private static final String DEFAULT_TASK_TRACK_STARTED = "true"; private static final String DEFAULT_TASK_TIME_LIMIT = "600"; private static final String DEFAULT_TASK_SOFT_TIME_LIMIT = "600"; private static final Dotenv dotenv = new DotenvBuilder().ignoreIfMissing().load(); private static final String CELERY_BROKER_URL = dotenv.get("CELERY_BROKER_URL"); private static final String CELERY_RESULT_BACKEND = dotenv.get("CELERY_RESULT_BACKEND"); public static void runTask(String message) { try { JSONObject json = new JSONObject(message); String taskName = json.getString("task"); JSONObject args = json.getJSONObject("args"); ConnectionFactory factory = new ConnectionFactory(); factory.setUri(CELERY_BROKER_URL); try (Connection connection = factory.newConnection()) { try (Channel channel = connection.createChannel()) { String taskId = UUID.randomUUID().toString(); Map<String, Object> headers = new HashMap<>(); headers.put("task", taskName); headers.put("id", taskId); headers.put("app", APP_NAME); headers.put("lang", "java"); headers.put("taskset", "celery"); headers.put("shadow", null); headers.put("eta", null); headers.put("expires", DEFAULT_RESULT_EXPIRES); headers.put("group", null); headers.put("retries", null); headers.put("timelimit", new int[]{Integer.parseInt(DEFAULT_TASK_TIME_LIMIT), Integer.parseInt(DEFAULT_TASK_SOFT_TIME_LIMIT)}); headers.put("callbacks", null); headers.put("errbacks", null); headers.put("reply_to", null); headers.put("correlation_id", null); headers.put("delivery_info", null); headers.put("kwargsrepr", "{}"); headers.put("utc", true); channel.basicPublish(DEFAULT_EXCHANGE, DEFAULT_ROUTING_KEY, null, args.toString().getBytes("UTF-8"), headers); logger.info("Task sent: " + taskName + " - " + taskId); } } } catch (Exception e) { logger.error("Error while sending task to Celery", e); } } } ``` 在这个示例中,我们使用 Celery Java 客户端库创建了一个方法,接收 RabbitMQ 消息并将其作为 Celery 任务发送。我们使用 dotenv 库从环境变量中读取 Celery 的 URL 和结果后端 URL,并使用这些值创建 Celery 连接。 注意,这里的 runTask() 方法只是将消息发送到 Celery,而实际任务的执行是在 Celery 服务器上完成的。因此,需要在 Celery 服务器上配置任务并启动 Celery 工作人员。

相关推荐

最新推荐

recommend-type

C#调用RabbitMQ实现消息队列的示例代码

主要介绍了C#调用RabbitMQ实现消息队列的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

SpringBoot下RabbitMq实现定时任务

主要为大家详细介绍了SpringBoot下RabbitMq实现定时任务,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

rabbitmq开发规范

1:rabbitmq的命名规范 2:rabbitmq生产者开发规范 3:rabbitmq消费者开发规范
recommend-type

rabbitmq(java)入门教程

rabbitmq(java)入门教程,对没有接触过的人是一个还算不错的文档,文档的最后有demo,可以直接复制出来加载到你的加载到你的eclipse或者MyEclipse中运行
recommend-type

基于Python的蓝桥杯竞赛平台的设计与实现

【作品名称】:基于Python的蓝桥杯竞赛平台的设计与实现 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【项目介绍】:基于Python的蓝桥杯竞赛平台的设计与实现
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

2. 通过python绘制y=e-xsin(2πx)图像

可以使用matplotlib库来绘制这个函数的图像。以下是一段示例代码: ```python import numpy as np import matplotlib.pyplot as plt def func(x): return np.exp(-x) * np.sin(2 * np.pi * x) x = np.linspace(0, 5, 500) y = func(x) plt.plot(x, y) plt.xlabel('x') plt.ylabel('y') plt.title('y = e^{-x} sin(2πx)') plt.show() ``` 运行这段
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。