共计 1184 个字符,预计需要花费 3 分钟才能阅读完成。
业务反馈某台应用服务器,普通用户使用 mutt 程序发送邮件时,提示“postdrop warning: mail_queue_enter: create file maildrop/713410.6065: Permission denied”,而且普通用法使用 crontab -e 编辑自身任务计划时,也会提示“crontab: edits left in /tmp/crontab.XXXXCl0bLz”。
使用 postfix check 命令检测发现有如下报错:
postfix/postfix-script: warning: not set-gid or not owner+group+world executable: /usr/sbin/postqueue
postfix/postfix-script: warning: not set-gid or not owner+group+world executable: /usr/sbin/postdrop
上面的提示其实已经非常清楚了,在这两个可执行文件的组权限中,没有 s 权限位。慎重起见,不审找了一台主机对比下,发现确实不存在 s 权限,正常的权限如下:
# ll /usr/sbin/postqueue
-rwxr-sr-x. 1 root postdrop 259992 Jan 27 2014 /usr/sbin/postqueue
解决方法非常简单:
chmod g+s /usr/sbin/postqueue
chmod g+s /usr/sbin/postdrop
postfix reload
使用 crontab -e 发现可以正常查看,但是编辑完,保存时提示“crontab: edits left in /tmp/crontab.XXXXCl0bLz”。即然上面第一个问题是 s 权限位引起的,这个问题想必也是,所以未做 strace 或审计跟踪,地接查看 /usr/bin/crontab 权限位,发现和正常主机对比,发现用户权限上少了 s 权限 ---crontab 命令和 passwd 命令类似,需要用户具有 s 权限位。执行如下命令后,问题解决:
chmod u+s /usr/bin/crontab
rccron restart
注:这点对比了下 SuSE 和 redhat 下的区别,发现 user 权限下如果没有 s 权限位。在 redhat 下提示:
- You (test) are not allowed to use this program (crontab)
- See crontab(1) for more information
而且直接 crontab - l 命令查看时,都会提示上面的错误。而在 SuSE 没有这个 s 权限,仍然可以正常的通过crontab -l 进行查看。