前言

Cronsun是一款开源的分布式任务调度系统,主要用于在*nix服务器集群中管理和调度周期性任务。相比于传统的Linux crontab 工具,Cronsun提供了一个集中化的Web界面,使得在多台服务器上的定时任务更容易管理和监控,并且具备任务失败通知、任务高可用性(当某台服务器宕机时,任务可以自动在其他正常的服务器上继续执行)等特点。

Cronsun支持多租户、任务分组、任务依赖、任务统计等多种功能,适合大规模、复杂环境下对定时任务有高级需求的场景。开发者可以通过Cronsun简洁的API或界面轻松添加、编辑、删除定时任务,并且能够实时跟踪任务执行状态和历史记录。

前期准备,需要安装好docker、docker-compose的运行环境。

Cronsun的github地址如下。

GitHub - shunfei/cronsun: A Distributed, Fault-Tolerant Cron-Style Job System.

一、安装MongoDB

1、创建相关目录,执行如下命令。

mkdir -p /docker/mongodb/data/db/
cd /docker/mongodb

2、编写yaml文件,内容如下。

mongo版本不能用最新的,不然cronsun启动的时候连接不上mongodb数据库,应该是cronsun代码太久了,驱动无法兼容。

vim docker-compose.yaml
version: '2.2.2'
services:
  mongodb:
    image: mongo:3.0
    container_name: mongodb
    restart: always
    ports:
      - "27017:27017"
    volumes:
      - ./data/db:/data/db
    environment:
      MONGO_INITDB_ROOT_USERNAME: admin
      MONGO_INITDB_ROOT_PASSWORD: admin
      MONGO_INITDB_DATABASE: admin
    command: --auth
    networks:
      - mynet

networks:
  mynet:
    name: mynet
    driver: bridge

3、启动mongodb容器,执行如下命令。

docker-compose up -d

4、查看服务是否正常启动,执行如下命令。

docker-compose ps -a

正常情况会返回如下内容。

docker容器中配置了crontab不生效 docker安装crontab_运维

5、进入mongodb容器,执行如下命令。

docker exec -ti mongodb bash

6、登录mongodb,执行如下命令,账号密码数据库换成你自己设定的值。

mongo -u admin -p admin --authenticationDatabase admin

7、创建cronsun数据库,并且给账号读写授权,执行如下命令。

use cronsun
db.createUser(
  {
    user: "admin",
    pwd: "admin",
    roles: [ { role: "readWrite", db: "cronsun" } ]
  }
)

8、至此,mongodb已安装完成,并且创建好cronsun数据库。

二、安装etcd

1、创建相关目录,执行如下命令。

mkdir -p /docker/etcd/data/
cd /docker/etcd/

2、编写yaml文件,内容如下。

vim docker-compose.yaml
version: '2.2.2'
services:
  etcd:
    image: bitnami/etcd
    container_name: etcd
    ports:
      - "2379:2379"
      - "2380:2380"
    volumes:
      - ./data:/bitnami/etcd/data
    environment:
      ALLOW_NONE_AUTHENTICATION: yes
    networks:
      - mynet

networks:
  mynet:
    name: mynet
    driver: bridge

 3、启动etcd容器,执行如下命令。

docker-compose up -d

4、查看服务是否正常启动,执行如下命令。

docker-compose ps -a

正常情况会返回如下内容。

docker容器中配置了crontab不生效 docker安装crontab_容器_02

5、至此,etcd已安装完成。

三、安装Cronsun

1、浏览器打开github地址,找到已发布的下载文件地址。

GitHub - shunfei/cronsun: A Distributed, Fault-Tolerant Cron-Style Job System.

docker容器中配置了crontab不生效 docker安装crontab_etcd_03

docker容器中配置了crontab不生效 docker安装crontab_docker_04

2、使用alpine镜像运行一个cronsun容器,执行如下命令。

docker run -it --name cronsun --network mynet -p 7079:7079 alpine

3、进入cronsun容器,执行如下命令。

docker exec -ti cronsun sh

4、因为alpine镜像使用的是apk包管理,我们需要更换国内源地址,执行如下命令更换为阿里云地址。

vi /etc/apk/repositories
https://mirrors.aliyun.com/alpine/v3.15/main
https://mirrors.aliyun.com/alpine/v3.15/community

 5、安装相关依赖,执行如下命令。

apk update
apk add zip curl

6、下载cronsun可执行文件,执行如下命令。

wget https://github.com/shunfei/cronsun/releases/download/v0.3.5/cronsun-v0.3.5-linux-amd64.zip

7、解压cronsun,执行如下命令。

unzip cronsun-v0.3.5-linux-amd64.zip
cd cronsun-v0.3.5/

8、修改db配置,如下内容,Hosts、Database、UserName、Password。

docker容器中配置了crontab不生效 docker安装crontab_运维_05

9、修改etcd配置,如下内容,Endpoints。

docker容器中配置了crontab不生效 docker安装crontab_etcd_06

10、启动web服务,执行如下命令。

./cronweb -conf conf/base.json

11、启动node服务,执行如下命令。

./cronnode -conf conf/base.json

12、至此,cronsun已安装完成。

四、测试验证

1、浏览器打开cronsun,地址如下。

http://宿主机IP:7079/ui/#/login

docker容器中配置了crontab不生效 docker安装crontab_容器_07

2、使用用户名 admin@admin.com 和密码 admin 进行登录。

3、新建分组节点。

docker容器中配置了crontab不生效 docker安装crontab_运维_08

docker容器中配置了crontab不生效 docker安装crontab_mongodb_09

docker容器中配置了crontab不生效 docker安装crontab_docker_10

4、新建任务。

docker容器中配置了crontab不生效 docker安装crontab_docker_11

docker容器中配置了crontab不生效 docker安装crontab_etcd_12

5、修改项目test1的index.php代码,增加写入日志内容。

vim index.php
<?php
echo "hello ayzen!this is test1!\r\n";

$datetime = date('Y-m-d H:i:s');
file_put_contents("./index.log", "datetime=${datetime},index.php running!\r\n", FILE_APPEND);

6、查看index.log日志,检查调度任务是否有正常运行。

docker容器中配置了crontab不生效 docker安装crontab_etcd_13

如上图所示,说明调度任务已正常运行。

7、至此,cronsun的测试已验证完成。

总结

本文介绍了cronsun是什么,以及它的安装部署流程。

1、安装MongoDB。

2、安装etcd。

3、安装Cronsun。

4、测试验证。

需要注意的是,因为cronsun太久了已经有5年多未更新版本了,所以mongodb不能安装太新的版本,不然会遇到驱动不兼容的问题。