澳门新浦京娱乐场网站-www.146.net-新浦京娱乐场官网
做最好的网站

澳门新浦京娱乐场网站:crontab执行不生效,详解

  转载请注明: 

linux服务器性能(网卡流量、CPU、内存、磁盘使用率)监控,linux流量

  广义的网站的监控涵盖所有的非业务行为的数据采集与管理,包括数据分析师和产品设计师使用的网站用户行为日志、业务运行数据,以及供运维工程师和开发工程师使用的性能统计数据等。

     本文主要是通过shell脚本来收集服务器性能指标,如系统load、内存占用、磁盘IO、CPU占用,并将其写入一个文件中,及时判断应用情况,防患于未然 。

  实现步骤如下:

  第一步:编写shell脚本,如下:

    vim check.sh,添加下面脚本之后保存

  1 #!/bin/bash
  2 #这个脚本使用来统计CPU、磁盘、内存使用率、带宽的
  3 #初始化一些下面用到的变量
  4 total=0
  5 system=0
  6 user=0
  7 i=0
  8 
  9 time=`date " %Y-%m-%d %k:%M"`
 10 day=`date " %Y-%m-%d"`
 11 minute=`date " %k:%M"`
 12 echo  "*************************************************************************" >> 1234.txt
 13 echo "统计开始时间:$day $minute" >> 1234.txt
 14 
 15 #带宽使用情况
 16 echo "#带宽的使用情况:#" >>1234.txt
 17 #循环五次,避免看到的是偶然的数据
 18 while (( $i<5 ))
 19 do
 20 #原先的`ifconfig eth0|sed -n "7p"|awk '{print $2}'|cut -c7-`方式获取网卡的信息为空,已经注释掉
 21 #rx_before=`ifconfig eth0|sed -n "7p"|awk '{print $2}'|cut -c7-`
 22 #tx_before=`ifconfig eth0|sed -n "7p"|awk '{print $6}'|cut -c7-`
 23 rx_before=$(cat /proc/net/dev | grep 'eth' | tr : " " | awk '{print $2}')
 24 tx_before=$(cat /proc/net/dev | grep 'eth' | tr : " " | awk '{print $10}')
 25 #休眠2s
 26 sleep 2
 27 #用sed先获取第7列,再用awk获取第2列,再cut切割,从第7个到最后,即只切割网卡流量数字部分
 28 #rx_after=`ifconfig eth0|sed -n "7p"|awk '{print $2}'|cut -c7-`
 29 #tx_after=`ifconfig eth0|sed -n "7p"|awk '{print $6}'|cut -c7-`
 30 rx_after=$(cat /proc/net/dev | grep 'eth' | tr : " " | awk '{print $2}')
 31 tx_after=$(cat /proc/net/dev | grep 'eth' | tr : " " | awk '{print $10}')
 32 #注意下面截取的相差2秒的两个时刻的累计和发送的bytes(即累计传送和接受的位)
 33 rx_result=$[(rx_after-rx_before)/1024/1024/2*8]
 34 tx_result=$[(tx_after-tx_before)/1024/1024/2*8]
 35 echo  "$time Now_In_Speed: $rx_result Mbps Now_OUt_Speed: $tx_result Mbps" >>1234.txt
 36 let "i  "
 37 done
 38 #注意下面grep后面的$time变量要用双引号括起来
 39 rx_result=$(cat 1234.txt|grep "$time"|awk '{In =$4}END{print In}')
 40 tx_result=$(cat 1234.txt|grep "$time"|awk '{Out =$7}END{print Out}')
 41 In_Speed=$(echo "scale=2;$rx_result/5"|bc)
 42 Out_Speed=$(echo "scale=2;$tx_result/5"|bc)
 43 #echo "#带宽的5次的平均值是:#" >>1234.txt
 44 echo  "$time In_Speed_average: $In_Speed Mbps Out_Speed_average: $Out_Speed Mbps" >>1234.txt
 45 
 46 
 47 #CPU使用情况
 48 #使用vmstat 1 5命令统计5秒内的使用情况,再计算每秒使用情况
 49 which sar > /dev/null 2>&1
 50 if [ $? -ne 0 ]
 51 then
 52   total=`vmstat 1 5|awk '{x =$13;y =$14}END{print x y}'`
 53   average=$(echo "scale=2;$total/5"|bc)
 54 fi
 55 echo "#CPU使用率:#" >>1234.txt
 56 echo "Total CPU  is already use: $average%" >>123.txt
 57 
 58 
 59 #磁盘使用情况(注意:需要用sed先进行格式化才能进行累加处理)
 60 disk_used=$(df -m | sed '1d;/ /!N;s/n//;s/  / /;' | awk '{used =$3} END{print used}')
 61 disk_totalSpace=$(df -m | sed '1d;/ /!N;s/n//;s/  / /;' | awk '{totalSpace =$2} END{print totalSpace}')
 62 disk_all=$(echo "scale=4;$disk_used/$disk_totalSpace" | bc)
 63 disk_percent1=$(echo $disk_all | cut -c 2-3)
 64 disk_percent2=$(echo $disk_all | cut -c 4-5)
 65 disk_warning=`df -m | sed '1d;/ /!N;s/n//;s/  / /;' | awk '{if ($5>85) print $5 $6;} '`
 66 echo "#磁盘利用率#" >>123.txt
 67 echo "hard disk has used: $disk_percent1.$disk_percent2%" >>123.txt
 68 #echo -e "tt.." 表示换行
 69 echo -e "tt#磁盘存在目录使用率超过85%报警#" >>123.txt
 70 echo -e "ttover used: $disk_warning" >>123.txt
 71 
 72 
 73 #内存使用情况
 74 #获得系统总内存
 75 memery_all=$(free -m | awk 'NR==2' | awk '{print $2}')
 76 #获得占用内存(操作系统 角度)
 77 system _memery_used =$(free -m | awk 'NR==2' | awk '{print $3}')
 78 #获得buffer、cache占用内存,当内存不够时会及时回收,所以这两部分可用于可用内存的计算
 79 buffer_used=$(free -m | awk 'NR==2' | awk '{print $6}')
 80 cache_used=$(free -m | awk 'NR==2' | awk '{print $7}')
 81 #获得被使用内存,所以这部分可用于可用内存的计算,注意计算方法
 82 actual_used_all =$[memery_all-(free buffer_used cache_used)]
 83 #获得实际占用的内存
 84 actual_used_all=`expr $memery_all - $free   $buffer_used   $cache_used `
 85 echo "$used_all" >> 123.txt
 86 memery_percent=$(echo "scale=4;$system _memery_used / $memery_all" | bc)
 87 memery_percent2=$(echo "scale=4; $actual_used_all / $memery_all" | bc)
 88 percent_part1=$(echo $memery_percent | cut -c 2-3)
 89 percent_part2=$(echo $memery_percent | cut -c 4-5)
 90 percent_part11=$(echo $memery_percent2 | cut -c 2-3)
 91 percent_part22=$(echo $memery_percent2 | cut -c 4-5)
 92 echo "#内存使用率#" >> 123.txt
 93 #获得占用内存(操作系统角度)
 94 echo "system memery is already use: $percent_part1.$percent_part2%" >>123.txt
 95 #获得实际内存占用率
 96 echo "actual memery is already use: $percent_part11.$percent_part22%" >>123.txt
 97 echo "buffer is already used : $buffer_used M" >>123.txt
 98 echo "cache is already used : $cache_used M" >>123.txt
 99 
