日期:2014-05-16  浏览次数:20687 次

Linux命令-后台执行命令学习笔记
一、cron和crontab
  1.crontab
下面是crontab的格式:
分< >时< >日< >月< >星期< >要运行的命令,其中< >表示空格。
crontab文件的一个条目是从左边读起的,第一列是分,最后一列是要运行的命令,它位于星期的后面。在这些域中,可以用横杠-来表示一个时间范围,例如你希望星期一至星期五运行某个作业,那么可以在星期域使用1- 5来表示。还可以在这些域中使用逗号“,”,例如你希望星期一和星期四运行某个作业,只需要使用1 , 4来表示。可以用星号*来表示连续的时间段。如果你对某个表示时间的域没有特别的限定,也应该在该域填入*。该文件的每一个条目必须含有5个时间域,而且每个域之间要用空格分隔。该文件中所有的注释行要在行首用#来表示。
例子:
30 21* * * /apps/bin/cleanup.sh  #每晚的21:30运行/apps/bin目录下的cleanup.sh
10 1 * * 6,0 /bin/find -name "core" -exec rm {} \;  #示每周六、周日的1:10运行一个find命令

0,30 18-23 * * * /apps/bin/dbcheck.sh #每天18:00至23:00之间每隔30分钟运行/app/bin目录下的dbcheck.sh

当使用crontab运行shell脚本时,要由用户来给出脚本的绝对路径,设置相应的环境变量。记住,既然是用户向cron提交了这些作业,就要向cron提供所需的全部环境。不要假定cron知道所需要的特殊环境,它其实并不知道。所以你要保证在shell脚本中提供所有必要的路径和环境变量,除了一些自动设置的全局变量。

创建一个名为<user>cron文件(例如jungecron),输入crontab代码
$ crontab jungecron #同时,新创建文件的一个副本已经被放在/var/spool/cron目录中,文件名就是用户名

查看crontab文件:crontab -l
修改crontab文件:crontab -e(要添加EDITOR变量:编辑$HOME目录下的.profile文件,添加EDITOR=vi; export EDITOR)
删除crontab文件:crontab -r
二、at命令
1.根用户可以通过/etc目录下的at.allow和at.deny文件来控制哪些用户可以使用at命令,哪些用户不行。

2.at命令的基本形式为:
at [-f script] [-m -l -r] [time] [date]
其中,
-f script 是所要提交的脚本或命令。
-l 列出当前所有等待运行的作业。atq命令具有相同的作用。
-r 清除作业。为了清除某个作业,还要提供相应的作业标识(ID);有些UNIX变体只接受atrm作为清除命令。
-m 作业完成后给用户发邮件。
time at命令的时间格式非常灵活;可以是H、HH.HHMM、HH:MM或H:M,其中H和M分别是小时和分钟。还可以使用a.m.或p.m.。
date 日期格式可以是月份数或日期数,而且at命令还能够识别诸如today、tomorrow这样的词。

3.使用at命令提交命令或脚本
1)如果你想提交若干行的命令,可以在at命令后面跟上日期/时间并回车。然后就进入了at命令提示符,这时只需逐条输入相应的命令,然后按‘<CRL-D>’退出。例子:
$at 21:10
at> find / -name "passwd" -print
at><EOT>
2)提交脚本
at 3.00pm tomorrow -f /apps/bin/db_table.sh
3)使用echo命令向at命令提交作业
  echo find /etc -name "passwd" -print | at now +1 minute

4)查看作业:at -l
5)清除作业:atrm [job no]或者 at -r [job no]

三、&命令
运行一个find命令,查找名为“srm.conf的文件,并把所有标准输出和错误输出重定向到一个叫作find.dt的文件中:
find /etc -name "srm.conf" -print >find.dt 2>&1 &

查看进程:
ps x | grep 28305 或者 ps -ef |grep 28305

四、nohup命令
如果你正在运行一个进程,而且你觉得在退出帐户时该进程还不会结束,那么可以使用nohup命令。该命令可以在你退出帐户之后继续运行相应的进程。nohup就是不挂起的意思(nohang up)。
该命令的一般形式为:
nohup command &
1 楼 junge8618 2010-10-29  
#避免主备信任关系不存在
/usr/bin/expect <<EOD
spawn ssh root@${_REMOTE_HOST_NAME} "exit;"
   for {} {1} {} {
           expect {
           "*(yes/no)?" { send "yes\r" ; continue }
           "*assword:" { send "huawei\r" ; continue }
           -re . { exp_continue }
           eof { break }
          }
       }
EOD