使用java程序作为celery的工作节点
celery是python实现的分布式调度框架,有时候想用celery去调用java服务,正好有一个celery-java的库可以使用,能达到这个效果,记录一下:
先添加依赖:
<dependency>
<groupId>com.geneea.celery</groupId>
<artifactId>celery-java</artifactId>
<version>1.10.4</version>
</dependency>
先定义任务类TestTask.java
import com.geneea.celery.CeleryTask;
@CeleryTask
public class TestTask {
public int sum(int x, int y){
return x + y;
}
}
再定义工作入口类MyWorker.java
import com.geneea.celery.CeleryWorkerCLI;
public class MyWorker {
public static void main(String[] args) throws Exception {
//注意broker的url的末尾/必须用转义符%2F
args = new String[]{"--queue","celery",
"--concurrency","2",
"--broker","amqp://guest:guest@localhost:5672/%2F"};
CeleryWorkerCLI.main(args);
}
}
运行MyWorker
即可启动java
版的celery
工作节点:
Started consuming tasks from queue celery.
Known tasks:
- cn.main.celery.TestTask
然后定义celery的任务调度程序test.py
:
import celery
app = celery.Celery(broker="amqp://guest:guest@localhost:5672//", backend="rpc://guest:guest@localhost:5672//")
#调度任务格式为pacakage.class#func
result = app.signature("cn.main.celery.TestTask#sum", [1, 2]).delay().get()
print("result is %s" % result)
运行test.py
程序反应如下:
C:\ProgramData\Anaconda3\python.exe D:/Test/python/celerys/javatest.py
result is 3
Process finished with exit code 0
19:06:43.685 INFO [pool-1-thread-1] c.g.c.CeleryWorkerCore:126 - CeleryTask cn.main.celery.TestTask#sum[2c1476a0-0d64-47c8-afce-6ddc99915ea9] succeeded in 338.9 μs
参考链接:
分类:
Airflow
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· .NET10 - 预览版1新功能体验(一)