Sendmail升级速成

12/3/2006来源:Qmail人气:6276

Sendmail作为邮件服务软件,一直以来,始终为各IT行业厂家的邮件服务器广泛使用,但由于Sendmail在设计当初,只考虑为用户提供邮件发送和接收等服务,并未对网络安全作过多考虑,因此这就为日后的网络黑客提供了攻击他人邮件服务器的可乘之机,即我们通常所说的"邮件转发"。

  邮件黑客正是利用了Sendmail的这一漏洞,利用某些服务器的SMTP不设防的缺陷,将自己的私人邮件通过他人的邮件服务器发向目的地,以满足一己私欲;更有甚者,利用他人邮件服务器,肆意的向外界的任意地址发送"垃圾邮件",这样做,不仅给他人的网络维护造成巨大损失,同时也给接收方带来的诸多不便。

  由于Sendmail自始至终一直作为邮件服务器的标准后台进程,并为广大服务器生产厂家所采纳,因此现阶段,想通过其它软件替代Sendmail做为邮件服务,似乎有远水难解近渴之感;当务之急,只有通过升级Sendmail来达到防止"邮件转发"的目的。

  鉴于篇幅有限,现只对Sendmail的实现做具体说明,有关Sendmail的详细原理,请读者查询相关文档。

  一. Sendmail的获取

  在一般情况下,将sendmail升级到sendmail.8.9.3即可达防止邮件服务器转发的功能。

  TipS:可到以下WWW或FTP站点下在最新的sendmail版本:

  http://www.sendmail.org

  ftp://ftp.ncic.ac.cn

  ftp://ftp.pku.ac.cn

  ftp://ftp.tsinghua.edu.cn

  sendmail的源代码文件为:sendmail..8.9.3.tar.gz

  在获得sendmail.8.9.3.tar.gz后,可通过gunzip和tar命令将此文件解包。

  二. Sendmail的生成

  这是sendmail升级过程中较为重要的一步,它将生成sendmail可执行文件。

  1. 进入当前目录下的/src目录,编辑文件Makefile.m4

  将:MAPDEF= ifdef(`confMAPDEF', `confMAPDEF')

  改为:MAPDEF= ifdef(`confMAPDEF', `confMAPDEF',`NDBM')

  2. 在/src目录下,运行./Build进行编译。

  TIPS:在编译过程中,可能会出现:sh groff not found 的提示信息。

  可将Makefile.m4文件中有关groff的行注释掉即可:

  #NROFF= ifdef(`confNROFF', `confNROFF', `groff -Tascii')

  若想将编译结果直接安装到缺省目录下,可通过:

  ./Build install 来实现。

  若出现gcc not found 或cc not found,可在/usr/bin下做如下软连接:

  ln -s /usr/bin/gcc gcc的实际位置,或 ln -s /usr/bin/cc cc的实际位置。

  如果还出现上述信息,则需要你重新安装gcc或cc编译器。

  三. 生成配置文件sendmail.cf

  1. 进入sendmail-8.9.3目录下的cf/cf目录,编辑tcpPRoto.mc文件:

  将源代码:

  divert(0)dnl

  VERSIONID(`@tcpproto.mc 8.10 (Berkeley) 5/19/1998')

  OSTYPE(*Your Os Type)

  DOMAIN(*Your Domain Name)

  FEATURE(access_db,dbm -o /etc/mail/access)

  FEATURE(blacklist_recipients)

  FEATURE(nouucp)

  MAILER(local)

  MAILER(smtp)

  TIPS:在*Your Os Type一项中填写"你的系统类型"(例如:solaris2),该型文件可在sendmail-8.9.3目录下的/cf/ostype目录下查到。

  在*Your Domain Name一项中填写你的域名,并用单引号括起(例如:'cstnet.net.cn')

  这其中FEATURE(blacklist_recipients),也可省略。

  2. 进入sendmail-8.9.3目录下的cf/domain目录,将文件"generic.m4"更名为"你的域名.m4"(例如:cstnet.net.cn.m4)。

  3. 用m4编译生成sendmail.cf文件。在sendmail-8.9.3/cf/cf目录下执行: m4 ../m4/cf.m4 tcpproto.mc>sendmail.cf 在m4编译过程中不应该出现任何错误提示。

  四. 重新启动sendmail

  在重新启动sendmail之前,需要做一些配置工作:

  1. 检查在/etc目录下是否存在sendmail.cw和aliases文件,若没有,需要建立此二文件:touch /etc/sendmail.cw /etc/aliases

  2. 检查是否存在/etc/mail目录,若没有,则建立此目录并在该目录下建立文本文件access,此文件非常重要,它是用来控制可用此邮件服务器发送邮件的IP地址。此文件将在后面做具体说明.

  3. 在sendmail-8.9.3/makemap目录下,运行./Build,此时在当前目录下会生成一个obj.xxx目录,在此目录下,已经生成了makemap可执行文件。

  TIPS:此时,可在/usr/bin下做makemap的软连接,以备将来使用: Ln -s /usr/bin/makemap makemap的实际位置

  4. 下面,我们对access文件的格式加以说明: 左边 右边 解释说明
  左边 右边 解释说明
  159.226.8.5 RELAY RELAY必须大写,表示允许159.226.8.5主机通过此邮件服务器发送和接收邮件,其余IP格式相同。
  159.226.8 RELAY RELAY必须大写,表示允许159.226.8这一个C通过此邮件服务器发送和接收邮件,其余网段格式相同。
  *[email protected] OK或RELAY OK或RELAY必须大写,表示允许[email protected]这个邮箱可通过此邮件服务器发送和接收邮件。
  *@cstnet.net.cn OK或RELAY OK或RELAY必须大写,表示允许域名 为cstnet.net.cn邮箱通过此邮件服务器发送和接收邮件。
  注释:带*号的格式在实际升级过程中往往不成立,一般情况下请读者不要使用。

  TIPS:在m4编译工程中,有可能出现:m4 not found的提示信息,此时之需要输入m4的完整路径(例如:/usr/bin/m4 ../m4/cf.m4 tcpproto.mc>sendmail.cf)即可。

  如果还未找到m4,那就需要你重新安装m4编译器了。

  这时,可将生成的sendmail.cf文件拷贝到/etc目录下,以备日后使用。

  5. 接下来需要用makemap(上文中已提到)将文本文件/etc/mail/access生成库文件:

  makemap dbm /etc/mail/access
  运行后,将在/etc/mail/目录下生成access.dir和access.pag两个库文件。

  6. 最后启动Sendmail

  执行:/usr/lib/sendmail -bd -q15m

  如果sendmail在缺省目录下,可直接执行:sendmail -bd -q15m

  如果sendmail.cf不再缺省目录下,则执行:/usr/lib/sendmail -bd -q15m -C"sendmail.cf的实际位置"。

  五. 升级维护

  当你需要添加/删除某些用户,允许/禁止他们通过本邮件服务器转发邮件时,只需按照以上格式修改/etc/mail/access文本文件,并执行:

  makemap -dbm /etc/mail/access