100 
101 echo  "结束本次统计:$day $minute" >> 123.txt
102 echo  "*************************************************************************" >> 123.txt
103 echo -e "nnnn" >> 123.txt

 第二步:创建shell脚本中用到两个文件123.txt和1234.txt
    touch 123.txt
 第三步:给check.sh和123.txt授予所有权限
  chmod 777 check.sh
  chmod 777 123.txt

澳门新浦京娱乐场网站 1

  第四步:执行check.sh脚本

    ./check.sh

澳门新浦京娱乐场网站 2

  第五步:查看执行写入文件的情况

澳门新浦京娱乐场网站 3

出现这信息表名脚本成功运行实时统计情况。

 

若是想使用定时任务,可使用crontab进行设置,请参见这篇文章

crontab的两种配置方式  

广义的网站的监控涵盖所有的非业务行为的数据采集与管理,包括数...

背景:不知道什么原因脚本手动执行:正常;crontab执行不生效;

定时任务 Crontab命令 详解整理

澳门新浦京娱乐场网站 4

前言

crontab是Unix和Linux用于设置周期性被执行的指令,是互联网很常用的技术,很多任务都会设置在crontab循环执行,如果不使用crontab,那么任务就是常驻程序,这对你的程序要求比较高,一个要求你的程序是24X7小时不宕机,一个是 要求你的调度程序比较可靠,实际工作中,90%的程序都没有必要花这么多时间和精力去解决上面的两个问题的,只需要写好自己的业务逻辑,通过crond这 个工业级程序去调度就行了,crond的可靠性,健壮性,大家应该是毫无疑问的。

