Linux脚本自动化核心是提升稳定性、可维护性与可观测性:用变量和getopts避免硬编码,set -euo pipefail加精细错误处理,统一日志函数记录时间戳与上下文,cron仅触发+独立脚本加锁,inotifywait替代轮询。

Linux脚本自动化不是写完能跑就行,关键是让脚本更稳、更省心、更容易维护。核心在于减少人工干预、提前防错、结果可查。
用好变量和参数,别硬编码
路径、用户名、超时时间这些容易变的值,全写死在脚本里,改一次就得翻半天代码。用变量封装,再配合命令行参数($1 $2)或 getopts 解析,灵活多了。
- 把常用路径定义成变量:# BASE_DIR="/opt/myapp"
- 用 getopts 支持 -h -t 30 -o /tmp/output.log 这类调用
- 加默认值和参数校验,比如 [ -z "$INPUT_FILE" ] && echo "Error: -f required" && exit 1
错误处理不能靠运气
一句 command || exit 1 只是入门。真正健壮的脚本得知道哪步失败、为什么失败、要不要重试、要不要发通知。
- 开头加 set -euo pipefail:遇到未定义变量、命令失败、管道中断自动退出
- 关键步骤后跟 if ! cmd; then echo "cmd failed"; exit 1; fi
- 用 $? 捕获上条命令退出码,区分不同错误做不同动作(比如网络超时重试3次,权限错误直接报错)
日志和输出要“说得清、查得到”
脚本跑完黑屏一片?出问题只能盲猜?加日志不是加 echo 就完事,得有时间戳、级别、上下文。
- 统一用函数打日志:log_info() { echo "$(date '+%F %T') [INFO] $*"; }
- 执行关键操作前/后都记一笔,比如 log_info "Starting backup for $DB_NAME"
- 把 stdout 和 stderr 分开重定向,或统一记到文件:./deploy.sh >> /var/log/deploy.log 2>&1
定时+触发要可靠,别只靠 crontab
cron 能调度,但没内置重试、依赖检查、资源限制。复杂任务建议分层处理。
- cron 只做“准时喊一嗓子”,真正逻辑放独立脚本里
- 加锁防止重复运行:if ! mkdir /tmp/myjob.lock 2>/dev/null; then exit; fi
- 需要事件触发(如文件到达)就用 inotifywait,比轮询更省资源
基本上就这些——变量清晰、错误可控、日志可读、调度可靠。不复杂但容易忽略,补上就能少踩80%的坑。










