linux 后台执行命令

本文主要内容:

1. 设置ctontab文件,并用它来提交作业。

2. 使用at命令来提交作业。

3. 在后台提交作业。

4. 使用nohup命令提交作业。

名词解释:

cron 系统调度进程。可以使用它在每天的非高峰负荷时间段运行作业,或在一周或一月中的不同时段运行。

At at命令。使用它在一个特定的时间运行一些特殊的作业,或在晚一些的非负荷高峰时间段或高峰负荷时间段运行。

& 使用它在后台运行一个占用时间不长的进程。

Nohup 使用它在后台运行一个命令,即使在用户退出时也不受影响。

1.1 cron和crontab

cron是系统主要的调度进程,每一个用户都可以有一个crontab文件来保存调度信息。系统管理员是通过cron.deny和cron.allow这两个文件来禁止或允许用户拥有自己的crontab文件。

1.1.1 crontab的域

为了能够在特定的时间运行作业,需要了解crontab文件每个条目中各个域的意义和格式。

下面就是这些域:

第1列分钟1~59

第2列小时1~23(0表示子夜)

第3列日1~31

第4列月1~12

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

第6列要运行的命令

下面是crontab的格式:

分< >时< >日< >月< >星期< >要运行的命令

其中< >表示空格。

Crontab文件的一个条目是从左边读起的,第一列是分,最后一列是要运行的命令,它位于星期的后面。在这些域中,可以用横杠-来表示一个时间范围,例如你希望星期一至星期五运行某个作业,那么可以在星期域使用1 - 5来表示。还可以在这些域中使用逗号“,”,例如你希望星期一和星期四运行某个作业,只需要使用1 , 4来表示。可以用星号*来表示连续的时间段。如果你对某个表示时间的域没有特别的限定,也应该在该域填入*。该文件的每一个条目必须含有5个时间域,而且每个域之间要用空格分隔。该文件中所有的注释行要在行首用#来表示。

1.1.2 crontab条目举例

这里有c r o n t a b文件条目的一些例子:

30 21* * * /apps/bin/cleanup.sh

上面的例子表示每晚的2 1 : 3 0运行/ a p p s / b i n目录下的c l e a n u p . s h。

45 4 1,10,22 * * /apps/bin/backup.sh

上面的例子表示每月1、1 0、2 2日的4 : 4 5运行/ a p p s / b i n目录下的b a c k u p . s h。

10 1 * * 6,0 /bin/find -name "core" -exec rm {} \;

上面的例子表示每周六、周日的1 : 1 0运行一个f i n d命令。

0,30 18-23 * * * /apps/bin/dbcheck.sh

上面的例子表示在每天1 8 : 0 0至2 3 : 0 0之间每隔3 0分钟运行/ a p p s / b i n目录下的d b c h e c k . s h。

0 23 * * 6 /apps/bin/qtrend.sh

上面的例子表示每星期六的11 : 0 0 p m运行/ a p p s / b i n目录下的q t r e n d . s h。你可能已经注意到上面的例子中,每个命令都给出了绝对路径。当使用c r o n t a b运行s h e l l脚本时,要由用户来给出脚本的绝对路径,设置相应的环境变量。记住,既然是用户向c r o n提交了这些作业,就要向c r o n提供所需的全部环境。不要假定c r o n知道所需要的特殊环境,它其实并不知道。所以你要保证在s h e l l脚本中提供所有必要的路径和环境变量,除了一些自动设置的全局变量。

如果c r o n不能运行相应的脚本,用户将会收到一个邮件说明其中的原因。

1.1.3 crontab命令选项

crontab命令的一般形式为:

Crontab [-u user] -e -l -r

其中:

-u 用户名。

-e 编辑crontab文件。

-l 列出crontab文件中的内容。

-r 删除crontab文件。

如果使用自己的名字登录,就不用使用- u选项,因为在执行crontab命令时,该命令能够

1.2 at命令

[root@test ~]# at 9:41

at> find /-name "passwd" -print

at> <EOT>

job 1 at 2015-11-09 09:41

1.3 & 命令

在当前目录下查找text.file文件,并将查找结果、所有的标准输出和错误输出重定向到输出到find.dt文件中

find . -name "text.file" -print > find.dt 2>&1 &

[3] 2956

2956是进程号,可监控或者杀死

# ps x | grep 2956

2975 pts/1 S+ 0:00 grep 2956

# ps -ef | grep 2956

root 2977 2479 0 10:47 pts/1 00:00:00 grep 2956

kill 进程号

kill -9 进程号

1.4 nohup 命令

nohup不挂起,可以在退出账户之后继续运行相应的进程。

该命令的一般形式为:

nohup command &

如果使用nohup命令提交作业,那么在缺省情况下该作业的所有输出都被重定向到一个名为nohup.out的文件中,除非另外指定了输出文件:

nohup command > myout.file 2>&1

查询当前目录日志中的数据库数据信息,并将其定向输入到指定文件

$ nohup " find . -name "orcl*" -exec grep "ORA-" {} \;" > log.file 2>&1 &

[1] 12039

$ cat log.file

nohup: ignoring input

nohup: failed to run command ` find . -name orcl* -exec grep ORA- {} \\;': No such file or directory

posted @ 2015-11-09 16:02  方诚  阅读(615)  评论(0编辑  收藏  举报