百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

分布式任务调度Celery(分布式任务调度平台)

mhr18 2025-07-08 21:07 4 浏览 0 评论

本文介绍了分布式任务调度系统Celery,包括安装,开发使用,并且配合supervisor,flower等工具进行系统化部署和使用。

(一)安装和代码开发使用示例

一,简介

Celery是一个分布式任务调度系统,简单、灵活、可靠,是一个处理大量消息的分布式系统。专注于实时处理的异步任务队列,同时也支持任务调度。

Celery的架构由三部分组成:

AMQP broker:即消息中间件,Celery本身不提供消息服务,但是可以方便的和第三方提供的消息中间件集成。包括,RabbitMQ, Redis等。

celery workers:即任务执行单元,是Celery提供的任务执行的单元,worker并发的运行在分布式的系统节点中。

task result store:即任务执行结果存储,用来存储Worker执行的任务的结果,Celery支持以不同方式存储任务的结果,包括AMQP, redis等。

二,Celery安装

2.1 安装celery相关包

pip3 install eventlet

pip3 install celery

pip3 install pymongo

pip3 install flower

2.2 配置环境变量

export PATH=/usr/local/python3/bin:$PATH

echo "PATH=/usr/local/python3/bin:$PATH" >> /etc/profile.d/python3.sh

cd /etc/profile.d/

chmod 777 python3.sh

2.3 oracle环境变量配置

如果用到oracle数据库,需要增加oracle环境变量配置信息到python3.sh

cat /etc/profile 查看oracle环境变量配置

export PATH=/opt/oracle/instantclient_11_2:$PATH

echo "PATH=/opt/oracle/instantclient_11_2:$PATH" >> /etc/profile.d/python3.sh

cd /etc/profile.d/

chmod 777 python3.sh

# locate libclntsh.so.11.1

/opt/oracle/instantclient_11_2/libclntsh.so.11.1

# vim /etc/ld.so.conf

在最后一行添加如下内容:

/opt/oracle/instantclient_11_2

执行ldconfig

# ldconfig

三,Celery使用

3.1 celery --help

3.2 celery work --help

3.3 应用实例代码结构

3.4 运行后rabbitmq中内容

3.5 启动worker命令

(二)Supervisor使用

一,简介

Supervisor是一个进程管理工具,也可以理解为进程守护监控,当进程中断的时候Supervisor能自动重新启动它。Supervisor是用Python开发的一套通用的进程管理程序,能将一个普通的命令行进程变为后台daemon,并监控进程状态,异常退出时能自动重启。

在线上环境中,为了celery高可用性,肯定需要配置celery自动失败重启和开机自启动等,保证celery服务端和客户端的可用性。

二,Supervisor安装

2.1 下载包地址

https://files.pythonhosted.org/packages/2f/43/130066cd6003233401142f5f98cd09c93165f5c6408f850dd965b4f2470e/supervisor-4.2.0-py2.py3-none-any.whl

2.2 安装下载包

pip3 install supervisor

2.3 创建配置文件

创建

/etc/supervisor/supervisord.conf配置文件

vim /etc/supervisor/supervisord.conf

内容如下:

[unix_http_server]

file=/tmp/supervisor.sock ; path to your socket file

port=127.0.0.1:9001

[supervisord]

logfile=/var/log/supervisord/supervisord.log ; supervisord log file

logfile_maxbytes=50MB ; maximum size of logfile before rotation

logfile_backups=10 ; number of backed up logfiles

loglevel=info ; info, debug, warn, trace

pidfile=/var/run/supervisord.pid ; pidfile location

nodaemon=false ; run supervisord as a daemon

minfds=1024 ; number of startup file descriptors

minprocs=200 ; number of process descriptors

user=root ; default user

childlogdir=/var/log/supervisord/ ; where child log files will live

[rpcinterface:supervisor]

supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface

[supervisorctl]

serverurl=unix:///tmp/supervisor.sock ; use unix:// schem for a unix sockets.

[include]

# Uncomment this line for celeryd for Python

;files=celeryd.confi

