Linux定时任务调试技巧分享 (linux定时任务调试)

Linux是一个广泛使用的开源操作系统,经常用于服务器环境,自动化运维和批处理程序等高度重复性操作。定时任务(shell script和python脚本)是Linux系统中非常常见的任务,它们通过cron定时执行。在实际使用过程中,我们常常会遇到定时任务无法按照预期执行的问题。本文将分享一些常见的Linux定时任务调试技巧,希望能够帮助读者快速排除问题并提高工作效率。

1. 查看/var/log/cron日志文件

/var/log/cron是Linux系统中保存cron定时任务执行记录的文件。我们可以通过以下命令查看该文件最近一次的执行记录:

“`

$ tl -f /var/log/cron

“`

上面的命令会打开一个跟随模式,实时显示/var/log/cron文件的最后几行内容。如果我们发现定时任务没有按照预期执行,可以在/var/log/cron文件中查找对应的任务,并分析错误信息和执行的时间。

2. 在命令行手动执行任务

我们可以在命令行中手动执行定时任务的脚本文件。这样做有两个好处:一是可以快速验证脚本的正确性,二是可以查看脚本的输出和错误信息。

“`

$ /path/to/your/script.sh

“`

上面的命令会在当前终端中执行/script.sh脚本文件。如果执行成功,我们可以根据脚本的输出和日志文件来确认任务是否正常执行。如果执行失败,可以根据错误信息定位问题。

3. 手动运行cron定时任务

我们可以手动运行cron定时任务,以便在脚本文件正式定时执行前,对脚本进行测试和调试。

“`

$ crontab -e

“`

上面的命令会打开一个文本编辑器,让我们编辑当前用户的cron定时任务列表。我们可以按照cron定时任务的格式,添加一条将要被执行的任务到cron任务清单中,例如:

“`

* * * * * /path/to/your/script.sh

“`

上面的任务表示每分钟执行一次/path/to/your/script.sh脚本文件。添加完成后,可以保存文件并退出编辑器。我们执行以下命令强制cron马上重新读取任务清单:

“`

$ sudo service cron restart

“`

之后cron就会执行我们刚刚添加的任务,并在/var/log/cron中记录任务执行的结果。如果任务正常执行,我们就可以确认cron定时任务是正确配置的。如果任务没有执行或执行出错,我们就可以根据/var/log/cron中的错误信息来排除问题。

4. 使用日志输出调试信息

更好的定时任务调试技巧之一是在脚本文件中加入日志输出功能。我们可以通过创建日志文件和记录调试信息的方式来检查定时任务的执行状态和问题。

在脚本文件中增加以下代码:

“`

#!/bin/bash

log_file=’/var/log/your_script.log’

date >> $log_file

echo ‘Start to run your script…’ >> $log_file

/path/to/your/script_body.sh >> $log_file 2>&1

echo ‘Your script finished.’ >> $log_file

“`

上面的代码会将日志输出到/var/log/your_script.log文件中。我们可以按照日期和时间查看日志文件的内容,并对执行过程进行分析和调试。

5. 使用注释调试

在添加和修改cron定时任务时,使用注释来标识每个任务。这样做有助于我们快速查找任务并排除问题。在脚本文件中加入注释也非常有用,例如:

“`

#!/bin/bash

# Start to run your script…

/path/to/your/script_body.sh

# Your script finished.

“`

上面的注释让我们一开始就知道执行脚本和脚本的结束时间。这样的注释可以让我们快速定位代码的执行时间和代码中的关键部分。

6. 使用shellcheck检查语法错误

Shellcheck是一个非常有用的静态代码分析工具,可以帮助我们检查定时任务脚本中可能存在的语法、语义及常见错误。这个工具是免费的,可以从GitHub或其他官方渠道下载。我们只需要运行以下命令:

“`

$ shellcheck /path/to/your/script.sh

“`

上面的命令会自动检查脚本中存在的潜在问题,输出任何错误或警告信息。使用Shellcheck可以找到代码中的错误,以免最终导致定时任务执行失败。

结论

以上是本文分享的Linux定时任务调试技巧。希望这些技巧可以帮助读者更好地管理和调试Linux定时任务。需要强调的是,在实际使用过程中,我们需要根据不同的情况和需求,选择不同的调试方法和工具。愿你通过这篇文章学到了新的知识并提高了工作效率。

相关问题拓展阅读:

如何在linux系统上设置定时执行任务

