问题描述
服务器内存接近耗尽报警,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 | 将/etc/crontab和/etc/cron.d/0hourly里的MAILTO=root修改为MAILTO="" |