手把手教你在linux下搭建一个简单的webmail服务器(上)
今天是我新手期的第六天了,今天和大家说一个简单的装b技巧。。可能有的同学,会问你,你学了一个月的linux,那你现在会什么了啊?今天说的就是做一个简单的webmail邮箱服务器。今天我这用到的是postfix+dovecot的。
照例,还是先和大家说下今天要讲的邮件系统理论东西。
邮件系统概述:
mua(mail user agent 用户代理): 用于收发邮件。
mta(mail transfer agent邮件传输代理):将来自于mua的邮件转发给指定用户。
mda(mail delivery agent邮件投递代理):将来自于mta的邮件保存到本机的收件箱中。(事实上,这个 mda 是挂在 mta 底下的一个小程序, 最主要的功能就是:分析由 mta 所到的信件表头或内容等数据, 来决定这封邮件的去向。)
postfix:提供邮件发送服务,即smtp。
dovecot:提供邮件收取服务,即pop3。
outlook express:客户端收发邮件的工具。
邮件通信协议,这里用到的是smtp简单邮件传输协议,使用的是tcp 25端口,用于发送和传输邮件。pop邮局协议,使用的是tcp 110端口,主要是从邮件服务器收取邮件。还有imap互联网消息访问协议,使用的是tcp 143端口,与pop同样用于收取邮件。目前常见的邮件服务器软件包括商业邮件系统的exchange,notes/domino等,因为我们的项目是和银行合作的,所以看到银行是用的notes,别的倒没见过。还有unix/linux的sendmail,qmail,postfix等。今天讲的postfix是wietse负责开发的,其目的是为了sendmail提供一个功耗的替代产品。postfix在投递效率,稳定性,服务性能以及安全性方面都有相当出色的表现。
好的,理论完毕,开始今天的手动环节。
先做下准备工作,关闭防火墙,关闭selinux,准备今天需要用到的源码包和软件:
postfix的tar包可以在postfix.org下载,用于发邮件。
dovecot的源码包,用于收邮件。
outlook,用于测试。
squirrelmail的源码包可以在squirrelmail.org下载,用于webmail服务器。
当然,你还可以在网上下载一个zh_cn的中文语言包,因为squirrelmail在浏览器里打开,默认是英文的.
==========================================================
1:搭建一个dns服务器:
修改主配置文件/etc/named.conf,改里面的监听,允许查询,指定解析ip,改正向反向解析的区域配置
在/var/named/下,创建主配置文件里标明的正向反向解析文件
设置默认dns服务器,修改/etc/resolv.conf文件
启动服务 /etc/init.d/named start
在这里可以用'nslookup'命令测试一下,你写在正反向解析文件内的域名是不是和ip对应.
============================================================
2:编译安装postfix,开启服务:
安装cyrus*包,卸载之前自带的postfix,确认postfix邮件服务需要用到的用户和组
#这里需要注意一下,安装完cyrus之后,cyrus-sasl的,需要最少安装6个,分别是gssapi,plain,devel,lib,md5,还有一个主程序的。
用make makefiles加扩展参数编译安装postfix的tar包解压出来的源码包,并查看postfix服务支持验证的方式(postconf -a查看)
#这里需要注意一下,我这里用的是:
make makefiles 'ccargs=-dese_sasl_auth -duse_cyrus_sasl -i/usr/include/sasl' 'auxlibs=-l/usr/lib64/sasl2 -lsasl2' && make && make install
#其中编译掺乎ccargs和auxlibs的作用如下:
#ccargs:为编译器提供额外的扩展参数,如:启用sasl认证。并指cyrus_sasl认证程序的头文件位于/usr/incude/sasl
#auxlibs:为编译器指出位于标准位置外的额外函数库。
#我后面直接跟了make,和make install ,大家做的时候,也可以把我上面那条命令,分成3步执行,因为如果你们是最小化安装的系统,那必须分3步执行,这里需要gcc的一些包,我之前做的时候就显示需要160多个包。。有gcc的包,有依赖包,另外这3条命令执行的时间稍微有点长,大家耐心的等待一下,最后的make install安装到最后,是一些选项,一路回车就可以的。
用postfix check检查配置,无信息输出为正确
手动修改安装好的postfix的主配置文件main.cf文件(或在安装postfix完成后,用postconf -n >/etc/postfix/main.cf生成主配置文件,这样生成的内容为去掉默认配置的主配置文件),在里面手动添加自己的监听服务的地址,主机名,域,发件人域,允许接收邮件域,邮件存储位置和格式
这些需要手动添加的,就是下面的这些:
inet_interfaces = 192.168.137.11 , 127.0.0.1
myhostname = mail.test
mydomain = test
myorigin = $mydomain
mydestination = $mydomain , $myhostname
home_mailbox = maildir/
用postfix reload 重启服务
3:测试
用 groupadd -g指定组的gid
用 useradd -g -s /sbin/nologin -g指定和组一样的gid
-s指定不能登陆
用echo 123 | passwd --stdin 用户 &>/dev/null
给用户更改密码为123,并把过程放进回收站/dev/null
用smtp发邮件测试,可以写成文件一起发送,但是需要先安装nc。也可以用telnet 加客户机地址 加25端口号,逐步输入,进行发送邮件
helo mail.test//宣告客户机地址
mail from: test1@test//告知发件人地址
rcpt to: test2@test//告知收件人地址
data//告知要发送邮件数据
subject:test//邮件标题
1111111111111111//邮件内容
.//单独的实点,表示正文结束
quit//断开连接并退出
可以查看/home/用户/maildir/new/下查看发送的邮件信息
4:dovecot收信,并测试
解压并编译安装dovecot,创建不登陆的dovecot用户,把解压包里的doc/dovecot-initd.sh放在/etc/init.d/改名为dovecot 并给x权限
复制解压包里doc/example-config/*到/etc/dovecot/,并编辑dovecot.conf文件。启用系统账号,不适用加密,不关闭明文认证,并指定邮件存放位置
安装pam-devel,在/etc/pam.d下创建dovecot认证文件
启动服务 /etc/init.d/dovecot start
测试方式类似上面发信的方式,不同的是,上面发信是用smtp的25端口,现在收信,用的是pop3的110端口。同样可以用写好的文本发送或者用telnet测试
5:在本机用outlook测试
先在工具-账户设置-新建-手动配置服务器设置或其他服务器类型,新建邮箱。
这里需要注意的是,点完新建,下一步,不要些你的姓名什么的呢,先点下面的勾(就是我下面标注出的地方),再下一步,再写。
邮箱1发信给邮箱2,测试接收。跟直观,比在字符界面跟容易观察
=============================================================
今天的课程好像有点多,我仔细想了一下,还是分两节课给大家讲解吧,要不你也不一定有时间练习。大家如果练习的时候遇到什么问题,可以在下面评论区和我互动。。。希望大家多多的关注,评论,谢谢各位的支持。
另外再和大家说下我的计划,预计是明天把剩下的讲完,后天和大家讲下pxe远程批量装机,pxe的话,就需要dns,ftp,tftp,等一些服务的组合了,另外在讲pxe的时候,我会加一些基础的网卡配置之类的和大家一起讲下,因为之前有同学留言说叫说下基础的东西,我知道应该讲一些基础的东西,但是因为不知道从哪开始讲,所以希望大家多多建议一下,希望讲哪些基础的东西,我回头也准备准备,再和大家一起分享。以后我也会在文章的最后,和大家说一下最近有什么变动的地方和一些留言什么的,希望大家能看到文章的最后,或者一起做的时候,看到最后我说的,没准就是你希望看到的啊。
文章下面的一亩三分地,怎么老是空着啊。。。
最后再和大家说一句,没有意外的话,我一般都会在早晨9点左右发文章的,咱们早上9点不见不散。