你可巧迟灶以通过编写一个 SHELL 脚本程序(在编程过程孝扮旦睁中会用到 Linux 系统的 at 命令),就可以实现在指定的时间执行指定的任务。

Linux crontab怎么定时执行任务

linux下定时执行任务的方法 【非原创,个人网上收集整理了一下】

在LINUX中,周期执行的任务一般由cron这个守护进程来处理。cron读取一个或多个配置文件,这些配置文件中包含了命令行及其调用时间。

cron的配置文件称卖世为“crontab”,是“cron table”的简写。

一、cron在3个地方查找配置文件:

1、/var/spool/cron/ 这个目录下存放的是每个用户包括root的crontab任务,每个任务以创建者的名字命名,比如tom建的crontab任务对应的文件就是/var/spool/cron/tom。

一般一个用户最多只有一个crontab文件。

二、/etc/crontab 这个文件负责安排由系统管理员制定的维护系统以及其他任务的crontab。

SHELL=/bin/bash

PATH=/in:/bin:/usr/in:/usr/bin

MAILTO=root

HOME=/

# .– 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

# | | | | |

# * * * * * command to be executed

三、/etc/cron.d/ 这个目录用来存放任何要执行的crontab文件或脚本。

四、权限

crontab权限问题到/var/adm/cron/下一看,文件cron.allow和cron.deny是否存在

用法如下:

1、如果两个文件都不存在,则只有root用户才能使用crontab命令。

2、如果cron.allow存在但cron.deny不存在,则只有列在cron.allow文件里的用户才能使用crontab命令,如果root用户也不在里面,则root用户也不能使用crontab。

3、如果cron.allow不存在, cron.deny存在,则只有列在cron.deny文陆颤件里面的用户不能使用crontab命令,其它用户都能使用。

4、如果两个文件都存在,则列在cron.allow文件中而且没有列在cron.deny中的用户可以使用crontab,如果两个文件中都有同一个用户,

以cron.allow文件里面是否有该用户为准,如果cron.allow中有该用户,则可以使用crontab命令。

AIX 中 普通用户默认都有 crontab 权限,如果要限制用户使用 crontab ,就需要编辑/var/adm/cron/cron.deny

HP-UNIX 中默认普通用户没得crontab 权限 ,要想放开普通用户的crontab 权限可以编

五、创建cron脚本

之一步:写cron脚本文件,命名为crontest.cron。

15,30,45,59 * * * * echo “xgmtest…..” >> xgmtest.txt 表示,每隔15分钟,执行打印一次命令

第二步:添加定时任务。执行命令 “crontab crontest.cron”。搞定

第三步:”crontab -l” 查看定时任务是否成功或者检测/var/spool/cron下是否生成对应cron脚本

六、cron服务

cron是一个linux下 的定时执行工具,可以在无需人工干预的情况下运行作业。

/in/service crond start //启动服务

/in/service crond stop //关闭服务

/in/service crond restart //重启服务

/in/service crond reload //重新载入配置

/in/service crond status //查看服务状态

crontab用法

crontab命令用于安装、删除或者列出用于驱动cron后台进程的表格。用户把需要执行的命令序列放到crontab文件中以获得执行。

每个用户都可以有自早配败己的crontab文件。/var/spool/cron下的crontab文件不可以直接创建或者直接修改。该crontab文件是通过crontab命令创建的

在crontab文件中如何输入需要执行的命令和时间。该文件中每行都包括六个域,其中前五个域是指定命令被执行的时间,最后一个域是要被执行的命令。

每个域之间使用空格或者制表符分隔。格式如下:

minute hour day-of-month month-of-year day-of-week commands

合法值 (0 is sunday)

除了数字还有几个个特殊的符号就是”*”、”/”和”-“、”,”,*代表所有的取值范围内的数字,”/”代表每的意思,”/5″表示每5个单位,”-“代表从某个数字到某个数字,”,”分开几个离散的数字。

-l 在标准输出上显示当前的crontab。

-r 删除当前的crontab文件。

-e 使用VISUAL或者EDITOR环境变量所指的编辑器编辑当前的crontab文件。当结束编辑离开时,编辑后的文件将自动安装。

几个例子:

每天早上6点

0 6 * * * echo “Good morning.” >> /tmp/test.txt //注意单纯echo,从屏幕上看不到任何输出,因为cron把任何输出都email到root的信箱了。

每两个小时

0 */2 * * * echo “Have a break now.” >> /tmp/test.txt