files = /etc/supervisor/supervisord.conf.d/*.conf

2.4 创建文件

创建celeryd_worker.conf文件

vim /etc/supervisor/supervisord.conf.d/celeryd_worker.conf

[program:celery]

command=/usr/local/python3/bin/celery -A app worker -l info -n 192.168.12.150 -Q add

directory=/tmp/pycharm_project_146 # 运行命令的目录

numprocs=1

# 设置log的路径

stdout_logfile=/var/log/supervisor/celeryworker.log

stderr_logfile=/var/log/supervisor/celeryworker.log

autostart=true

autorestart=true

startsecs=10

stopwaitsecs = 600

priority=15

2.5 创建日志文件目录

mkdir -p /var/log/supervisor

mkdir -p /var/log/supervisord

2.6 创建service文件

创建

/etc/systemd/system/supervisord.service文件

此文件用于在centos中通过服务器supervisord,需要赋予777权限

vim /etc/systemd/system/supervisord.service

chmod 777 supervisord.service

三,Supervisord使用

3.1 启动Supervisord

运行systemctl start supervisord,启动supervisor,之后celery会自动启动

3.2 命令查看celery运行状态

运行supervisorctl status查看可发现celery成功运行

3.3 woker启动进程数和服务器cpu核数相关

查看逻辑核数:

cat /proc/cpuinfo| grep "processor"| wc -l

(三)flower安装部署和使用

一,简介

Flower是基于web的监控和管理Celery的工具。也是基于python实现的,用flower的前提是flower所在服务器能和任务队列所在服务器连通。

最牛逼的是起了flower后,你可以选择通过API调用方式来对任务和worker进行管理,而不用flower自带的web界面,等于是你可以自己开发个web界面来调flower的接口。

二、Flower安装和使用

2.1 Flower安装

pip3 install flower

2.2 Flower启动

方式一:

cd /tmp/pycharm_project_146

flower -A app --port=5555 --address=0.0.0.0 --persistent=True,-A指定项目名,port指定web端监听端口,address指定地址,persistent为true指定flower在本地保存当前状态。

方式二:

cd /tmp/pycharm_project_146

celery flower -A app --port=5555 --address=0.0.0.0 --persistent=True

方式三:

使用带认证

celery flower -A app --port=5555 --address=0.0.0.0 --persistent=True --basic_auth=root:123456

2.3 界面访问

浏览器访问

http://192.168.12.150:5555/dashboard

flower作为web页面来管理celery后台任务,和任务队列是隔离的,也就是flower的运行与否并不会影响到任务队列的真正执行,但是flower中也可以通过API接口来管理celery中的任务执行。

相关推荐

Springboot数据访问(整合动态数据源)

Springboot整合动态数据源dynamic-datasource-spring-boot-starter基本概念这个依赖是MyBatis-Plus团队开发的动态数据源组件,它是一个基于Spri...

《有手就会写sql》-第1章 数据库(sql实时更新同表里某个字段的数据)

为啥要用数据库存放数据的方式,有很多种,常用的比如:excel,数据库等。有了excel,为啥还要用数据库呢?原因有很多。其中之一:excel存储的数据有限的,最多能存个几千万条。但一个银行的交易数据...

DBdoctor:一款企业级数据库性能诊断工具

DBdoctor是一个全面覆盖开发、测试、运维等各个环节SQL审核以及数据库性能诊断与优化的监控平台。针对数据库性能诊断门槛高、耗时长的问题,DBdoctor提供了快速易用的解决方案,深入到数...

面试必问:MySQL死锁 是什么,如何解决?(史上最全)

MySQL死锁接触少,但面试又经常被问到怎么办?最近有小伙伴在面试的时候,被问了MySQL死锁,如何解决?虽然也回答出来了,但是不够全面体系化,所以,小北给大家做一下系统化、体系化的梳理,帮助大家在面...

JAVA入门教程-第1章 概述(java入门篇)

大道至简-JAVA入门教程在本教程中,你将学习Java语言的基础知识。Java基础内容涵盖:Java基础概念、Java词法结构、Java数组、Java流程控制、Java字符串、Java...

突发消息!微软停止俄罗斯业务(微软停止服务怎么办)

越来越多的IT公司加入封杀俄罗斯的阵营中。数字化转型网先后关注的有(点击下方蓝字可打开文章):SAP停止俄罗斯所有业务乌克兰呼吁SAP、Oracle封杀俄罗斯,Oracle已停止在俄所有业务埃森哲停止...

分布式数据库设计——存储引擎原理(全)

摘要数据库的一个首要目标是可靠并高效地管理数据,以供人们使用。进而不同的应用可以使用相同的数据库来共享它们的数据。数据库的出现使人们放弃了为每个独立的应用开发数据存储的想法,同时,随着数据库广泛的使用...

Java运行环境配置(java运行环境配置成功截图)

若要在计算机上运行Java程序,需要配置Java运行环境(JRE)或Java开发工具包(JDK)。以下是在Windows操作系统上配置Java运行环境的步骤:下载Java安装程序:前往Oracle官方...

分布式任务调度Celery(分布式任务调度平台)

本文介绍了分布式任务调度系统Celery,包括安装,开发使用,并且配合supervisor,flower等工具进行系统化部署和使用。(一)安装和代码开发使用示例一,简介Celery是一个分布式任务调度...

Android SDK 安装与配置(android sdk安装在哪里)

AndroidSDK安装与配置全流程指南一、前期准备与环境要求1.系统兼容性验证o操作系统:支持Windows10/11(64位)、macOS10.14+、Ubuntu16.04+等主流...

高性能Linux服务器构建实战:运维监控、性能调优与集群应用

百万级字迹详解实战案例,篇幅因素故只展现pdf目录,完整解析获取方式在篇尾了!目录读者对象Web应用篇(1至第3章)数据备份恢复篇(4至第6章)网络存储应用篇(7和第8章)运维监控与性能优化篇(9和第...

Vmware虚拟机迁移数据库时踩过的坑

从Vmware迁移数据库虚拟机到其他平台,起来后认不到asm盘,不禁傻眼了。很多时候为了保证虚拟机系统的完整可启动,在做任何变更前,领导都会要求克隆一份镜像保存,或者直接在镜像上操作。这是传统的备份理...

Java 中 java.util.Date 与 java.sql.Date 有什么区别?

Java里的java.util.Date和java.sql.Date绝对是那种看起来不起眼但能搞得你Debug到半夜的“坑王”。我们先从表面上看,java.sql.Date是继承自j...

主流数据库的不同点在哪?MySQL和SQL Server的区别介绍

在本教程中,树懒君介绍了两种最普遍应用的RDBMS—MySQL和MicrosoftSQLServer。通过介绍MySQL和SQLServer的几个关键区别,希望大家能在这两者之间做出最适合自己的...

Java安全-Java Vuls(Fastjson、Weblogic漏洞复现)

复现几个Java的漏洞,文章会分多篇这是第一篇,文章会分组件和中间件两个角度进行漏洞复现复现使用环境VulhubVulFocus组件Fastjson1.2.24反序列化RCEFastJson...

取消回复欢迎 发表评论: