Linux 指令学习之crontab

2023-11-12

crontab简介

crontab可以在指定的时间执行一个shell脚本以及执行一系列Linux命令.

运用场景

  • 服务器管理员定时备份数据库数据
  • 服务器管理员定时同步数据库数据
  • 服务器管理员定时备份服务器日志信息

crontab 常用命令

crontab –e     //修改 crontab 文件,如果文件不存在会自动创建。 
crontab –l      //显示 crontab 文件。 
crontab -r      //删除 crontab 文件。
crontab -ir     //删除 crontab 文件前提醒用户。

crontab 服务常用命令

service crond status     //查看crontab服务状态
service crond start     //启动服务 
service crond stop     //关闭服务 
service crond restart     //重启服务 
service crond reload     //重新载入配置

crontab 语法格式

*  *  *  *  *  command
分  时  日  月  周   命令

第1列表示分钟00~59 每分钟用*或者 */1表示

第2列表示小时00~23(0表示0点)

第3列表示日期01~31

第4列表示月份01~12

第5列标识号星期0~6(0表示星期天)

第6列要运行的命令

实例:

 实例:每个工作日23:59都进行数据库备份作业

59 23 * * 1-5 /home/sh/mysql-backup.sh

创建MySQL数据库备份脚本,mysql_backup.sh

#!/bin/bash
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin
export PATH
#数据库用户名
dbuser='root'
#数据库用密码
dbpasswd='512212'
#需要备份的数据库,多个数据库用空格分开
dbnames='db1 db2 db3'
#备份时间
backtime=`date +%Y%m%d%H%M%S`
#日志备份路径
logpath='/data/mysql/backup'
#数据备份路径
datapath='/data/mysql/backup'
 
#备份文件存放服务器及存放路径( 用户名@服务器IP:路径)
#backfileserver="root@192.168.0.70:/data/backup/"
 
 
 
#文件没有则创建
if [ ! -d "$datapath" ]; then
	mkdir -p "$datapath"
fi
 
if [ ! -d "$logpath" ]; then
	mkdir -p "$logpath"
fi
#日志记录头部
echo "备份时间为${backtime},备份数据库 ${dbnames} 开始" >> ${logpath}/mysqllog.log
 
#正式备份数据库
for dbname in $dbnames; do
	source=`mysqldump -u${dbuser} -p${dbpasswd} ${dbname}> ${datapath}/${dbname}_${backtime}.sql` 2>> ${logpath}/mysqllog.log
	#备份成功以下操作
	if [ "$?" == 0 ];then
		cd $datapath
		#为节约硬盘空间,将数据库压缩
		tar zcf ${dbname}_${backtime}.tar.gz ${dbname}_${backtime}.sql > /dev/null
		#删除原始文件,只留压缩后文件
		rm -f ${datapath}/${dbname}_${backtime}.sql
		#删除七天前备份,也就是只保存7天内的备份
		find $datapath -name "*.tar.gz" -type f -mtime +7 -exec rm -rf {} \; > /dev/null 2>&1
		echo "数据库表 ${dbname} 备份成功!!" >> ${logpath}/mysqllog.log
		
		#拷贝备份文件到备份服务器,使用scp时如何免输入密码,参考:https://jingyan.baidu.com/article/90bc8fc824e2dab752640c3f.html
		# scp "${dbname}_${backtime}.tar.gz" $backfileserver
		
	else
		#备份失败则进行以下操作
		echo "数据库表 ${dbname} 备份失败!!" >> ${logpath}/mysqllog.log
	fi
 
done

实例:每10分钟采集一次服务器性能(网卡流量、CPU、内存和磁盘占用率)

*/10 * * * * /home/sh/check.sh

创建Linux 服务器监控脚本,check.sh

#!/bin/bash
#这个脚本使用来统计CPU、磁盘、内存使用率、带宽的
total=0
system=0
user=0
i=0

#带宽使用情况
time=`date "+%Y-%m-%d %k:%M"`
day=`date "+%Y-%m-%d"`
minute=`date "+%k:%M"`
echo  "*************************************************************************" >> 123.txt
echo "统计开始时间:$day $minute" >> 123.txt

