crontab导致的一个问题排查

摘要

问题描述

  • 服务器内存接近耗尽报警,ps -ef查看有3000多个进程,大部分都是crond、sendmail、postdrop
  • postdrop是由sendmail启动的,而sendmail又是由crond启动的。

问题分析

  • crond在执行脚本时会将脚本输出信息以邮件的形式发送给系统用户,所以必然要调用sendmail
  • 而sendmail又会调用postdrop发送邮件
  • 但是如果系统的postfix服务没有正常运行,那么邮件就会发送不成功
  • 造成sendmail、postdrop、crond进程就无法正常退出,形成大量的僵尸进程

解决办法

  • 先把僵尸进程都干掉,让内存降下来
  • 或者将postfix服务重启一下
1
ps -ef | egrep "sendmail|postdrop" | grep -v grep |xargs kill

推荐解决方案

  • 为防以后postfix挂了再出现类似问题,可以进行如下配置,将crond的邮件通知关闭:
1
2
3
将/etc/crontab和/etc/cron.d/0hourly里的MAILTO=root修改为MAILTO=""
crontab -e第一行增加一段MAILTO=""