执行shell 脚本 如何将日志全部输出到文件

在执行 Shell 脚本时,如果需要将 所有输出(包括标准输出 stdout 和错误输出 stderr 重定向到日志文件,可以使用以下方法:


方法 1:直接重定向(推荐)

bash 复制代码
/appdata/mysql_backup_dump.sh > /var/log/mysql_backup.log 2>&1
  • > :将标准输出(stdout)重定向到 /var/log/mysql_backup.log
  • 2>&1 :将错误输出(stderr)合并到标准输出(即也写入日志文件)。
  • 效果 :所有输出(包括 echomysqldump 正常信息、错误信息)都会写入日志文件。

方法 2:追加模式(不覆盖旧日志)

bash 复制代码
/appdata/mysql_backup_dump.sh >> /var/log/mysql_backup.log 2>&1
  • >>:追加到日志文件(而不是覆盖),适合长期运行的备份任务。

方法 3:使用 tee 命令(同时输出到屏幕和文件)

bash 复制代码
/appdata/mysql_backup_dump.sh 2>&1 | tee -a /var/log/mysql_backup.log
  • tee -a :将输出 同时显示在终端追加到日志文件-a 表示追加)。
  • 适用场景:调试时想实时查看输出,同时保留日志。

方法 4:在脚本内部重定向

如果脚本是自己编写的,可以在脚本开头指定日志文件:

bash 复制代码
#!/bin/bash
exec > /var/log/mysql_backup.log 2>&1  # 所有后续输出都重定向到日志
echo "Backup started at $(date)"
# 备份命令(如 mysqldump)
  • exec:重定向整个脚本的输出,包括后续所有命令。

方法 5:使用 logger 写入系统日志

如果希望日志进入系统日志(如 /var/log/syslog/var/log/messages):

bash 复制代码
/appdata/mysql_backup_dump.sh > /tmp/backup.log 2>&1
logger -t "MySQL_BACKUP" -f /tmp/backup.log  # 写入系统日志
rm -f /tmp/backup.log  # 可选:删除临时日志文件
  • logger -t "TAG":给日志添加标签(方便过滤)。
  • -f:指定日志文件路径。

最佳实践

  1. 推荐方法 1 或 2(简单可靠)。

  2. 日志轮转 :使用 logrotate 管理日志文件,避免日志过大:

    bash 复制代码
    # /etc/logrotate.d/mysql_backup
    /var/log/mysql_backup.log {
        daily
        rotate 7
        compress
        missingok
        notifempty
    }
  3. 在 cron 中记录日志

    bash 复制代码
    0 2 * * * /appdata/mysql_backup_dump.sh > /var/log/mysql_backup.log 2>&1

验证日志是否生效

bash 复制代码
tail -f /var/log/mysql_backup.log  # 实时查看日志

或手动运行脚本并检查日志:

bash 复制代码
/appdata/mysql_backup_dump.sh > /var/log/mysql_backup.log 2>&1
cat /var/log/mysql_backup.log

总结

方法 命令 特点
覆盖日志 > log 2>&1 每次运行覆盖旧日志
追加日志 >> log 2>&1 保留历史日志
屏幕+文件 `2>&1 tee -a log`
脚本内重定向 exec > log 2>&1 整个脚本生效
系统日志 logger -t TAG -f log 集成到系统日志

选择最适合你的方式即可!

相关推荐
Johny_Zhao6 小时前
OpenClaw安装部署教程
linux·人工智能·ai·云计算·系统运维·openclaw
chlk1232 天前
Linux文件权限完全图解:读懂 ls -l 和 chmod 755 背后的秘密
linux·操作系统
舒一笑2 天前
Ubuntu系统安装CodeX出现问题
linux·后端
改一下配置文件2 天前
Ubuntu24.04安装NVIDIA驱动完整指南(含Secure Boot解决方案)
linux
深紫色的三北六号2 天前
Linux 服务器磁盘扩容与目录迁移:rsync + bind mount 实现服务无感迁移(无需修改配置)
linux·扩容·服务迁移
SudosuBash2 天前
[CS:APP 3e] 关于对 第 12 章 读/写者的一点思考和题解 (作业 12.19,12.20,12.21)
linux·并发·操作系统(os)
哈基咪怎么可能是AI3 天前
为什么我就想要「线性历史 + Signed Commits」GitHub 却把我当猴耍 🤬🎙️
linux·github
十日十行3 天前
Linux和window共享文件夹
linux
木心月转码ing4 天前
WSL+Cpp开发环境配置
linux
崔小汤呀5 天前
最全的docker安装笔记,包含CentOS和Ubuntu
linux·后端