#循环五次,避免看到的是偶然的数据
echo "#带宽的使用情况:#" >>123.txt
while (( $i<5 ))
do
#原先的`ifconfig eth0|sed -n "7p"|awk '{print $2}'|cut -c7-`方式获取网卡的信息为空,已经注释掉
#rx_before=`ifconfig eth0|sed -n "7p"|awk '{print $2}'|cut -c7-`
#tx_before=`ifconfig eth0|sed -n "7p"|awk '{print $6}'|cut -c7-`
rx_before=$(cat /proc/net/dev | grep 'eth' | tr : " " | awk '{print $2}')
tx_before=$(cat /proc/net/dev | grep 'eth' | tr : " " | awk '{print $10}')
sleep 2
#rx_after=`ifconfig eth0|sed -n "7p"|awk '{print $2}'|cut -c7-`
#tx_after=`ifconfig eth0|sed -n "7p"|awk '{print $6}'|cut -c7-`
rx_after=$(cat /proc/net/dev | grep 'eth' | tr : " " | awk '{print $2}')
tx_after=$(cat /proc/net/dev | grep 'eth' | tr : " " | awk '{print $10}')

rx_result=$[(rx_after-rx_before)/1024/1024/2*8]
tx_result=$[(tx_after-tx_before)/1024/1024/2*8]
echo  "$time Now_In_Speed: $rx_result Mbps Now_OUt_Speed: $tx_result Mbps" >>123.txt

let "i++"
done

rx_result=$(cat 123.txt|grep "$time"|awk '{In+=$4}END{print In}')
tx_result=$(cat 123.txt|grep "$time"|awk '{Out+=$7}END{print Out}')
In_Speed=$(echo "scale=2;$rx_result/5"|bc)
Out_Speed=$(echo "scale=2;$tx_result/5"|bc)
#echo "#带宽的5次的平均值是:#" >>123.txt
echo  "$time In_Speed_average: $In_Speed Mbps Out_Speed_average: $Out_Speed Mbps" >>123.txt

#CPU使用情况
which sar > /dev/null 2>&1
if [ $? -ne 0 ]
then
  total=`vmstat 1 5|awk '{x+=$13;y+=$14}END{print x+y}'`
  average=$(echo "scale=2;$total/5"|bc)
fi
echo "#CPU使用率:#" >>123.txt
echo "Total CPU  is already use: $average%" >>123.txt
#磁盘使用情况(注意:需要用sed先进行格式化才能进行累加处理)
disk_used=$(df -m | sed '1d;/ /!N;s/\n//;s/ \+/ /;' | awk '{used+=$3} END{print used}')
disk_totalSpace=$(df -m | sed '1d;/ /!N;s/\n//;s/ \+/ /;' | awk '{totalSpace+=$2} END{print totalSpace}')
disk_all=$(echo "scale=4;$disk_used/$disk_totalSpace" | bc)
disk_percent1=$(echo $disk_all | cut -c 2-3)
disk_percent2=$(echo $disk_all | cut -c 4-5)
disk_warning=`df -m | sed '1d;/ /!N;s/\n//;s/ \+/ /;' | awk '{if ($5>85) print $5 $6;} '`
echo "#磁盘利用率#" >>123.txt
echo "hard disk has used: $disk_percent1.$disk_percent2%" >>123.txt
echo -e "\t\t#磁盘存在目录使用率超过85%报警#" >>123.txt
echo -e "\t\tover used: $disk_warning" >>123.txt


#内存使用情况
memery_used=$(free -m | awk 'NR==2' | awk '{print $3}')
buffer_used=$(free -m | awk 'NR==2' | awk '{print $6}')
cache_used=$(free -m | awk 'NR==2' | awk '{print $7}')
free=$(free -m | awk 'NR==2' | awk '{printf $4}')
memery_all=$(free -m | awk 'NR==2' | awk '{print $2}')
used_all=$[memery_all-(free+buffer_used+cache_used)]
echo "$used_all $memery_all $free" >>123.txt
memery_percent=$(echo "scale=4;$memery_used / $memery_all" | bc)
memery_percent2=$(echo "scale=4; $used_all / $memery_all" | bc)
percent_part1=$(echo $memery_percent | cut -c 2-3)
percent_part2=$(echo $memery_percent | cut -c 4-5) 
percent_part11=$(echo $memery_percent2 | cut -c 2-3)
percent_part22=$(echo $memery_percent2 | cut -c 4-5)
echo "#内存使用率#" >> 123.txt
echo "system memery is already use: $percent_part1.$percent_part2%" >>123.txt
echo "actual memery is already use: $percent_part11.$percent_part22%" >>123.txt

