哥使用Linux
分类: LINUX
2009-04-19 20:34:03
apt-get install postfix postfix-doc libsasl2 sasl2-bin courier-imap courier-pop courier-authdaemon |
START=yes MECHANISMS="shadow" |
0: OK "Success." |
smtpd_banner = $myhostname ESMTP $mail_name (Debian/GNU) biff = no append_dot_mydomain = no myhostname = vd.vlinux.net alias_maps = hash:/etc/aliases alias_database = hash:/etc/aliases myorigin = /etc/mailname mydestination = $myorigin, localhost.localdomain, localhost relayhost = mynetworks = 127.0.0.0/8 mailbox_size_limit = 0 recipient_delimiter = + inet_interfaces = all home_mailbox = Maildir/ smtpd_sasl_auth_enable = yes smtpd_recipient_restrictions = permit_sasl_authenticated, reject_unknown_recipient_domain, reject_non_fqdn_recipient reject_non_fqdn_hostname, reject_non_fqdn_sender, reject_non_fqdn_recipient, reject_unauth_destination, reject_unauth_pipelining, reject_invalid_hostname, permit |
192.168.5.2 vd.vlinux.net vd |
pwcheck_method: saslauthd saslauthd_path: /var/run/saslauthd/mux mech_list: PLAIN LOGIN |
vd:~# telnet localhost 25 Trying 127.0.0.1... Connected to localhost.localdomain. Escape character is '^]'. 220 vd.vlinux.net ESMTP Postfix (Debian/GNU) ehlo localhost 250-vd.vlinux.net 250-PIPELINING 250-SIZE 10240000 250-VRFY 250-ETRN 250-AUTH LOGIN PLAIN 250 8BITMIME ] |
vd:~# telnet localhost 25 Trying 127.0.0.1... Connected to localhost.localdomain. Escape character is '^]'. 220 vd.vlinux.net ESMTP Postfix (Debian/GNU) ehlo localhost 250-vd.vlinux.net 250-PIPELINING 250-SIZE 10240000 250-VRFY 250-ETRN 250-AUTH LOGIN PLAIN 250 8BITMIME auth login 334 VXNlcm5hbWU6 dGVzdA== //用户名test的的Base64编码 334 UGFzc3dvcmQ6 dGVzdHBhc3M= //密码testpass的Base64编码 535 Error: authentication failed |
perl -MMIME::Base64 -e 'print encode_base64("user")' |
php -r 'echo base64_encode("user")."\n";' |
echo -n "user" | openssl base64 -a |
Feb 26 23:39:47 vd postfix/smtpd[2323]: connect from localhost.localdomain[127.0.0.1] Feb 26 23:39:57 vd postfix/smtpd[2323]: warning: SASL authentication failure: cannot connect to saslauthd server: No such file or directory Feb 26 23:39:57 vd postfix/smtpd[2323]: warning: localhost.localdomain[127.0.0.1]: SASL login authentication failed |
smtp inet n - n - - smtpd |
Feb 26 23:47:23 vd postfix/smtpd[2405]: warning: SASL authentication failure: cannot connect to saslauthd server: Permission denied |
Starting SASL Authentication Daemon: ‘/var/run/saslauthd’ 的权限模式已更改为 0710 (rwx--x---) |
很早以前曾经写过Debian下安装Postfix的第一篇,由于时间问题,使用虚拟用户及多域名的配置一直没时间整理,现在终于完成了。 1. 安装相关软件
2. 安装postfixadmin 由于使用mysql支持postfix需要自己设计数据库的结构,在这里我们使用一个第三方的软件postfixadmin,幸运的是现在postfixadmin有了deb安装包。
修改/etc/config.inc.php
其它的选项,您可以根据自己的喜好修改。在mysql中创建postfix所用数据库及帐户:
从以下页面访问postfixadmin的管理界面: 在各项检查通过后,即可创建一个管理员帐号(邮箱格式)。成功后删除/usr/share/postfixadmin/setup.php文件。再次登录postfixadmin界面后就可以用创建的管理员帐号进行管理了,如创建域名,创建邮箱,创建对某些域名具有管理权的管理员等。 3. 配置postfix支持mysql 修改/etc/postfix/main.cf文件如下:
并依次创建如下文件:
关于详细配置请见/usr/share/doc/postfixadmin/DOCUMENTS/POSTFIX_CONF.txt。 修改/etc/postfix/master.cf,将smtp的chroot改为n
4. 配置并验证smtp的sasl认证 修改/etc/default/saslauthd文件设置 START=yes(注意yes一定要是小写),启用saslauthd服务:/etc/init.d/saslauthd start 新建sasl认证配置文件smtpd.conf
将postfix用户加入sasl组,建立/etc/pam.d/smtp文件如下:
修改/etc/default/saslauthd文件中options行
重启postfix服务: /etc/init.d/postfix restart 验证:
或者用下列方法验证:
5. 验证邮件接收 在本地使用mail命令向新建用户发送邮件
如果接收到新邮件,会存放在/home/postfix/domain/user/new目录下. 6. 配置pop3和imap 修改/etc/courier/authdaemonrc文件中下行:
修改/etc/courier/authmysqlrc文件如下:
验证: 重启courier-authdaemon服务: /etc/init.d/courier-authdaemon restart
出现以上信息说明imap和pop3服务配置成功, 可以使用邮件客户端收发信件了。 7. 安装webmail debian下的webmail试了许多, 发现ilohamail是配置最方便且界面友好的,最好修改以下几个地方。 登录界面调整修改文件/etc/IlohaMail/login.php:
由于中文界面有些地方翻译的不是很好,需要修改/usr/share/IlohaMail/lang/cn目录下的一些文件。下面是已要修改完成的打包文件:
Debian上PostFix的配置(三)
|