通过Crontab-UI提高cron任务管理效率,实现安全任务管理
liuian 2024-12-01 00:59 40 浏览
之前介绍了使用一文精通crontab服务,并实现tomcat状态监测,通过编辑crontab文件,创建及删除cron任务。这种编辑方式在任务不多的情况下,比较便捷,当任务过多时,仍然不方便管理,有可能不小心修改错了一行表达式,就会导致任务失败或者服务宕机。如果可以通过web页面的方式对cron任务进行管理,那么这种错误的可能性就会降低。
Crontab-UI的应用
在日常开发中,总会遇到定时任务。在Spring体系中,我们会想到Quartz、Spring Schedule以及一些分布式任务xxl-job等。但是在Unix/Linux系统中,首先想到的解决方案大概会是cron定时任务,它能够很好的帮助我们在类Unix系统中有计划性的创建周期性命令或者任务,并有计划的去执行这些周期性任务。许多服务端开发以及运维工程师在定时任务这块,确实大量使用了cron定时任务来解决问题。cron定时任务也比较简单,应用并不是特别困难的事情,但是对于不熟悉的开发者,以及当我们创建了大量的定时任务时,创建新的、更新旧的任务,都要通过对crontab文件进行修改,不可避免地会出现错误,如果因为修改时导致一些任务发生错误,可能会引起生产系统的一些问题,同时如果因为crontab的定义错误导致cron任务宕机,那么对我们的工作都会带来很严重的损失。为了避免以上问题,可以使用crontab-ui(crontab任务的图形管理系统),它提供了Web管理界面,我们可以通过这一工具很轻松的管理cron任务,并且任务创建后,可以先执行一次进行测试,极大的方便了cron任务的应用。
crontab-ui是基于NodeJS开发的且在GitHub开源。使用crontab-ui,主要是创建、删除、启动、停止cron任务时,不再需要手动编辑crontab文件,只要通过管理工具操作即可完成上述主要的工作。同时crontab-ui也提供备份cron任务、导入、导出工具,以及支持错误日志等功能。使用该工具将能够在很大程度上减轻我们的工作量。
crontab-ui支持npm部署以及docker部署,两者的安装过程都比较简单,如下介绍了安装及使用过程。
docker部署
# 拉取镜像
docker pull alseambusher/crontab-ui
# 极简启动
docker run -d -p 8000:8000 alseambusher/crontab-ui
# 指定用户名和密码
docker run -e BASIC_AUTH_USER=admin -e BASIC_AUTH_PWD=123456 -d -p 8000:8000 alseambusher/crontab-ui
# 指定数据存储和日志输出位置
mkdir -p /data/crontabs/logs
docker run --mount type=bind,source="$(pwd)"/crontabs/,target=/crontab-ui/crontabs/ -d -p 8000:8000 alseambusher/crontab-ui
# 账号和存储位置指定
# /data/crontabs上述创建
docker run --mount type=bind,source=/data/crontabs/,target=/crontab-ui/crontabs/ -v /data:/data:rw -e BASIC_AUTH_USER=admin -e BASIC_AUTH_PWD=123456 TZ=Asia/Shanghai -d -p 8000:8000 alseambusher/crontab-ui
使用docker启动crontab-ui时,cron都是使用镜像去创建的,因此需要挂载目录,让镜像使用宿主机的脚本等资源。同时还要注意的是因为cron服务在镜像中,因此时间等信息也是使用的镜像服务,需要设置时间参数。当通过镜像方式部署服务,所有创建的cron都会被创建在镜像中,宿主机并不会创建cron服务。
npm安装
Crontab-UI采用NodeJS开发,因此安装之前需要先安装npm。npm安装完成之后,Crontab-UI的安装非常简单。
# 安装Crontab-UI
npm install -g crontab-ui
# 安装完成之后,启动也比较简单,最简单的启动方式
crontab-ui
# 指定用户名密码以及端口号启动
HOST=0.0.0.0 PORT=8080 CRON_DB_PATH=/data/crontabs BASIC_AUTH_USER=admin BASIC_AUTH_PWD=123456 crontab-ui
Crontab-UI系统使用
Crontab-UI服务部署并启动后,通过访问http://ip:8080,首先就会要求登录admin/123456,登录后,将看到Cronjobs任务管理首页,如下图。
以下应用过程均为docker部署的服务。
创建一个任务
点击New按钮,在打开的任务创建栏目中,输入相应的定时任务信息后,点击Save按钮,即可创建一个cron定时任务。
- Name,可选项,任务名称,建议填写,便于管理。
- Command想要执行的命令,这里是要执行一个脚本。
- Quick Schedule设置周期执行,可以按照启动、每小时、每日、每周、每月、每年等指标快速制定计划任务。当然应用最多的仍然是cron表达式来制定周期性任务,当使用cron表达式时,书写完成需要点击Set按钮,此时Job栏目就会显示完整的cron任务表达式。
- Enable error logging,当勾选时,该定时任务将会记录错误日志,且可以通过web管理页面直接查看错误日志,在工作中,查找问题将会非常有帮助。
下图为示例任务创建,每分钟执行一个脚本。
当点击Save按钮后,将会创建该任务,如下图所示。
当任务创建完成后,如果发现有需要调整的地方,可以通过Edit按钮进行任务修改。本例中,将对hello任务轮播任务进行调整,之前创建时,没有勾选打印日志,勾选后,点击保存,如下图所示。此时将会出现日志查看按钮。
启动任务
当点击运行时,会执行一次,此时并没有实现每分钟轮播功能,查看容器cron列表,也没有发现任何任务信息。需要点击Save to crontab按钮后,才能将cron任务配置写入到crontab中。本例使用了docker环境部署,因此可以登录到crontab-ui容器,查看容器的crontab任务情况
# 登录容器
docker exec -it alseambusher/crontab-ui sh
# 只运行任务,没有点击Save to crontab按钮时,查看任务。此时服务器并没有crontab任务写入,并且查看日志只有一次输出,并没有循环执行
/crontab-ui # crontab -l
# 点击Save to crontab按钮后,监控日志输出,发现每分钟打印一次,任务循环执行,再次查看容器的crontab任务列表, 发现任务已成功创建
/crontab-ui # crontab -l
# */1 * * * * ((({ /bin/sh /data/sh/hello.sh; } | tee /etc/crontabs/xPLSahWYLOVOW9pP.stdout) 3>&1 1>&2 2>&3 | tee /etc/crontabs/xPLSahWYLOVOW9pP.stderr) 3>&1 1>&2 2>&3)
停止任务
点击Disable按钮,可以将任务置为不可用,此时任务仍然在运行,置为不可用后,通过点击Save to crontab按钮后,将配置写入crontab中,就可以实现关停任务。
获取本机已有的crontab任务
当部署Crontab-UI之前,已经通过crontab -e命令创建了任务,也可以纳入到Crontab-UI进行管理。通过点击Get from crontab按钮从本机获取crontab服务。
备份任务
点击页面上的Backup按钮,弹出框确认备份,即可实现当前所有cron任务的备份。crontab文件出现问题时,可以通过备份来进行恢复。
备份之后,如果不小心删除了某些任务,可以通过恢复到指定的备份。如下图恢复备份
从Backups列表中选择一个备份点,将进入备份恢复页面,在该页面用户可以选择恢复,也可以选择删除备份点。
导入/导出cron任务
导入/导出一般用于多台机器执行相同的任务。当有这种需求时,可以先在一台机器上进行cron服务配置,配置完成后可以通过导出按钮,将已创建好的任务数据库下载到本地。然后在其他需要执行这些任务的机器上部署Crontab-UI服务,并通过导入按钮,选择上述导出的本地数据库,可以实现快速任务构建。
导出的文件一般是crontab.db命名,可以使用记事本打开该文档进行查看。该数据文件采用行JSON的形式存储,一行JSON对象描述一个任务,如下所示:
{
"name": "hello任务轮询",
"command": "/bin/sh /data/sh/hello.sh",
"schedule": "*/1 * * * *",
"stopped": true,
"timestamp": "Thu Aug 12 2021 10:54:46 GMT+0000 (Coordinated Universal Time)",
"logging": "false",
"mailing": {},
"created": 1628765686866,
"saved": true,
"_id": "xPLSahWYLOVOW9pP"
}
通过导入,可以在很大程度上加快内网定时任务的部署,同时因为是依靠导出再导入的方式,从某种方面看,只要搞定一台服务器的任务后,其他服务器的任务不会再出现BUG的现象,这将会在减轻任务部署的工作量的同时,会提高任务部署质量。
- 上一篇:Go 每日一库之定时任务库:cron
- 下一篇:定时任务之cron
相关推荐
- Python生态下的微服务框架FastAPI
-
FastAPI是什么FastAPI是一个用于构建API的web框架,使用Python并基于标准的Python类型提示。与flask相比有什么优势高性能:得益于uvloop,可达到与...
- SpringBoot:如何解决跨域问题,详细方案和示例代码
-
跨域问题在前端开发中经常会遇到,特别是在使用SpringBoot框架进行后端开发时。解决跨域问题的方法有很多,我将为你提供一种详细的方案,包含示例代码。首先,让我们了解一下什么是跨域问题。跨域是指在...
- 使用Nginx轻松搞定跨域问题_使用nginx轻松搞定跨域问题的方法
-
跨域问题(Cross-OriginResourceSharing,简称CORS)是由浏览器的同源策略引起的。同源策略指的是浏览器限制来自不同源(协议、域名、端口)的JavaScript对资源的...
- spring boot过滤器与拦截器的区别
-
有小伙伴使用springboot开发多年,但是对于过滤器和拦截器的主要区别依然傻傻分不清。今天就对这两个概念做一个全面的盘点。定义与作用范围过滤器(Filter):过滤器是一种可以动态地拦截、处理和...
- nginx如何配置跨域_nginx配置跨域访问
-
要在Nginx中配置跨域,可以使用add_header指令来添加Access-Control-Allow-*头信息,如下所示:location/api{if($reques...
- 解决跨域问题的8种方法,含网关、Nginx和SpringBoot~
-
跨域问题是浏览器为了保护用户的信息安全,实施了同源策略(Same-OriginPolicy),即只允许页面请求同源(相同协议、域名和端口)的资源,当JavaScript发起的请求跨越了同源策略,...
- 图解CORS_图解数学
-
CORS的全称是Cross-originresourcesharing,中文名称是跨域资源共享,是一种让受限资源能够被其他域名的页面访问的一种机制。下图描述了CORS机制。一、源(Orig...
- CORS 幕后实际工作原理_cors的工作原理
-
跨域资源共享(CORS)是Web浏览器实施的一项重要安全机制,用于保护用户免受潜在恶意脚本的攻击。然而,这也是开发人员(尤其是Web开发新手)感到沮丧的常见原因。小编在此将向大家解释它存在...
- 群晖无法拉取Docker镜像?最稳定的方法:搭建自己的加速服务!
-
因为未知的原因,国内的各大DockerHub镜像服务器无法使用,导致在使用群晖时无法拉取镜像构建容器。网上大部分的镜像加速服务都是通过Cloudflare(CF)搭建的,为什么都选它呢?因为...
- Sa-Token v1.42.0 发布,新增 API Key、TOTP 验证码等能力
-
Sa-Token是一款免费、开源的轻量级Java权限认证框架,主要解决:登录认证、权限认证、单点登录、OAuth2.0、微服务网关鉴权等一系列权限相关问题。目前最新版本v1.42.0已...
- NGINX常规CORS错误解决方案_nginx配置cors
-
CORS错误CORS(Cross-OriginResourceSharing,跨源资源共享)是一种机制,它使用额外的HTTP头部来告诉浏览器允许一个网页运行的脚本从不同于它自身来源的服务器上请求资...
- Spring Boot跨域问题终极解决方案:3种方案彻底告别CORS错误
-
引言"接口调不通?前端同事又双叒叕在吼跨域了!""明明Postman能通,浏览器却报OPTIONS403?""生产环境跨域配置突然失效,凌晨3点被夺命连环Ca...
- SpringBoot 项目处理跨域的四种技巧
-
上周帮一家公司优化代码时,顺手把跨域的问题解决了,这篇文章,我们聊聊SpringBoot项目处理跨域的四种技巧。1什么是跨域我们先看下一个典型的网站的地址:同源是指:协议、域名、端口号完全相...
- Spring Cloud入门看这一篇就够了_spring cloud使用教程
-
SpringCloud微服务架构演进单体架构垂直拆分分布式SOA面向服务架构微服务架构服务调用方式:RPC,早期的webservice,现在热门的dubbo,都是RPC的典型代表HTTP,HttpCl...
- 前端程序员:如何用javascript开发一款在线IDE?
-
前言3年前在AWSre:Invent大会上AWS宣布推出Cloud9,用于在云端编写、运行和调试代码,它可以直接运行在浏览器中,也就是传说中的WebIDE。3年后的今天随着国内云计算的发...
- 一周热门
-
-
【验证码逆向专栏】vaptcha 手势验证码逆向分析
-
Python实现人事自动打卡,再也不会被批评
-
Psutil + Flask + Pyecharts + Bootstrap 开发动态可视化系统监控
-
一个解决支持HTML/CSS/JS网页转PDF(高质量)的终极解决方案
-
再见Swagger UI 国人开源了一款超好用的 API 文档生成框架,真香
-
网页转成pdf文件的经验分享 网页转成pdf文件的经验分享怎么弄
-
C++ std::vector 简介
-
飞牛OS入门安装遇到问题,如何解决?
-
系统C盘清理:微信PC端文件清理,扩大C盘可用空间步骤
-
10款高性能NAS丨双十一必看,轻松搞定虚拟机、Docker、软路由
-
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)
- mysql刷新权限 (34)