echo  "结束本次统计:$day $minute" >> 123.txt
echo  "*************************************************************************" >> 123.txt
echo -e "\n\n\n\n" >> 123.txt

创建shell脚本中用于接受linux 采集性能指标文件123.txt

touch 123.txt

给 check.sh 和123.txt 赋予全权限

chmod +777 check.sh

chmod +777 123.txt

知识拓展:正确、错误日志的输出是否写入到文件方法:

1.不输出任何内容(建议使用方法一)

*/1 * * * * /root/XXXX.sh >/dev/null 2>&1 
或
*/1 * * * * /root/XXXX.sh &>/dev/null    //&表示任何内容

2.将正确和错误日志都输出到 /tmp/load.log

*/1 * * * * /root/XXXX.sh > /tmp/load.log 2>&1

3.只输出正确日志到 /tmp/load.log

*/1 * * * * /root/XXXX.sh > /tmp/load.log
或
*/1 * * * * /root/XXXX.sh 1> /tmp/load.log    //1可以省略

4.只输出错误日志到 /tmp/load.log

*/1 * * * * /root/XXXX.sh 2> /tmp/load.log

部分解释:

/dev/null 代表空设备文件
> 代表重定向到哪里
1 表示stdout标准输出,系统默认值是1,所以">/dev/null"等同于"1>/dev/null"
2 表示stderr标准错误
& 表示等同于的意思,2>&1,表示2的输出重定向等同于1

知识拓展:crontab 定时任务脚本上锁

问题背景:在Linux系统使用crontab配置一个定时任务后,出现一种情况,如果我设置的crontab任务时间是每隔1分钟执行一次任务脚本,但是这个脚本执行时间超过了1分钟,比如2分钟,这时系统会再执行任务。导致两个相同的任务在执行。这种情况下可能会出现一些并发问题,严重时会导致出现脏数据/性能瓶颈的恶性循环。

解决办法

  • 思想
    • 利用Linux中的flock,将执行脚本的定时任务进程加上文件锁。
  • flock详解
    • 简介:
      • flock是对于整个文件的建议性锁。如果一个进程在一个文件(inode)上放了锁,那么其它进程是可以知道的。(建议性锁不强求进程遵守。)最棒的一点是,它的第一个参数是文件描述符,在此文件描述符关闭时,锁会自动释放。而当进程终止时,所有的文件描述符均会被关闭。
      • 当多个进程可能会执行同一个脚本,这些进程需要保证其它进程没有在操作,以免重复执行。通常,这样的进程会使用一个「锁文件」,也就是建立一个文件来告诉别的进程自己在运行,如果检测到那个文件存在则认为有操作同样数据的进程在工作。
    • 使用
      flock -h
      
      Usage:
       flock [options] <file|directory> <command> [command args]
       flock [options] <file|directory> -c <command>
       flock [options] <file descriptor number>
      
      Options:
      -s, --shared:    获得一个共享锁
      -x, --exclusive: 获得一个独占锁
      -u, --unlock:    移除一个锁,通常是不需要的,脚本执行完会自动丢弃锁
      -n, --nonblock:  如果没有立即获得锁,直接失败而不是等待
      -w, --timeout:   如果没有立即获得锁,等待指定时间
      -o, --close:     在运行命令前关闭文件的描述符号。用于如果命令产生子进程时会不受锁的管控
      -c, --command:   在shell中运行一个单独的命令
      -h, --help       显示帮助
      -V, --version:   显示版本

   实战

