手把手教你在linux下搭建一个简单的webmail服务器(上)
今天是我新手期的第六天了,今天和大家说一个简单的装B技巧。。可能有的同学,会问你,你学了一个月的Linux,那你现在会什么了啊?今天说的就是做一个简单的webmail邮箱服务器。今天我这用到的是postfix dovecot的。
照例,还是先和大家说下今天要讲的邮件系统理论东西。
邮件系统概述:
MUA(Mail User Agent 用户代理): 用于收发邮件。
MTA(Mail Transfer Agent邮件传输代理):将来自于MUA的邮件转发给指定用户。
MDA(Mail Delivery Agent邮件投递代理):将来自于MTA的邮件保存到本机的收件箱中。(事实上,这个 MDA 是挂在 MTA 底下的一个小程序, 最主要的功能就是:分析由 MTA 所到的信件表头或内容等数据, 来决定这封邮件的去向。)
outlook,用于测试。
squirrelmail的源码包可以在www.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.com
mydomain = test.com
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.com//宣告客户机地址
mail from: test1@test.com//告知发件人地址
rcpt to: test2@test.com//告知收件人地址
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点不见不散。
,