crontab简易入门

假设我要设置一个任务,每分钟就要做一个数据同步,这个同步脚本的路径是/home/blue/do/rsyncfile.sh,那么我可以在这么配置,使用blue用户,在终端输入

1``crontab``-e

2``# 此时会进入 vi 的编辑画面让您编辑工作!注意到,每项工作都是一行。

3``#分 时 日 月 周 |<==============任务的完整命令行

4````* * * * * /home/blue/``do``/rsyncfile.sh

默认情况下,任何使用者只要不被列入/etc/cron.deny当中,那么他就可以直接下达『crontab -e』去编辑自己的例行性命令了!整个过程就如同上面提到的,会进入 vi 的编辑画面, 然后以一个工作一行来编辑,编辑完毕之后输入『:wq』储存后离开 vi 就可以了!

假如我们需要修改为每5分钟运行数据同步的脚本,那么同样使用crontab -e进入编辑:

1``*/5 * * * * /home/blue/``do``/rsyncfile.sh

假如服务器出了问题,有一天的数据没有同步,于是我们就需要补数据了,假设这个补数据的脚本是/home/blue/do /rsyncfile_day.sh,但是白天是高峰期,晚上用户不多,是低峰期,我们补数据会占用大量带宽,尤其是白天,会影响正常业务,所以一般我们 可以让补数据任务在凌晨2点开始跑,那么同样使用crontab -e进入编辑:

1``0 2 1 4 * /home/blue/``do``/rsyncfile_day.sh

这样,在4月1号凌晨2点0分就会开始启动我们的补数据的脚本了。

同步数据,在互联网公司是再平常不过的任务了,这里大家可以看到crontab的魅力所在了,只需要写最简单的业务逻辑,把调度交给crond做,就完成了一个可靠性很高的一项任务了,如果要自己去额外写这种调度程序,不知道要花多少精力才能做到可靠稳定。

crontab的语法

1``crontab``[-u username] [-l|-e|-r]

2``选项与参数:

3``-u :只有 root 才能进行这个任务,亦即帮其他使用者创建/移除``crontab``工作排程;

4``-e :编辑``crontab``的工作内容

5``-l :查阅``crontab``的工作内容

6``-r :移除所有的``crontab``的工作内容,若仅要移除一项,请用 -e 去编辑

查询使用者目前的 crontab 内容:

1``crontab``-l

2``*/5 * * * * /home/blue/``do``/rsyncfile.sh

3``0 2 1 4 * /home/blue/``do``/rsyncfile_day.sh

清空使用者目前的 crontab:

1``crontab``-r

2``crontab``-l

3``no``crontab``for``blue

如果你想删除当前用户的某一个crontab任务,那么使用crontab -e进入编辑器,再删除对应的任务。

crontab的限制

