linux shell

关注公众号 jb51net

关闭
首页 > 脚本专栏 > linux shell > shell脚本日志输出到文件

执行shell 脚本将日志全部输出到文件的多种方法

作者:liuyunshengsir

执行Shell脚本时,可将所有输出(stdout+stderr)重定向到日志文件,方法包括直接重定向(> 2>&1)、追加模式(>>)、tee命令(屏幕+文件)、脚本内重定向(exec)及logger系统日志,推荐方法1或2,结合logrotate管理日志大小

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

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

/appdata/mysql_backup_dump.sh > /var/log/mysql_backup.log 2>&1

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

/appdata/mysql_backup_dump.sh >> /var/log/mysql_backup.log 2>&1

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

/appdata/mysql_backup_dump.sh 2>&1 | tee -a /var/log/mysql_backup.log

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

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

#!/bin/bash
exec > /var/log/mysql_backup.log 2>&1  # 所有后续输出都重定向到日志
echo "Backup started at $(date)"
# 备份命令(如 mysqldump)

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

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

/appdata/mysql_backup_dump.sh > /tmp/backup.log 2>&1
logger -t "MySQL_BACKUP" -f /tmp/backup.log  # 写入系统日志
rm -f /tmp/backup.log  # 可选:删除临时日志文件

最佳实践

  1. 推荐方法 1 或 2(简单可靠)。
  2. 日志轮转:使用 logrotate 管理日志文件,避免日志过大:
    # /etc/logrotate.d/mysql_backup
    /var/log/mysql_backup.log {
        daily
        rotate 7
        compress
        missingok
        notifempty
    }
  3. 在 cron 中记录日志
    0 2 * * * /appdata/mysql_backup_dump.sh > /var/log/mysql_backup.log 2>&1

验证日志是否生效

tail -f /var/log/mysql_backup.log  # 实时查看日志

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

/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集成到系统日志

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

到此这篇关于执行shell 脚本将日志全部输出到文件的多种方法的文章就介绍到这了,更多相关shell脚本日志输出到文件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文