免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4793 | 回复: 3
打印 上一主题 下一主题

[Mail] Postfix 邮件路由和传输研究(relay_domains部分作修改) [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-10-14 00:09 |只看该作者 |倒序浏览
Postfix 邮件路由和传输研究

本文最初发表于 http://hi.baidu.com/delphiss/blog/item/9f6c71cead14423bf9dc6148.html
转载请注明出处
作者:wdy

postfix从各种渠道收到邮件后,先由cleanup程序处理收件地址,就是把一些不规范的发件和收件地址域名“清理”一下,比如没有的补全,改写等等。

cleanup清理后的邮件被队列管理器交给trivial-rewrite来决定下一步的传输路由。

postfix下一步的传输前需要获得几个目标地址数据:

    mydestination:本地标识;
    virtual_mailbox_domains:虚拟邮箱域名;
    relay_domains:转发域。

路由信息包括邮件一下步的传输者(transport)和下一跳收件地址(next-hop  destinations)。

传输者是指 local 或 smtp 这样的在master.cf 里定义的记录。
next-hop destinations 包括 主机或域名等。

trivial-rewrite 判定的过程如下:

   如果收件域出现在mydestination里,或目标收件ip地址与  $inet_interfaces 或 $proxy_interfaces 匹配,邮件由 [local_transport]投递;
   [local_transport]的缺省设置是 local:$myhostname。表示transport是local(master.cf里定义的),next-hop为$myhostname。

   如果收件域出现在virtual_mailbox_domains里,表示是个虚拟域的邮件,把邮件交给 [virtual_transport];
   [virtual_transport] 缺省的设置是 virtual: ,表示用 virtual 投递,next-hop还是原收件地址。
    virtual 根据 virtual_mailbox_base 来确定邮箱根目录,根据 virtual_mailbox_maps 来确定邮箱的存储路径,根据 virtual_uid_maps 和 virtual_gid_maps 来确定保存邮件使用的uid和gid。
   当然现在大多数都使用 maildrop 来进行虚拟域的投递,安装好maildrop后先在master.cf里把maildrop配置成一个transport,然后设置 :
     virtual_transport   = maildrop:

     如果收件域出现在relay_domains里,则直接转发邮件。
     对于postfix来说,如果收下发往非本域的、需要通过网络转发到别的域的邮件,比如发给新浪搜狐的,则发信人得到许可才给转发。(否则就属于开放转发了,会被垃圾邮件发送者利用)。
     最常见就是发信人连接本域SMTP服务时,通过用户名口令确定了本域的身份,就可以给任何域发送邮件;如果发信人IP地址与 inet_interfaces 或 proxy_interfaces 匹配,则不需要smtp身份认证也可以转发邮件。
     有一种特殊情况除外,那就是如果收件域出现在 relay_domains 里,不需要发信人smtp身份认证就可以转发。
    [relay_transport] 的缺省设置是 relay: ,查看master.cf,relay实际上就是通过smtp来转发邮件的。
    如果 relay_transport 设置里next-hop destinations为空,则依次查询  sender_dependent_relayhost_maps, relayhost 来确定,如果都为空则next-hop 为原收件地址不变。
   
    如果收件域是需要远程投递的其他的域,邮件由 [default_transport]投递;
    [default_transport] 的缺省设置是 smtp: 。smtp MDA会先查询收件域名的mx记录,查询出ip后连接25端口进行投递。
    如果 default_transport 设置里next-hop destinations为空,则依次查询 default_transport, sender_dependent_relayhost_maps,
        relayhost来确定,如果都为空则next-hop 为原收件地址不变。

以上是postfix缺省的邮件路由方式,如果我们要自己指定一些路由方式,比如把 abc.com 所有邮件转发到另外一台主机让它来投递,把 root@xyz.com 的邮件拒收等等,我们就需要用到transport_maps查询表。transport_maps比缺省的postfix路由方式优先级要高。

transport_maps数据项的键名为收件地址,键值为 transport:nexthop
收件地址可以是一个域名,表示匹配这个域名下所有的收件地址。
transport必须是master.cf里定义的传输方式。
如果 transport 传输方式是 inet 类型,则 nexthop 的形式为 host:port。如果 host 是个域名,则先查询mx记录确定ip地址。如果 host 本身就是个ip或是个A记录,则需要用方括号括起来。
port指定要连接的端口,缺省是25。

举几个例子:

abc.com    smtp:[192.168.12.34]:20025
发送给abc.com的邮件使用smtp MDA传送到192.168.12.34的20025端口上。

xyz.com    maildrop
发送给xyz.com的邮件交给maildrop投递。

root@abc.com   error:No mail accepted for root
当场拒收给root@abc.com的邮件,并给出错误信息:No mail accepted for root

spam@mydomain.com    spam
这个是dspam里的设置,表示把发给spam@mydomain.com的邮件交给spam(同样,spam在master.cf里设置)。


----------------------------------------------------------------------------------------------------------------------------
2008-10-17  第一次发布关于 relay_domains 部分的说明基本上是参考了《postfix权威指南》的说法,自己感觉
     说的不太准确,对这部分内容做了修改

[ 本帖最后由 Aryang 于 2008-10-17 13:41 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2008-10-14 00:54 |只看该作者
收藏  不錯不錯   支持

论坛徽章:
8
综合交流区版块每周发帖之星
日期:2015-12-02 15:03:53数据库技术版块每日发帖之星
日期:2015-10-02 06:20:00IT运维版块每日发帖之星
日期:2015-10-02 06:20:00IT运维版块每日发帖之星
日期:2015-09-14 06:20:00金牛座
日期:2014-10-10 11:23:34CU十二周年纪念徽章
日期:2013-10-24 15:41:34酉鸡
日期:2013-10-19 10:17:1315-16赛季CBA联赛之北京
日期:2017-03-06 15:12:44
3 [报告]
发表于 2008-10-14 08:34 |只看该作者
非常谢谢

收藏了

论坛徽章:
0
4 [报告]
发表于 2008-10-17 09:54 |只看该作者
写的的确好,这样东东越多越好!!!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP