Shell脚本异常退出主因是命令失败未检测,需用$?判断、set -e自动终止、set -u防未定义变量、trap保障清理;一句set -euo pipefail加关键trap可解决80%问题。

Shell脚本异常退出,通常不是因为语法写错了,而是某条命令执行失败后,脚本没做判断就继续往下跑,最终导致逻辑错乱、数据损坏甚至误删文件。关键在于:Shell 默认不因命令失败而停止,必须主动干预。
退出状态码($?)是判断依据
每条命令执行完都会返回一个退出状态码:0 表示成功,非 0(如 1、2、127、130)表示不同类型的失败。Shell 不自动检查它,但你可以用 $? 拿到上一条命令的结果。
- 运行
ls /missing后立刻执行echo $?,会输出 2 -
command || echo "出错了"是常见简写:前面失败才执行后面 -
if command; then echo "成功"; else echo "失败"; fi更清晰可控
set -e:让脚本在错误时自动退出
在脚本开头加 set -e(或 set -o errexit),Shell 遇到任何非 0 状态的命令就立即终止脚本。这是最直接的防御手段。
- 适合大多数业务脚本,尤其涉及文件操作、服务启停等关键流程
- 注意:管道(
|)、if、while条件判断中的命令不受影响,它们本就依赖状态码做逻辑分支 - 想临时绕过某条可能失败的命令?用
command || true或set +e; command; set -e
set -u:防止未定义变量引发静默错误
变量拼错或漏赋值很常见,比如写成 $USER_NAME 却实际是 $USERNAME。默认情况下,Shell 把空变量当空字符串继续执行,容易埋下隐患。
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~