10 Star 39 Fork 9

Gitee 极速下载 / Crocodile

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
此仓库是为了提升国内下载速度的镜像仓库,每日同步一次。 原始仓库: https://github.com/labulaka521/crocodile
克隆/下载
贡献代码
同步代码
取消
提示: 由于 Git 不支持空文件夾,创建文件夹后会生成空的 .keep 文件
Loading...
README
MIT

Crocodile 分布式任务调度系统

GitHub Workflow Status Downloads license Release

English | 中文

Introduction

基于Golang开发的分布式任务调度系统,支持http、golang、python、shell、python3、nodejs、bat等调度任务

Screenshot

点击我

                                                  +----------+
        +-------------+                           ||--------||
        ||-----------||                           ||        ||
        ||           ||                           || Worker ||
        ||   调度中心 ||                           ||         ||
        ||           ||      RPC调用(gRPC)        ||---------||
        ||-----------|| +-----------------------> ||-------- ||
        ||-----------||                           ||        ||
        ||           || <-----------------------+ || Worker ||
  +---> ||   调度中心 ||      任务实时日志            ||        ||
任 |    ||           ||                           ||--------||
务 |    ||-----------|| <------+                  ||--------||
完 |     +------------+        |                  ||        ||
成 |         ^    |            |                  || Worker ||
持 |       实|任   |            |数                ||        ||                
久 |       时|务   |获          |据                 +----------+ 
日 |       志|状   |取          |存                
志 |       日|态   |锁          |储
   |        v     v            v
   |      +-------+-+      +----+---+
   |      |         |      |        |
   +----- |  Redis  |      | MySQL  |
          |         |      |        |
          +---------+      +--------+

Features

  • 多调度中心、多Worker运行
  • 在Web节点对任务进行增加、修改、删除、克隆、运行任务、终止任务等操作
  • 实时查看正在运行的任务、任务的实时日志和任务状态
  • 多种任务类型:
    • 执行http请求任务
    • 运行shellpythongolangpython3nodejs代码(当然其他语言也可以支持,如需要请提出)
  • 父、子任务:
    当设置了父任务或者子任务后,先会运行父任务->主任务->子任务,任意任务出错后会立即中断整个流程,还可以设置父任务或子任务并行或者串行运行
  • 调度算法:
    支持四种调度算法随机、轮训、Worker权重、Worker最少任务数来调用Worker运行任务,
  • 自定义报警策略:
    可以设置当任务成功失败、或者运行完成后报警给多个用户
    设置任务的返回码或者返回内容来比较任务的实际返回码或者返回内容是否相同来判断任务运行成功或者,code任务默认为0,http任务默认为200
  • 主机组:
    一个任务只可以绑定到任意一个主机组,任务的运行会通过任务的路由策略来选取这个主机组中的一个任务来运行任务
  • 主机:
    一个主机组可以绑定多个主机,主机是实际运行任务的节点,注册后调度中心自动发现
  • 安全策略
    证书加密(可关闭)
    密钥认证(必选,防止未授权Worker节点接入)
  • 任务的日志管理,清理日志
  • 报警通知支持平台
    • 邮件
    • 企业微信
    • 钉钉
    • Slack Channel
    • Telegram Bot
    • WebHook URL
  • 详细的操作审计功能
  • 权限控制
    有三种用户类型
    • 管理员
      拥有所有操作权限,
    • 普通用户 可以创建新的任务、主机组,可以对自已创建的任务或主机组进行操作,不能查看审计记录、所有用户
    • 访客
      只有查看的权限、无任何操作修改权限,不能查看审计记录、所有用户

Supported platforms

  • Linux
  • Mac
  • Windows

Quick Start

git clone https://github.com/labulaka521/crocodile
cd crocodile
docker-compose up -d

然后在浏览器中打开http://ip:8080,然后在初始化页面输入一个管理员用户名、用户密码然后点击开始安装,安装完成后你就可以进入到系统中去

Running

  • 点击下载后解压
  • 安装redis、mysql,然后修改配置文件
  • 如果需要开启调度节点之间的证书认证,请生成证书, 运行生成cert证书的命令
    crocodile cert
    然后会在当前目录本地生成两个文件cert.pemkey.pem,将这两个文件保存后,将文件的路径填写值配置文件中,每个节点都需要这两个文件
  • 作为一个调度中心来运行
    可以启动多个调度中心,防止单点故障导致调度挂掉
    ./crocodile server -c core.toml
  • 作为一个Worker(主机)节点来运行
    ./crocodile client -c core.toml
  • 查看版本编译信息
    ./crocodile version
  • 配置报警

Development

  • 前端
    • 安装yarn
    • 进入web目录,先下载依赖yarn,然后单独运行前端yarn run dev
    • 打包至go,执行make frontrnd
  • 后端
    • 作为调度中心运行make runs
    • 作为Worker节点运行make runc

sql目录也是被打包在go-bindata中的,在安装时会从go-bindata生成的文件读取sql创建语句,如果修改了sql,就重新执行下make bin-data

Doc

Wiki

Donate

如果这个项目帮助了你,希望你可以通过支付宝可以捐助

License

Crocodile is under the MIT license. See the LICENSE file for details.

MIT License Copyright (c) 2019 labulaka521 Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

简介

Crocodile是基于Golang开发的定时任务调度系统,支持http请求、运行golang、python、shell等调度任务 展开 收起
MIT
取消

发行版

暂无发行版

贡献者

全部

近期动态

加载更多
不能加载更多了
1
https://gitee.com/mirrors/Crocodile.git
git@gitee.com:mirrors/Crocodile.git
mirrors
Crocodile
Crocodile
master

搜索帮助

14c37bed 8189591 565d56ea 8189591