电子邮件服务器是处理邮件交换的软硬件设施的总称,包括电子邮件程序、电子邮箱等。为用户提供基于 E-mail 服务的电子邮件系统,人们通过访问服务器实现邮件的交换;
常见的邮件服务器
邮件的相关协议
软件相关讲解
搭建一个DNS服务器
#关闭firewalld
[root@node0 ~]# systemctl stop firewalld
[root@node0 ~]# systemctl disable firewalld
Removed symlink /etc/systemd/system/multi-user.target.wants/firewalld.service.
Removed symlink /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service.
#安装bind
[root@node0 ~]# yum -y install bind
#修改主配置文件-->修改监听端口
[root@node0 ~]# vim /etc/named.conf
........
options {
listen-on port 53 { any; }; #这里改为any
listen-on-v6 port 53 { ::1; };
directory "/var/named";
dump-file "/var/named/data/cache_dump.db";
statistics-file "/var/named/data/named_stats.txt";
memstatistics-file "/var/named/data/named_mem_stats.txt";
recursing-file "/var/named/data/named.recursing";
secroots-file "/var/named/data/named.secroots";
allow-query { any; }; #这里也需要改为any
#使用 extmail.org 作为解析域,只保留正向解析即可
[root@node0 ~]# vim /etc/named.rfc1912.zones
............
zone "extmail.org" IN {
type master;
file "extmail.localhost";
allow-update { none; };
};
#修改数据文件
[root@node0 ~]# cd /var/named/
[root@node0 named]# cp -a named.localhost extmail.localhost
[root@node0 named]# vim extmail.localhost
$TTL 1D
@ IN SOA extmail.org. rname.invalid. (
0 ; serial
1D ; refresh
1H ; retry
1W ; expire
3H ) ; minimum
NS dns.extmail.org.
MX 3 mail.extmail.org.
dns A 192.168.75.130
mail A 192.168.75.130
#重启服务
[root@node0 named]# systemctl start named
#测试dns服务器
[root@node0 named]# yum -y install bind-utils-9.9.4-72.el7.x86_64
#到这里为止,搭建成功
[root@node0 named]# nslookup mail.extmail.org
Server: 127.0.0.1
Address: 127.0.0.1#53
Name: mail.extmail.org
Address: 192.168.75.130
安装gcc等必要的依赖软件
#安装gcc和mysql
[root@node0 ~]# yum -y install gcc* mysql-server mysql httpd mailx
#启动
[root@node0 ~]# systemctl start httpd
[root@node0 ~]# systemctl start mariadb
#准备好必要的源码包
[root@node0 ~]# ls
anaconda-ks.cfg extmail-1.2.tar.gz extman-1.1.tar.gz Unix-Syslog-1.1.tar.gz
把web页面放到Apache的页面目录下
#创建一个目录
[root@node0 ~]# mkdir -p /var/www/extsuite
#解压目录
[root@node0 ~]# tar -xf extmail-1.2.tar.gz
[root@node0 ~]# tar -xf extman-1.1.tar.gz
#把这两个解压的内容移动到创建的目录上
[root@node0 ~]# cp -a extmail-1.2 /var/www/extsuite/extmail
[root@node0 ~]# cp -a extman-1.1 /var/www/extsuite/extman
#进入到目录,注意一下权限和属主的问题
[root@node0 extsuite]# chown -R root:root extmail/
[root@node0 extsuite]# chown -R root:root extman
[root@node0 extsuite]# ll
总用量 4
drwxr-xr-x 7 root root 4096 12月 25 2009 extmail
drwxr-xr-x 11 root root 240 12月 24 2009 extman
将成品的数据库文件导入到Mysql当中(没有设置密码,使用空密码登录)
#将./extman/docs 中模板和数据导入到数据库中
[root@node0 extsuite]# cd /var/www/extsuite/
[root@node0 extsuite]# mysql < /var/www/extsuite/extman/docs/extmail.sql
#修改另外一个文件
[root@node0 extsuite]# vim ./extman/docs/init.sql
..........
INSERT INTO `manager` VALUES ('[email protected]','123456','admin','root','Super User','my question','my answer'
,'0','2007-02-14 15:10:04','2010-11-08',1);
#然后再导入
[root@node0 extsuite]# mysql < ./extman/docs/init.sql
将邮件模板拷贝到邮件服务器的主目录下
[root@node0 extsuite]# cd /var/www/extsuite/extman/docs/
[root@node0 docs]# cp -a mysql_virtual_alias_maps.cf mysql_virtual_domains_maps.cf mysql_virtual_mailbox_maps.cf /etc/postfix/
创建映射用户和修改配置文件
[root@node0 docs]# useradd -u 600 -s /sbin/nologin vmail
[root@node0 docs]# vim /etc/postfix/main.cf
..........
113 inet_interfaces = all #将此选项取消注释
.....
116 #inet_interfaces = localhost #将此选项注释掉
#在尾部添加下列内容
680 virtual_mailbox_base = /home/vmail
681 virtual_uid_maps = static:600
682 virtual_gid_maps = static:600
683 virtual_alias_maps = mysql:/etc/postfix/mysql_virtual_alias_maps.cf
684 virtual_mailbox_domains = mysql:/etc/postfix/mysql_virtual_domains_maps.cf
685 virtual_mailbox_maps = mysql:/etc/postfix/mysql_virtual_mailbox_maps.cf
#重启服务,验证测试和查看结果
[root@node0 docs]# systemctl restart postfix.service
#验证
[root@node0 docs]# echo "hello " | mail -s test [email protected]
搭建收件方配置
安装过dovecot相关的软件
[root@node0 ~]# yum -y install dovecot dovecot-devel dovecot-mysql
[root@node0 ~]# systemctl start dovecot
配置dovecot能够去到数据库里边读取数据
#修改配置文件
[root@node0 ~]# vim /etc/dovecot/conf.d/10-mail.conf
#添加一下两行数据
mail_location = maildir:/home/vmail/%d/%n/Maildir
#定义 dovecot 查询邮件的位置(顶头写)
first_valid_uid = 600
#再修改另外一个配置文件
[root@node0 ~]# vim /etc/dovecot/conf.d/10-auth.conf
.........##取消调用数据库的记录注释
#!include auth-system.conf.ext
#第三个修改数据库连接的配置文件
[root@node0 ~]# cp -a /usr/share/doc/dovecot-2.2.36/example-config/dovecot-sql.conf.ext /etc/dovecot/
......
[root@node0 ~]# vim /etc/dovecot/dovecot-sql.conf.ext
#将下列内容加入配置文件即可
.........
driver = mysql #驱动类型
connect = host=localhost dbname=extmail user=extmail password=extmail #连接数据库的信息
default_pass_scheme = MD5
password_query = \
SELECT username, domain, password \
FROM mailbox WHERE username = '%u' AND domain = '%d'
#验证登录密码的查询命令
user_query = SELECT maildir, 600 AS uid, 600 AS gid FROM mailbox WHERE username = '%u'
#查询虚拟用户对应的邮箱目录
重启dovecot验证是否能够连接
#安装telnet
[root@node0 ~]# yum -y install telnet
修改/etc/httpd/conf/httpd.conf配置文件,能加载邮件 web页面
NameVirtualHost *:80 #取消注释,开启虚拟主机功能
#添加一下内容
<VirtualHost *:80>
DocumentRoot /var/www/extsuite/extmail/html
ServerName mail.extmail.org
scriptalias /extmail/cgi /var/www/extsuite/extmail/cgi
alias /extmail /var/www/extsuite/extmail/html
scriptalias /extman/cgi /var/www/extsuite/extman/cgi
alias /extman /var/www/extsuite/extman/html
suexecusergroup vmail vmail
</VirtualHost>
extmail 目录中更改 cgi 的属组属主,让 vmail 有权限执行
[root@node0 ~]# chown -R vmail.vmail cgi/
[root@node0 ~]# cp -a webmail.cf.default webmail.cf
[root@node0 ~]# vim webmail.cf
SYS_MAILDIR_BASE = /home/vmail #邮件存放目录
SYS_CRYPT_TYPE = plain #加密类型
SYS_MYSQL_USER = extmail #MySQL 用户名
SYS_MYSQL_PASS = extmail #MySQL 密码
extman 中更改 cgi 的属组属主,让 vmail 有权限执行
[root@node0 ~]# chown -R vmail.vmail cgi/
[root@node0 ~]# cp -a webman.cf.default webman.cf
[root@node0 ~]# vim webman.cf
SYS_MAILDIR_BASE = /home/vmail
SYS_SESS_DIR = /tmp
SYS_CAPTCHA_ON = 0 #生产环境中开启,实验环境无法显示校验码
SYS_CRYPT_TYPE = plain
安装 Unix-Syslog 软件
#解压缩 Unix-Syslog-1.1.tar.gz 软件
yslog-1.1
# perl Makefile.PL
# make
# make install
#剩余的就是验证
在浏览器上访问,windows 测试需要手动指向 dns 服务器