/etc/cron.allow:将可以使用 crontab 的帐号写入其中,若不在这个文件内的使用者则不可使用 crontab;

/etc/cron.deny:将不可以使用 crontab 的帐号写入其中,若未记录到这个文件当中的使用者,就可以使用 crontab 。

以优先顺序来说,/etc/cron.allow比/etc/cron.deny要优先, 而判断上面,这两个文件只选择一个来限制而已,因此,建议你只要保留一个即可, 免得影响自己在配置上面的判断!一般来说,系统默认是保留/etc/cron.deny,你可以将不想让他运行 crontab 的那个使用者写入 /etc/cron.deny 当中,一个帐号一行!

/etc/crontab配置文件讲解

『crontab -e』是针对使用者的 cron 来设计的,如果是『系统的例行性任务』时,就要编辑/etc/crontab这个文件。

那就是 crontab -e 这个 crontab 其实是 /usr/bin/crontab 这个运行档,但是 /etc/crontab 可是一个『纯文字档』,必须用 root 的身份编辑一下这个文件。

首先我们要来看看crontab的文件内容

01``cat``/etc/``crontab

02

03``# /etc/crontab: system-wide crontab

04``` # Unlike any other crontab you don't have to run thecrontab' ``

05``# command to install the new version when you edit this file

06``# and files in /etc/cron.d. These files also have username fields,

07``# that none of the other crontabs do.

08

09``SHELL=/bin/sh

10``PATH=/usr/``local``/sbin:/usr/``local``/bin:/sbin:/bin:/usr/sbin:/usr/bin

11

12``# m h dom mon dow user command

13``17 * * * * root``cd``/ && run-parts --report /etc/``cron``.hourly

14``25 6 * * * root``test``-x /usr/sbin/anacron || (``cd``/ && run-parts --report /etc/``cron``.daily )

15``47 6 * * 7 root``test``-x /usr/sbin/anacron || (``cd``/ && run-parts --report /etc/``cron``.weekly )

16``52 6 1 * * root``test``-x /usr/sbin/anacron || (``cd``/ && run-parts --report /etc/``cron``.monthly )

这个文件与将刚刚我们下达 crontab -e 的内容几乎完全一模一样!只是有几个地方不太相同

1``PATH=....:

这里就是输入运行档的搜寻路径!使用默认的路径配置就已经很足够了!

1``17 * * * * root``cd``/ && run-parts --report /etc/``cron``.hourly:

这个 /etc/crontab 里面预配置义出四项工作任务,分别是每小时、每天、每周及每个月分别进行一次的工作! 但是在五个栏位后面接的并不是命令,而是一个新的栏位,那就是『运行后面那串命令的身份』为何!这与使用者的 crontab -e 不相同。由於使用者自己的 crontab 并不需要指定身份,但 /etc/crontab 里面当然要指定身份啦!以上表的内容来说,系统默认的例行性工作是以 root 的身份来进行的。

那么后面那串命令是什么呢?你可以使用『 which run-parts 』搜寻看看,其实那是一个 bash script 啦!如果你直接进入 /usr/bin/run-parts 去看看, 会发现这支命令会将后面接的『目录』内的所有文件捉出来运行!这也就是说『 如果你想让系统每小时主动帮你运行某个命令,将该命令写成 script,并将该文件放置到 /etc/cron.hourly/ 目录下即可』的意思!

现在你知道系统是如何进行他默认的一堆例行性工作排程了吗?如果你下达『 ll /etc/cron.daily 』就可以看到一堆文件, 那些文件就是系统提供的 script ,而这堆 scripts 将会在每天的凌晨 6:25 开始运行!

假设你现在要作一个目录,让系统可以每 2 分钟去运行这个目录下的所有可以运行的文件,你可以写下如下的这一行在 /etc/crontab 中:

1``*/2 * * * * root run-parts /etc/``cron``.min

当然罗, /etc/cron.min 这个目录是需要存在的喔!那如果我需要运行的是一个『程序』而已, 不需要用到一个目录呢?该如何是好?例如在侦测网络流量时,我们希望每五分钟侦测分析一次, 可以这样写:

1``*/5 * * * * root /bin/mrtg /etc/mrtg/mrtg.cfg

如何!创建例行性命令很简单吧!如果你是系统管理员而且你的工作又是系统维护方面的例行任务时, 直接修改 /etc/crontab 这个文件即可喔!又便利,又方便管理呢!

crontab的原理

当使用者使用 crontab 这个命令来创建工作排程之后,该项工作就会被纪录到/var/spool/cron/里面去了,而且是以帐号来作为判别的喔!举例来说, blue 使用 crontab 后, 他的工作会被纪录到/var/spool/cron/blue里头去!但请注意,不要使用 vi 直接编辑该文件, 因为可能由于输入语法错误,会导致无法运行 cron 喔!另外, cron 运行的每一项工作都会被纪录到/var/log/cron这个登录档中,所以罗,如果你的 Linux 不知道有否被植入木马时,也可以搜寻一下 /var/log/cron 这个登录档呢!

crond服务的最低侦测限制是『分钟』,所以『 cron 会每分钟去读取一次/etc/crontab与/var/spool/cron里面的数据内容 』,因此,只要你编辑完 /etc/crontab 这个文件,并且将他储存之后,那么 cron 的配置就自动的会来运行了!

备注:在 Linux 底下的 crontab 会自动的帮我们每分钟重新读取一次 /etc/crontab 的例行工作事项,但是某些原因或者是其他的 Unix 系统中,由于 crontab 是读到内存当中的,所以在你修改完 /etc/crontab 之后,可能并不会马上运行, 这个时候请重新启动 crond 这个服务吧!『/etc/init.d/crond restart』 或『servicecrond restart』

crontab的格式讲解

每项工作 (每行) 的格式都是具有六个栏位,这六个栏位的意义为:

代表意义分钟小时日期(天)月份周命令数字范围0-590-231-311-120-7呀就命令啊

比较有趣的是那个『周』喔!周的数字为0或7时,都代表『星期天』的意思!另外, 还有一些辅助的字符,大概有底下这些:

特殊字符代表意义*(星号)代表任何时刻都接受的意思!举例来说,范例一内那个日、月、周都是 * , 就代表著『不论何月、何日的礼拜几的 12:00 都运行后续命令』的意思!,(逗号)

代表分隔时段的意思。举例来说,如果要下达的工作是 3:00 与 6:00 时,就会是:

0 3,6 * * * command

时间参数还是有五栏,不过第二栏是 3,6 ,代表 3 与 6 都适用!

-(减号)

代表一段时间范围内,举例来说, 8 点到 12 点之间的每小时的 20 分都进行一项工作:

20 8-12 * * * command

仔细看到第二栏变成 8-12 喔!代表 8,9,10,11,12 都适用的意思!

/n(斜线)

那个 n 代表数字,亦即是『每隔 n 单位间隔』的意思,例如每五分钟进行一次,则:

*/5 * * * * command

很简单吧!用 * 与 /5 来搭配,也可以写成 0-59/5 ,相同意思!

周与日月不可同时并存

另一个需要注意的地方在於:『你可以分别以周或者是日月为单位作为循环,但你不可使用「几月几号且为星期几」的模式工作』。 这个意思是说,你不可以这样编写一个工作排程:

1``30 12 11 9 5 root``echo``"just test"``<==这是错误的写法

本来你以为九月十一号且为星期五才会进行这项工作,无奈的是,系统可能会判定每个星期五作一次,或每年的 9 月 11 号分别进行,如此一来与你当初的规划就不一样了~所以罗,得要注意这个地方!上述的写法是不对的!

CentOS下查看crontab执行历史记录

在crontab中添加了定时任务,但发现没有得到期望的结果,因而怀疑是crontab没有执行相应的任务,但怎么定位crontab是否执行呢?

这就需要查看crontab的执行历史记录,具体位置如下:

1``cd``/var/log

2``tail``-100``cron

在cron文件中即可查阅已经操作过的相关定时任务。

参考资料:


一、Crontab 格式说明

我们可以用crontab -e添加要执行的命令。 命令执行的结果,无论是标准输出还是错误输出,都将以邮件形式发给用户。

添加的命令必须以如下格式:

* * * * * /command path

前五个字段可以取整数值,指定何时开始工作,第六个域是字符串,即命令字段,其中包括了crontab调度执行的命令。 各个字段之间用spaces和tabs分割。

前5个字段分别表示:

分钟:0-59
小时:1-23
日期:1-31
月份:1-12
星期:0-6(0表示周日)

还可以用一些特殊符号:

*: 表示任何时刻
,: 表示分割
-:表示一个段,如第二端里: 1-5,就表示1到5点
/n : 表示每个n的单位执行一次,如第二段里,*/1, 就表示每隔1个小时执行一次命令。也可以写成1-23/1.

一些示例:

00 8,12,16 * * * /data/app/scripts/monitor/df.sh
30 2 * * * /data/app/scripts/hotbackup/hot_database_backup.sh
10 8,12,16 * * * /data/app/scripts/monitor/check_ind_unusable.sh
10 8,12,16 * * * /data/app/scripts/monitor/check_maxfilesize.sh
10 8,12,16 * * * /data/app/scripts/monitor/check_objectsize.sh

43 21 * * * 21:43 执行
15 05 * * * 05:15 执行
0 17 * * * 17:00 执行
0 17 * * 1 每周一的 17:00 执行
0,10 17 * * 0,2,3 每周日,周二,周三的 17:00和 17:10 执行
0-10 17 1 * * 毎月1日从 17:00到7:10 毎隔1分钟 执行
0 0 1,15 * 1 毎月1日和 15日和 一日的 0:00 执行
42 4 1 * * 毎月1日的 4:42分 执行
0 21 * * 1-6 周一到周六 21:00 执行
0,10,20,30,40,50 * * * * 每隔10分 执行
*/10 * * * * 每隔10分 执行
* 1 * * * 从1:0到1:59 每隔1分钟 执行
0 1 * * * 1:00 执行
0 */1 * * * 毎时0分 每隔1小时 执行
0 * * * * 毎时0分 每隔1小时 执行
2 8-20/3 * * * 8:02,11:02,14:02,17:02,20:02 执行
30 5 1,15 * * 1日 和 15日的 5:30 执行

二、& 后台执行命令

当在前台运行某个作业时,终端被该作业占据;而在后台运行作业时,它不会占据终端。可以使用&命令把作业放到后台执行。

如:

1``30 2 * * * /data/app/scripts/hotbackup/hot_database_backup.sh &

在后台运行作业时要当心:需要用户交互的命令不要放在后台执行,因为这样你的机器就会在那里傻等。

不过,作业在后台运行一样会将结果输出到屏幕上,干扰你的工作。如果放在后台运行的作业会产生大量的输出,最好使用下面的方法把它的输出重定向到某个文件中:

如:

1``command``>out.``file``2>&1 &

在这个例子中,2>&1表示所有的标准输出和错误输出都将被重定向到一个叫做out.file 的文件中。

三、2>&1 含义

先看一个例子:

1``0 2 * * * /u01/``test``.sh >/dev/null 2>&1 &

这句话的意思就是在后台执行这条命令,并将错误输出2重定向到标准输出1,然后将标准输出1全部放到/dev/null 文件,也就是清空。

在这里有有几个数字的意思:

0表示 键盘输入
1表示 标准输出
2表示 错误输出

我们也可以这样写:

0 2 *澳门新浦京娱乐场网站:crontab执行不生效,详解整理。 * * /u01/test.sh 1>/u01/out.file &
0 2 * * * /u01/test.sh 2>/u01/out.file &
0 2 * * * /u01/test.sh 2>/u01/out.file 2>&1 &

将tesh.sh 命令输出重定向到out.file, 即输出内容不打印到屏幕上,而是输出到out.file文件中。

2>&1 是将错误输出重定向到标准输出。 然后将标准输入重定向到文件out.file。

&1 表示的是文件描述1,表示标准输出,如果这里少了&就成了数字1,就表示重定向到文件1。

& :后台执行

测试:

ls 2>1 : 不会报没有2文件的错误,但会输出一个空的文件1;
ls xxx 2>1: 没有xxx这个文件的错误输出到了1中;
ls xxx 2>&1: 不会生成1这个文件了,不过错误跑到标准输出了;
ls xxx >out.txt 2>&1 == ls xxx 1>out.txt 2>&1: 因为重定向符号>默认是1,这句就把错误输出和标准输出都传到out.txt 文件中。

四、2>&1写在后面的原因

格式:command > file 2>&1 == command 1> file 2>&1

首先是command > file将标准输出重定向到file中, 2>&1 是标准错误拷贝了标准输出,也就是同样被重定向到file中,最终结果就是标准输出和错误都被重定向到file中。

如果改成: command 2>&1 >file

2>&1 标准错误拷贝了标准输出的行为,但此时标准输出还是在终端。>file 后输出才被重定向到file,但标准错误仍然保持在终端。

澳门新浦京娱乐场网站,延伸阅读:

Shell标准输出、标准错误 >/dev/null 2>&1

如何让Linux定时任务crond以秒为单位执行(如每隔3秒)


经验教训:

打算在服务器上 每天晚上23:00 定时执行Python脚本,去备份MySql数据库,命令如下:

1``* 23 * * * python /``var``/www/html/crontab_python/back_db.py >/dev/null 2>&1

结果呢,每次备份都产生了 60份 备份文件,仔细查看定时任务命令,发现在“分”的位置上,少加了个“0”,因为“*”表示该位置的任何一个值,修改如下:

1``0 23 * * * python /var/www/html/crontab_python/back_db.py >/dev/null 2>&1

0 4 * * * /usr/local/php/bin/php /usr/local/nginx/www/backup-db/backup_db.php 172.16.8.26 >/dev/null 2>&1
0 4 * *澳门新浦京娱乐场网站:crontab执行不生效,详解整理。 * /usr/local/php/bin/php /usr/local/nginx/www/backup-db/backup_db.php 172.16.10.151 >/dev/null 2>&1

Crontab命令 详解整理 前言 crontab是Unix和Linux用于设置周期性被执行的指令,是互联网很常用的技术,很多任务都会设置在crontab循环...

  广义的网站的监控涵盖所有的非业务行为的数据采集与管理,包括数据分析师和产品设计师使用的网站用户行为日志、业务运行数据,以及供运维工程师和开发工程师使用的性能统计数据等。

 

     本文主要是通过shell脚本来收集服务器性能指标,如系统load、内存占用、磁盘IO、CPU占用,并将其写入一个文件中,及时判断应用情况,防患于未然 。

总结原因:

  实现步骤如下:

1.shell脚本中绝对路径问题(尤其是生成文件路径)

第一步:编写shell脚本

vim 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 "tt#磁盘存在目录使用率超过85%报警#" >>123.txt
echo -e "ttover 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 "nnnn" >> 123.txt

2.crontab的环境变量问题(尤其是命令调用路径)

第二步:创建shell脚本中用到的文件123.txt    

touch 123.txt

 

第三步:给check.sh和123.txt授予所有权限  

chmod 777 check.sh
chmod 777 123.txt

澳门新浦京娱乐场网站 5

用下面的脚本解析以上两个问题:

第四步:执行check.sh脚本   

./check.sh

澳门新浦京娱乐场网站 6


第五步:查看执行写入文件的情况

澳门新浦京娱乐场网站 7

出现这信息表名脚本成功运行实时统计情况。

 

[root@monitor2 scripts]# cat cron.sh
#!/bin/sh

参考文章

若是想使用定时任务,可使用crontab进行设置,请参见这篇文章

crontab的两种配置方式

 

学习本就是一个不断模仿、练习、再到最后面自己原创的过程。

虽然可能从来不能写出超越网上通类型同主题博文,但为什么还是要写?
于自己而言,博文主要是自己总结。假设自己有观众,毕竟讲是最好的学(见下图)。

于读者而言,笔者能在这个过程get到知识点,那就是双赢了。
当然由于笔者能力有限,或许文中存在描述不正确,欢迎指正、补充!
感谢您的阅读。如果本文对您有用,那么请点赞鼓励。

澳门新浦京娱乐场网站 8

 

 

# func : 远程登录MySQL执行SQL语句,返回结果导入日期结尾的文件,每分钟执行一次脚本
user='admin'
pswd='admin'
host='10.10.60.108'
port=4001
MYSQL_CMD="mysql -u${user} -p${pswd} -h${host} -P${port}"     # 远程登录命令,直接调用mysql命令。
SQL="SELECT VERSION();"
time_mark=`date ' %Y%m%f%H%M%S'`
#filedir="/data/scripts"     # 生成文件的绝对路径
filename="version_${time_mark}.txt"     # 直接指定文件名字
${MYSQL_CMD} -e"${SQL}" >${filename}     # 直接写入指定的文件中 取决于上面filename变量


以上是脚本内容!!!


计划任务:

*/1 * * * * /bin/sh /data/scripts/cron.sh


 

解析问题:

【shell脚本中绝对路径问题】

1.在脚本所在目录下:/data/scripts/手动执行以上脚本(不是绝对路径文件)

命令:./cron.sh

结果:正常生成文件

-rw-r--r--. 1 root root       26 Jan 10 12:13 version_20170110121326.txt

-rw-r--r--. 1 root root       26 Jan 10 12:13 version_20170110121344.txt

2.crontab执行脚本

观察:

[root@monitor2 scripts]# tailf /var/log/cron

Jan 10 12:17:01 monitor2 CROND[524]: (root) CMD (/bin/sh /data/scripts/cron.sh)

结果:计划任务照常执行,但是不会生成文件

3.修改脚本,生成文件是绝对路径

脚本:

filedir="/data/scripts"     # 生成文件的绝对路径:开启
filename="${filedir}/version_${time_mark}.txt"     # 直接指定文件名字:绝对路径了

运行:手动执行,正常生成文件

运行:计划任务运行,正常生成文件

 

【crontab的环境变量问题】

1.脚本中:直接使用mysql命令

命令:手动执行脚本,正常输出文件。因为:/etc/profile 中加入 了系统环境变量:/usr/local/mysql/bin/

2.crontab执行:如果想成功执行

分两种情况:

     1.脚本中mysql命令指定绝对路径:/usr/local/mysql/bin/mysql

     2.将mysql可执行文件复制到:crontab的环境变量指定的路径中

 


# crontab的配置文件!!!


[root@monitor2 scripts]# cat /etc/crontab
SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin     # 将mysql可执行文件复制到/usr/bin下,脚本中就可以直接使用mysql命令
MAILTO=root
HOME=/

# For details see man 4 crontabs

# Example of job definition:
# .---------------- minute (0 - 59)
# | .------------- hour (0 - 23)
# | | .---------- day of month (1 - 31)
# | | | .------- month (1 - 12) OR jan,feb,mar,apr ...
# | | | | .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
# | | | | |
# * * * * * user-name command to be executed


 

!查看:cron的log日志文件:

  tailf /var/log/cron

 

!重启crond服务:

  service crond restart

 

总结:

脚本中涉及文件和命令的使用最好都用上绝对路径!!!

脚本中涉及文件和命令的使用最好都用上绝对路径!!!

脚本中涉及文件和命令的使用最好都用上绝对路径!!!


本文由澳门新浦京娱乐场网站发布于澳门新浦京娱乐场网站,转载请注明出处:澳门新浦京娱乐场网站:crontab执行不生效,详解