如何排查 Cron 任务执行成功但未传输文件的问题
我曾经遇到过一个每晚运行的导出任务,它在 cron 中显示成功,但发送到供应商 SFTP 的文件夹却是空的。服务账号没有配置错误邮件提醒,所以直到供应商询问为什么缺少报告时,支持团队才发现问题。起初看起来像是 SFTP 的问题,但实际上文件在本地根本没有创建。脚本返回了零值,因为 SQL 客户端吞掉了权限警告,并写入了一个空的结果集。 我按照任务实际运行的顺序进行了检查:cron 环境、工作目录、数据库凭据、输出路径、文件大小、校验和,最后是上传。直接在我的 shell 中运行会产生误导,因为我的 PATH 和权限与 cron 不同。我添加了 set -euo pipefail,先将导出内容写入临时文件,并设置上传步骤拒绝低于最小字节数的文件。警报从"任务完成"变更为"文件过小",这最终指向了 SQL 权限问题。 我还修改了成功消息。它不再显示"导出完成",而是显示"已将 48,212…