# 每30分钟执行数据库备份,验证flock 文件锁功能
*/30 * * * * flock -xn /home/lock/mysql_backup.lock -c '/bin/sh /home/sh/mysql_backup.sh >/dev/null 2>&1'
  • 脚本解释
    • flock -xn /home/lock/mysql_backup.lock -c
      • 对后面的脚本进程加文件锁,格式为:flock 参数 锁文件地址 参数
    • '/bin/sh /home/sh/mysql_backup.sh >/dev/null 2>&1'
      • 执行脚本地址及打印日志
      • 注意:一定要加上引号,否则脚本不执行!!!
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Linux 指令学习之crontab 的相关文章

  • 在非实时操作系统/内核上执行接近实时任务的最佳方法是什么?

    在一台 GNU Linux 机器上 如果想要执行 实时 亚毫秒级时间关键 任务 您几乎总是必须经历漫长 复杂且容易出现问题的内核补丁过程 以提供足够的支持 1 http en wikipedia org wiki RTLinux Backg
  • 提高mysql导入速度[关闭]

    Closed 这个问题是与编程或软件开发无关 help closed questions 目前不接受答案 我有一个很大的数据库22GB 我曾经用过进行备份mysqldumpgzip 格式的命令 当我提取 gz 文件时 它会生成 sql文件的
  • Visual Studio - X11:缺少 DISPLAY 环境变量

    我正在使用 Visual Studio 2019 Enterprise 开发跨平台 Windows Linux x64 GUI 应用程序 在这个 2019 版本中 我们可以使用 Visual Studio调试平台 Windows 本机 和
  • 用于时间线数据的类似 gnuplot 的程序

    我正在寻找一个类似 gnuplot用于在时间轴中绘制数据图表的程序 类似 gnuplot 在 Linux 上运行 命令行功能 GUI 对我帮助不大 可编写脚本的语法 输出为 jpg png svg 或 gif 输出应该是这样的 set5 s
  • pthread_self() 返回的线程 ID 与调用 gettid(2) 返回的内核线程 ID 不同

    这句话来自于pthread self 的手册页 http linux die net man 3 pthread self 那么 我应该根据什么来决定是否应该使用pthread self or gettid确定哪个线程正在运行该函数 两者都
  • Ctrl-p 和 Ctrl-n 在 Docker 下表现异常

    For the life of me I can t seem to figure out why ctrl p and ctrl n don t work like they re supposed to under the Docker
  • php_network_getaddresses: getaddrinfo 失败: 名称或服务未知 (0) 连接失败..!

    我正在使用 php 邮件程序功能 但出现以下错误 如何修复它 2016 01 22 06 15 48 SMTP 错误 无法连接到服务器 php network getaddresses getaddrinfo失败 名称或服务未知 0 连接失
  • 用于获取特定用户 ID 和进程数的 Bash 脚本

    我需要 bash 脚本来计算特定用户或所有用户的进程 我们可以输入 0 1 或更多参数 例如 myScript sh root deamon 应该像这样执行 root 92 deamon 8 2 users has total proces
  • 亚马逊 Linux - 安装 openjdk-debuginfo?

    我试图使用jstack在 ec2 实例上amazon linux 所以我安装了openjdk devel包裹 sudo yum install java 1 7 0 openjdk devel x86 64 但是 jstack 引发了异常j
  • 如何回忆上一个 bash 命令的参数?

    Bash 有没有办法回忆上一个命令的参数 我通常这样做vi file c其次是gcc file c Bash 有没有办法回忆上一个命令的参数 您可以使用 or 调用上一个命令的最后一个参数 Also Alt can be used to r
  • Java时区混乱

    我正在运行 Tomcat 应用程序 并且需要显示一些时间值 不幸的是 时间快到了 还有一个小时的休息时间 我调查了一下 发现我的默认时区被设置为 sun util calendar ZoneInfo id GMT 08 00 offset
  • 有没有办法提高linux管道的性能?

    我正在尝试使用 64 位将超高速数据从一个应用程序传输到另一个应用程序CentOS http en wikipedia org wiki CentOS6 我使用以下方法进行了基准测试dd发现阻碍我的是管道而不是程序中的算法 我的目标是达到
  • Linux 中的 Windows NAmed Pipes 替代品

    我们正在将现有的 Windows 代码移植到 Linux 我们使用 ACE 作为抽象层 我们使用 Windows 命名管道与多个客户端进行通信并执行重叠操作 linux 下这个相当于什么 我检查了linux命名管道 FIFO 但它们似乎只支
  • 在 MacOS 上构建需要 net461 的 dotnet SDK 项目的最简单方法

    我有一个 dotnet SDK sln and a build proj with
  • 使用 .htaccess 启用 PHP 短标签

    我在自己的 Centos 服务器上设置了 Apache 并具有多个虚拟 Web 服务器 并且我希望仅为位于以下位置的其中一个 Web 服务器启用 PHP 短标记 var www ostickets html 我可以通过添加成功启用短标签sh
  • 在 Windows / Linux 中创建 Mac 包

    我自己努力制作一个 r 包 我按照 stackoverflow 中上一个问题的说明进行操作如何为外行开发软件包 http cran r project org bin windows Rtools 以下是我根据上一个问题采取的步骤 在新的
  • PHP mail() 函数不发送邮件

    我有一个小问题 我正在使用一个工作脚本 在我的测试帐户 共享服务器上工作 使用 mail 函数通过 PHP 发送邮件 我刚刚得到了一个专用服务器 但我还无法让该功能发挥作用 在过去的 10 个小时左右的时间里 我阅读了有关 BIND 用于
  • 如何在C程序中直接改变显存映射来绘制像素(无需库函数)

    是否可以通过使用 C 程序更改 RAM 中屏幕 视频即监视器 内存映射中的值来显示黑点 我不想使用任何库函数 因为我的主要目标是学习如何开发简单的操作系统 我尝试访问起始屏幕内存映射 即 0xA0000 在 C 中 我尝试运行该程序 但由于
  • 使用 hcitool 扫描低功耗蓝牙?

    当我运行此命令时 BLE 设备扫描仅持续 5 秒 sudo timeout 5s hcitool i hci0 lescan 输出显示在终端屏幕中 但是 当我将输出重定向到文件以保存广告设备的地址时 每次运行该命令时 我都会发现该文件是空的
  • 在Linux中创建可执行文件

    我计划做的一件事是编写 非常简单的 Perl 脚本 并且我希望能够在不从终端显式调用 Perl 的情况下运行它们 我明白 要做到这一点 我需要授予他们执行权限 使用 chmod 执行此操作非常简单 但它似乎也是一个稍微费力的额外步骤 我想要

