问题:登录服务器某用户时,出现以下问题(资源暂时不可用):但是该服务器的其他用户能正常登录,经查看该用户下存在大量的sendmail、postdrop进程,初步确定是crond引发大量的sendmail、postdrop进程导致。
su: cannot set user id: Resource temporarily unavailable
服务器内存接近耗尽报警,ps -ef查看有3000多个进程,大部分都是crond、sendmail、postdrop
而 postdrop是由sendmail启动的,而sendmail又是由crond启动的。
问题分析和解决思路:
为题分析:crond在执行脚本时会将脚本输出信息以邮件的形式发送给系统用户,所以必然要调用sendmail,而sendmail又会调用postdrop发送邮件,但是如果系统的postfix服务没有正常运行,那么邮件就会发送不成功,造成sendmail、postdrop、crond进程就无法正常退出,形成大量的僵尸进程,
解决方案:kill掉sendmail进程和postdrop进程,让内存降下来
1.kill掉sendmail进程
kill -9 $(ps -ef |grep hochoy | grep sendmail |gawk '$0 !~/grep/ {print $2}' | tr -s '\n' ' ')
扫描二维码关注公众号,回复: 3907905 查看本文章2.kill 掉postdrop进程
kill -9 $(ps -ef |grep hochoy | grep postdrop |gawk '$0 !~/grep/ {print $2}' | tr -s '\n' ' ')
为防以后postfix挂了再出现类似问题,可以进行如下配置,将crond的邮件通知关闭:
将/etc/crontab和/etc/cron.d/0hourly里的MAILTO=root修改为MAILTO=""
crontab -e第一行增加一段MAILTO=""