-
Demon-IPA 是一个基于 Swoole 的分布式任务调度系统
-
结构扩展性强适用于二次开发
-
web 界面管理任务 支持任务日志的查看 时刻了解任务执行的状态
-
去中心化,多个 worker pull 的方式抢占消费任务 避免单台机器 down 机导致任务不能执行
-
依赖:Swoole , Redis
由多节点调度器读取任务表,读取后抢占锁决定谁来决定任务的执行
初始任务为1级任务,调度器不执行,将任务变为二级任务分发给任务执行集群,分发前进行存活检测
执行结果写进log表,做可视化图标
当所有执行机器down机,拥有锁的调度器独自执行任务
-
安装Swoole , php-redis 扩展
-
nginx 配置
server {
listen 80;
server_name km.demon.com;
root /mnt/workspace/Demon-IPA;
index index.html index.htm index.php;
location / {
if (!-e $request_filename) {
rewrite ^/(.*)$ /index.php;
}
}
location ~ \.php$ {
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
}
3.修改Mysql,Redis 配置
将根目录中的env.example.php重命名为env.php,并且修改其中的配置
4.启动server
执行:
php server/jobServer start
1.机器负责情况