随机推荐

  • Python使用历史数据模拟法计算投资组合VaR(数据来源为Tushare)

    Python如何使用历史数据模拟法计算投资组合VaR 数据来源为Tushare 本文数据可以点赞关注私信我获取 VaR Value at Risk 是一种常用的风险管理指标 用于衡量投资组合在特定时间内的最大可能损失 历史数据模拟法是一种计
  • Android:年过35岁的程序员还有出路吗,rxjava面试题

    通过上面网友们的分析 其实大家也看的出一个情况 领导选择用你的标准之一 一定是能力的大小 如果技术过硬 年龄从来不会是第一标准 还记得你第一次写代码的时候吗 那种难以抗拒的兴奋和激动 你说你不如年轻人敏捷了 不如他们聪明了 都不是 只是因为
  • C++转换函数

    一 定义 转换构造函数是将其他类型转化为当前class类型 反之 就是转换函数 转换函数的定义格式 operator type TODO return data operator 是 C 关键字 type 是要转换的目标类型 data 是要
  • 【学习笔记】编程规约

    概述 阿里Java开发手册对编程规约 异常日志 单元测试 安全规约 MySQL数据库 工程结构 设计规约进行了规范并且进行了开源 整个手册针对java程序的诞生过程进行较为全面的规范 并且有插件 P3C 进行检查 结尾附地址 即使不是jav
  • 剑指offer_第3题_从尾到头打印链表

    题目描述 输入一个链表 按链表值从尾到头的顺序返回一个ArrayList 链表结构 class ListNode def init self x self val x self next None 理解 什么是链表 python数据结构之链
  • C语言从字符串中提取数字

    利用正则表达式 参考 http blog csdn net yangbingzhou article details 51352648 include
  • 使用AD(Altium Designer)三年的笔记(虽然很口语化,但是好记性不如烂笔头嘛~开熏)

    AD使用心得 1 放置过孔阵列 首先在边角或中间放置一个过孔 选中此过孔 高亮显示 Ctrl C 此时光标变为大十字 将十字放在过孔的中心 左键 编辑 特殊粘贴 在弹出的复选框中选择前两项 2 怎样将PCB板的四个角画成圆弧形 Keepou
  • RXJS部分操作符解释

    RXJS部分操作符解释 div div
  • ftp服务器vsftpd的安装与配置[ubuntu, linux]

    Ubuntu下Ftp的软件有好多种 google一下 各种的一些大致特点 wu Ftp 比较老牌 但针对它的攻击比较多 设置比较麻烦 但功能比较强大 proFtpd 能实现wu Ftp以及server U的所有功能 安全性也较高 但比起vc
  • 重磅!最全面最好用的保险行业数据解决方案全面上线!

    随着数字化时代的到来 保险机构面临着直销平台客户转化率低 代理人员队伍低效的困境 为了解决这些问题 帆软保险行业数据解决方案使用科学的数据分析报表为你带来承保 保全 批改 理赔 续期 精算 投资等一整套的数据应用场景 帮助多家企业达到降本增
  • java Lambda表达式详解

    文章目录 一 背景 1 1语法 1 2函数式接口 二 Lambda的基本使用 2 1引子 2 2常见的使用方式 2 3语法小结 三 变量捕获 3 1 匿名内部类 3 2 匿名内部类的变量捕获 3 3Lambda的变量捕获 四 Lambda在
  • 【C++】关于STL容器删除erase问题

    对于容器vector set 最近在看阿秀的八股文pdf时发现一条似乎有点问题 于是做了实验 以vector和set为例 这两个容器的erase函数都会返回下一个元素的迭代器 但是顺序容器vector确实不能使用erase it 此时it指
  • Clion Messages 乱码

    使用clion 时 编译错误时 console 输出时有乱码 在 Editor gt General gt Console gt Default Encoding 里修改设置为UTF 8 就正常了
  • [运维] nginx不允许ip访问

    nginx不允许IP访问 编辑nginx conf文件 编辑server前如下所示 server listen 80 server name localhost charset koi8 r access log logs host acc
  • 开发板测试网口带宽方法

    由于项目需要 需对开发板千兆网口传输速率进行测试 开始想到的方法十分简单 直接在开发板上移植一个ftp服务器 然后利用Ubuntu上的ftp客户端进行文件传输 以测试网口文件传输速度 但这样做需要将测试文件放到SD卡中 而SD卡的文件传输速
  • torch::jit::load(model_path) 失败原因

    下面是Pytorch配套的视频教程 Pytorch 快速实战教程 0 Pytorch实战前言 哔哩哔哩 bilibili Pytorch 分割实战教程 介绍一个图像分割的网络搭建利器 Segmentation model PyTorch 哔
  • std::vector简介及其使用(转)

    std vector简介及其使用 本文中的vector指的是std vector C 11标准 Vector概述 template
  • 修改组件默认样式之/deep/(less,sass)

    在使用第三方组件时有时候我们想修改组件的样式 可以使用全局的方式 即不使用scoped 如果多处共用我们只需要统一修改 假如有多种类型呢 我们不得不另起一个名字 如果我们想要封装一个组件 定义的样式希望在该文件中生效 不影响其他组件 我们将
  • weex初始的坎坷之路

    年前 老大就交代年后要把某个页面weex实现 当时不了解weex 连名字都叫不出来 问了度娘 才知道跟react native类似的三端开发 春节回来就开始学 入门很坎坷 因为他是以vue为模板引擎 我没学过vue 当时会react 之前也
  • Linux 指令学习之crontab

    crontab简介 crontab可以在指定的时间执行一个shell脚本以及执行一系列Linux命令 运用场景 服务器管理员定时备份数据库数据 服务器管理员定时同步数据库数据 服务器管理员定时备份服务器日志信息 crontab 常用命令 c