一、关于nohup:
1.假设有一 tash.sh
[~]$ appending output to nohup.out
证明运行成功,同时把程序运行的输出信息放到当前目录的 nohup.out 文件中去。
解释:nohup 命令运行由 Command参数和任何相关的 Arg参数指定的命令,忽略所有挂断(SIGHUP)信号。在注销后使用 nohup 命令运行后台中的程序。要运行后台中的 nohup 命令,添加 & ( 表示“and”的符号)到命令的尾部。 如果不将 nohup 命令的输出重定向,输出将附加到当前目录的 nohup.out 文件中。如果当前目录的 nohup.out 文件不可写,输出重定向到 $HOME/nohup.out 文件中。
0:标准输入流 stdin
1:标准输出流 stdout
2:标准错误流 stderr
二、定时任务可用两种方案实现:
1.shell代码
不太推荐,可参考https://www.cnblogs.com/linux-wang/p/8142844.html
2.使用crontab来完成定时执行一次可执行任务
1)安装crontab
[root@slaver1 hadoop]# yum install crontabs
[root@slaver1 hadoop]# service crond status #查看状态
[root@slaver1 hadoop]# /sbin/service crond stop #关闭服务
[root@slaver1 hadoop]# /sbin/service crond start #启动服务
[root@slaver1 hadoop]# /sbin/service crond restart #重启服务
[root@slaver1 hadoop]# /sbin/service crond reload #重新载入配置
[root@slaver1 hadoop]# service crond start #手动启动crontab服务
[root@slaver1 hadoop]# ntsysv #查看crontab服务是否已设置为开机启动,执行命令
[root@slaver1 hadoop]# chkconfig –level 35 crond on #加入开机自动启动
2)命令格式
crontab [-u user] file
crontab [-u user] [ -e | -l | -r ]
3)参数详情
-u user:用来设定某个用户的crontab服务,例如,“-u ixdba”表示设定ixdba用户的crontab服务,此参数一般有root用户来运行。
file:file是命令文件的名字,表示将file做为crontab的任务列表文件并载入crontab。如果在命令行中没有指定这个文件,crontab命令将接受标准输入(键盘)上键入的命令,并将它们载入crontab。
-e:编辑(编辑某个用户的crontab文件内容。如果不指定用户,则表示编辑当前用户的crontab文件。)
-l:查看(显示某个用户的crontab文件内容,如果不指定用户,则表示显示当前用户的crontab文件内容。)
-r:删除(从/var/spool/cron目录中删除某个用户的crontab文件,如果不指定用户,则默认删除当前用户的crontab文件。)
-ir:删除提示(在删除用户的crontab文件时给确认提示。)
4)编辑当前用户的cron配置
crontab -e
#每小时去执行目录下的shell文件
0*/1 * * * /home/test/test.sh
5)crontab文件格式:
minute hour day month week command
分 时 日 月 周 命令
minute: 表示分钟,可以是从0到59之间的任何整数。
hour:表示小时,可以是从0到23之间的任何整数。
day:表示日期,可以是从1到31之间的任何整数。
month:表示月份,可以是从1到12之间的任何整数。
week:表示星期几,可以是从0到7之间的任何整数,这里的0或7代表星期日。command:要执行的命令,可以是系统命令,也可以是自己编写的脚本文件。
例如:
* * * * * /home/test.sh #每一分钟执行一次test.sh脚本
10,15 * * * * /home/test.sh #每小时的10,15分钟各执行一次test.sh脚本
15 8 * * * /home/test.sh #每天早上8点15执行一次
15 8 1 jan * /home/test.sh #1月1号早上8点15执行一次
0 6 * * 6 /home/test.sh #每个星期六的早上6点执行一次
* 8 * * * /home/test.sh #每个早上8点执行一次
0 */2 * * * /home/test.sh #每两小时执行一次
在以上各个字段中,还可以使用以下特殊字符:
星号(*):代表所有可能的值,例如month字段如果是星号,则表示在满足其它字段的制约条件后每月都执行该命令操作。
逗号(,):可以用逗号隔开的值指定一个列表范围,例如,“1,2,5,7,8,9”
中杠(-):可以用整数之间的中杠表示一个整数范围,例如“2-6”表示“2,3,4,5,6”
正斜线(/):可以用正斜线指定时间的间隔频率,例如“0-23/2”表示每两小时执行一次。同时正斜线可以和星号一起使用,例如*/10,如果用在minute字段,表示每十分钟执行一次。