Chinaunix首页 | 论坛 | 博客
  • 博客访问: 643625
  • 博文数量: 198
  • 博客积分: 4256
  • 博客等级: 上校
  • 技术积分: 1725
  • 用 户 组: 普通用户
  • 注册时间: 2009-12-15 13:12
文章分类

全部博文(198)

文章存档

2012年(12)

2011年(39)

2010年(135)

2009年(12)

我的朋友

分类: LINUX

2010-07-04 01:09:56

几个兄弟想建email服务器,按照wiki死活搞不通,找我写了个傻瓜版教程。
我看了一下,wiki里的确好像有些混乱,就写了。写完就不浪费,顺便贴到坛子里,希望能对有需要的人有点帮助作用
---------------------------------------

需求:
建立EMail服务器,提供SMTP和POP3服务,客户用foxmail或者outlook收发信件。

前提:
域名(mail.example.com)、固定IP、DNS上设置好A、MX、PTR记录

使用软件:
Ubuntu 8.04 Server, Postfix, Dovecot

-------------------------

步骤:
1、装好Ubuntu 8.04,update
注意:如果DNS上PTR记录正确的话,安装过程中系统会自动发现你的主机名和域名。

2、安装postfix
引用:
sudo apt-get install postfix

安装完成后,系统会自动提示进行一些基本信息设置。默认即可。

3、初始配置postfix
引用:
sudo dpkg-reconfigure postfix

默认即可,反正事后可以在main.cf里改

4、配置main.cf
main.cf文件在/etc/postfix下
在mydestination后加上example.com,成为这个样子:
引用:
mydestination = example.com, mail.example.com, localhost.example.com, localhost
这是因为默认情况postfix只接收发到@mail.example.com的邮件,而不接收@example.com的邮件。

5、更改mailbox类型
引用:
sudo postconf -e 'home_mailbox = Maildir/'

注:postconf -e和在mail.cf自己写是一回事,-e for edit
这 个步骤其实为可选操作。mailbox类型可以是mbox或者是maildir,互有优缺点。但如果将来还打算扩展webmail这类应用,最好选为 Maildir,这样兼容性更好一些。对于dovecot pop3而言,倒是无所谓了。具体mbox和maildir有什么区别,去参考《postfix权威指南》

6、安装dovecot
引用:
sudo apt-get install dovecot-pop3d

系统会自动带上dovecot-common,后面配置sasl认证的时候就不用再装了

7、编辑dovecot.conf
主要有两个地方:
引用:
mail_location = maildir:~/Maildir

#我们前面设置了mailbox类型为maildir,这是对应的设置。
引用:
disable_plaintext_auth = no

#默认情况下,dovecot是不允许plaintext类型的认证的,打开

------------------
重启postfix和dovecot。至此,postfix可以收信,并且foxmail可以pop3取信。测试。
到现在foxmail还不能连接到postfix发信,原因是postfix不进行open relay,OR可不能打开,太危险了。
两种解决方案:
a、 在mail.cf里的mynetworks字段加上foxmail所在的网段。默认情况下mynetworks字段只有127.0.0.0/8,所以你 telnet mail.example.com 25 后,是可以发信的。如果你确定foxmail所在的网段,加上即可。
b、很多情况下发信客户ip是不能确定的,所以打开sasl认证。
接下来配置sasl认证
------------------

8、编辑dovecot.conf
在mechanisms字段加上login,成为这个样子:
引用:
mechanisms = plain login

编辑socket listen字段,成为这个样子:
引用:
socket listen {
client {
path = /var/spool/postfix/private/auth-client
mode = 0660
user = postfix
group = postfix
}
}

9、给postfix加上如下配置
引用:
sudo postconf -e 'smtpd_sasl_type = dovecot'
sudo postconf -e 'smtpd_sasl_path = private/auth-client'
sudo postconf -e 'smtpd_sasl_local_domain ='
sudo postconf -e 'smtpd_sasl_security_options = noanonymous'
sudo postconf -e 'broken_sasl_auth_clients = yes'
sudo postconf -e 'smtpd_sasl_auth_enable = yes'
sudo postconf -e 'smtpd_recipient_restrictions = permit_sasl_authenticated,permit_mynetworks,reject_unauth_destination'
sudo postconf -e 'inet_interfaces = all'

10、重起postfix和dovecot。不出意外的话,已经可以通过foxmail正常收发邮件了


注:
1、这样的配置对认证过程不加密,如果害怕密码被监听,就进一步加上ssl好了。
2、 如果被hotmail等退信的话。大部分情况下有两种可能:a、没有PTR记录,找你的ISP做。b、你的IP属于垃圾邮件监控地址(俗称上榜,呵呵), 去查查看。比如(hotmail就是用这个的),如果属于pbl,申请取消就好了,如果sbl这些,那就只能找你的 ISP解决了。gmail则比较奇怪。如果gmail退信的话,试着改一下mail.cf中mydestination的顺序,把localhost改到 前面。改成这个样子:
“mydestination = localhost, localhost.example.com, mail.example.com, example.com”
很多人就这样把问题解决了,但似乎谁都不知道原理 :)
阅读(2908) | 评论(0) | 转发(1) |
给主人留下些什么吧!~~