在有些情况下,我们不希望自己的shell脚本在运行的时候被中断。比如说我们写的shell脚本设定为某一用户默认的shell,使这一用户进入系统后只能作某一项工作,如数据库备份。我们不希望用户使用 ctrl + c 之类便进入到shell状态,做到我们不希望做的事情,这里便用到了信号处理
kill -l 和 trap -l:
几种重要的信号:
1) SIGHUP
本信号在用户终端连接(正常或非正常)结束时发出, 通常是在终端的控制进程结束时, 通知同一session内的各个作业, 这时它们与控制终端不再关联.
2) SIGINT
程序终止(interrupt)信号, 在用户键入INTR字符(通常是Ctrl-C)时发出
20) SIGTSTP
停止进程的运行, 但该信号可以被处理和忽略. 用户键入SUSP字符时(通常是Ctrl-Z(暂停脚本执行))发出这个信号
通过trap使用信号的方法:
trap命令用于指定在接收到信号后将要采取的行动。
trap命令的一种常见用途是在脚本程序被中断时完成清理工作。(比如说当我接收到信号后,执行一些清理工作)。历史上,shell总是用数字来代表信号,而新的程序应该使用信号的名字,在使用信号名时需要省略SIG前缀
通常我们需要忽略的信号有 HUP INT QUIT ABRT ALRM TERM TSTP
信号: 说明:
HUP(1) 挂起,通常因终端掉线或用户退出而引发
INT(2) 中断,通常因按下ctrl+c组合键而引发
QUIT(3) 退出,通常因按下ctrl+/组合键而引发
ABRT(6) 中止,通常因某些严重的执行错误而引发
ALRM(14) 报警,通常用来处理超时
TERM(15) 终止,通常在系统关机时发送
TSTP(20) 停止进程的运行,但该信号可以被处理和忽略,用户键入SUSP字符时(通常是ctrl-z)发出这个信号
trap命令的参数分为两部分。第一部分是接收到指定信号时,将要采取的行动,后一部分是要处理的信号名
例如 trap " " 1 2 3 20 15 trap " " HUP INT QUIT TSTP
stty -a: 列出中断信号与键盘的对应
例1:自定义信号处理方式
例2:屏蔽多个信号
trap " " 1 2 3 15 20
trap " " `seq 64`
trap " " `echo {1..64}`
例3:触发信号后清理文件
分析: -mmin +60 一个小时之内修改过的
xargs 是给命令传递参数的一个过滤器。
之所以能用到这个命令,关键是由于很多命令不支持|管道来传递参数