前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布

webcron

作者头像
周小董
发布2019-03-25 15:56:00
1.2K0
发布2019-03-25 15:56:00
举报
文章被收录于专栏:python前行者python前行者

一个定时任务管理器,基于Go语言和beego框架开发。用于统一管理项目中的定时任务,提供可视化配置界面、执行日志记录、邮件通知等功能,无需依赖*unix下的crontab服务。

项目背景

开发此项目是为了解决本人所在公司的PHP项目中定时任务繁多,使用crontab不好管理的问题。我所在项目的定时任务也是PHP编写的,属于整个项目的一部分,我希望能有一个系统可以统一配置这些定时任务,并且可以查看每次任务的执行情况,任务执行完成或失败能够自动邮件提醒开发人员,因此做了这个项目。

功能特点

  • 统一管理多种定时任务。
  • 秒级定时器,使用crontab的时间表达式。
  • 可随时暂停任务。
  • 记录每次任务的执行结果。
  • 执行结果邮件通知。

界面截图

webcron
webcron

安装说明

系统需要安装Go和MySQL。

1、安装go语言环境(go1.9.2.linux-amd64.tar.gz):解压缩到路径/usr/local/go

go下载地址:https://dl.gocn.io/

2、 添加环境变量(vi /etc/profile):

代码语言:javascript
复制
export GOROOT=/usr/local/go
export GOBIN=$GOROOT/bin
export PATH=$PATH:$GOBIN
export GOPATH=/usr/local/webcron
export AUTO_GOPATH=1

3、获取源码(如git未安装则会报错)

代码语言:javascript
复制
$ go get github.com/lisijie/webcron

4 打开配置文件 conf/app.conf,修改相关配置(修改任务数和数据库配置 ):

代码语言:javascript
复制
appname = webcron

httpport = 8000

runmode = dev 

# 允许同时运行的任务数

jobs.pool = 50 

# 站点名称

site.name = 定时任务管理器

# 数据库配置

db.host = ip端口(192.168.11.11)

db.user = 用户名

db.password = 密码

db.port = 3306

db.name = dataserver

db.prefix = t_

db.timezone = Asia/Shanghai

# 邮件服务器配置

mail.queue_size = 100

mail.from = no-reply@example.com

mail.host = smtp.example.com

mail.port = 25

mail.user = username

mail.password = your password

5 创建数据库webcron ,再导入install.sql

6 创建数据库表

代码语言:javascript
复制
  $ mysql -u username -p -D webcron < install.sql

7 编译构建webcron

代码语言:javascript
复制
  $  **cd** /usr/local/webcron/src/github.com/lisijie/webcron

  $  go build

8 运行webcron

代码语言:javascript
复制
$**cd** /usr/local/webcron/src/github.com/lisijie/webcron

$ ./webcron 或 $ nohup ./webcron 2>&1 > error.log &

设为后台运行

9 访问

http://localhost:8000

帐号:admin 密码:admin888

参考:https://github.com/lisijie/webcron

Cron表达式说明

Cron表达式是一个字符串,字符串以空格隔开,分为5或6个域,每一个域代表一个含义,系统支持的表达式格式如下:

代码语言:javascript
复制
Seconds Minutes Hours DayofMonth Month [DayofWeek]

其中 DayofWeek 为可选域。

每一个域可出现的字符如下:

• Seconds: 可出现”* / , -“四个字符,有效范围为0-59的整数 • Minutes: 可出现”* / , -“四个字符,有效范围为0-59的整数 • Hours: 可出现”* / , -“四个字符,有效范围为0-23的整数 • DayofMonth: 可出现”* / , - ?”五个字符,有效范围为0-31的整数 • Month: 可出现”, - * /”四个字符,有效范围为1-12的整数或JAN-DEC • DayofWeek: 可出现”* / , - ?”五个字符,有效范围为0-6的整数或SUN-SAT两个范围。0表示星期天,1表示星期一, 依次类推

各个字符的含义如下:

• * 表示匹配该域的任意值,假如在Minutes域使用*, 即表示每分钟都会触发事件。 • ? 字符仅被用于天(月)和天(星期)两个子表达式,表示不指定值,当2个子表达式其中之一被指定了值以后,为了避免冲突,需要将另一个子表达式的值设为“?”。 • - 表示范围,例如在Minutes域使用5-20,表示从5分到20分钟每分钟触发一次。 • / 表示起始时间开始触发,然后每隔固定时间触发一次,例如在Minutes域使用5/20,则意味着5分钟触发一次,而25,45等分别触发一次。 • , 表示列出枚举值值。例如:在Minutes域使用5,20,则意味着在5和20分每分钟触发一次。

一些例子:

代码语言:javascript
复制
0 0 10,14,16 * * ? 每天上午10点,下午2点,4点触发 

0 0/30 9-17 * * ? 朝九晚五工作时间内每半小时触发  

0 0 12 ? * WED 表示每个星期三中午12点触发  

0 0 12 * * ? 每天中午12点触发 

0 15 10 ? * * 每天上午10:15触发 

0 15 10 * * ? 每天上午10:15触发 

0 15 10 * * ? * 每天上午10:15触发 

0 * 14 * * ? 在每天下午2点到下午2:59期间的每1分钟触发 

0 0/5 14 * * ? 在每天下午2点到下午2:55期间的每5分钟触发 

0 0/5 14,18 * * ? 在每天下午2点到2:55期间和下午6点到6:55期间的每5分钟触发 

0 0-5 14 * * ? 在每天下午2点到下午2:05期间的每1分钟触发 

0 10,44 14 ? 3 WED 每年三月的星期三的下午2:10和2:44触发 

0 15 10 ? * MON-FRI 周一至周五的上午10:15触发 

0 15 10 15 * ? 每月15日上午10:15触发 

0 15 10 L * ? 每月最后一日的上午10:15触发
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018年07月01日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 项目背景
  • 功能特点
  • 界面截图
  • 安装说明
  • Cron表达式说明
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档