晚上11点到早上8点之间每两个小时和早上八点

0 23-7/2,8 * * * echo “Have a good dream” >> /tmp/test.txt

每个月的4号和每个礼拜的礼拜一到礼拜三的早上11点

* 1-3 command line

1月1日早上4点

* command line SHELL=/bin/bash PATH=/in:/bin:/usr/in:/usr/bin MAILTO=root //如果出现错误,或者有数据输出,数据作为邮件发给这个帐号 HOME=/

每小时执行/etc/cron.hourly内的脚本

01 * * * * root run-parts /etc/cron.hourly

每天执行/etc/cron.daily内的脚本

02 4 * * * root run-parts /etc/cron.daily

每星期执行/etc/cron.weekly内的脚本

22 4 * * 0 root run-parts /etc/cron.weekly

每月去执行/etc/cron.monthly内的脚本

* * root run-parts /etc/cron.monthly

注意: “run-parts”这个参数了,如果去掉这个参数的话,后面就可以写要运行的某个脚本名,而不是文件夹名。

每天的下午4点、5点、6点的5 min、15 min、25 min、35 min、45 min、55 min时执行命令。

5,15,25,35,45,55 16,17,18 * * * command

每周一,三,五的下午3:00系统进入维护状态,重新启动系统。

00 15 * * 1,3,5 shutdown -r +5

每小时的10分,40分执行用户目录下的innd/bbslin这个指令:

10,40 * * * * innd/bbslink

每小时的1分执行用户目录下的bin/account这个指令:

1 * * * * bin/account

每天早晨三点二十分执行用户目录下如下所示的两个指令(每个指令以;分隔):

20 3 * * * (/bin/rm -f expire.ls logins.bad;bin/expire$#@62;expire.1st)

每年的一月和四月,4号到9号的3点12分和3点55分执行/bin/rm -f expire.1st这个指令,并把结果添加在mm.txt这个文件之后(mm.txt文件位于用户自己的目录位置)。

12,,4 * /bin/rm -f expire.1st$#@62;$#@62;mm.txt

at命令实现定时任务

假如我们只是想要让特定任务运行一次,那么,这时候就要用到at监控程序了。

at类似打印进程,会把任务放到/var/spool/at目录中,到指定时间运行它 。at命令相当于另一个shell,运行at time命令时,它发送一个个命令,可以输入任意命令或者程序。

at命令执行流程如下

# at 2:05 tomorrow

at>/home/kyle/do_job

at> Ctrl+D

AT Time中的时间表示方法

时 间 例子 说明

Minute at now + 5 minutes 任务在5分钟后运行

Hour at now + 1 hour 任务在1小时后运行

Days at now + 3 days 任务在3天后运行

Weeks at now + 2 weeks 任务在两周后运行

Fixed at midnight任务在午夜运行

Fixed at 10:30pm任务在晚上10点30分

注意:linux默认为不启动,而ubuntu默认为启动的。检查是否启动,用service atd检查语法,用service atd status检查atd的状态,用service atd start启动atd服务。

查看at执行的具体内容:一般位于/var/spool/at目录下面, 用vi打开,在最后一部分就是你的执行程序

参数详解

-V : 印出版本编号

-q : 使用指定的伫列(Queue)来储存,at 的资料是存放在所谓的 queue 中,使用者可以同时使用多个 queue,而 queue 的编号为 a, b, c… z 以及 A, B, … Z 共 52 个

-m : 即使程序/指令执行完成后没有输出结果, 也要寄封信给使用者

-f file : 读入预先写好的命令档。使用者不一定要使用交谈模式来输入,可以先将所有的指定先写入档案后再一次读入

网络应用

-l : 列出所有的指定 (使用者也可以直接使用 atq 而不用 at -l)

-d : 删除指定 (使用者也可以直接使用 atrm 而不用 at -d)

-v : 列出所有已经完成但尚未删除的指定

删除任务

atrm 2

三天后的下午 5 点锺执行 /bin/ls :

at 5pm 3 days /bin/ls

三个星期后的下午 5 点锺执行 /bin/ls :

at 5pm 2 weeks /bin/ls

明天的 17:20 执行 /bin/date :

at 17:20 tomorrow /bin/date

1999 年的最后一天的最后一分钟印出 the end of world !

at 23:59 12/31/1999 echo the end of world !

关于linux定时任务调试的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。


数据运维技术 » Linux定时任务调试技巧分享 (linux定时任务调试)