文章目录

  • 一、邮件概述
  • 二、邮件应用协议
  • 三、软件相关
  • 四、企业级邮件服务
  • 4.1 发送方配置
  • 4.1.1 DNS 搭建
  • 4.1.2 安装 gcc 以及其他依赖软件
  • 4.1.3 将 web 页面放到 Apache 的网页目录下
  • 4.1.4 将成品数据库文件导入到 MySQL 中(没设置密码,空密码登录)
  • 4.1.5 将邮件模板拷贝到邮件服务器的主目录下
  • 4.1.6 创建映射用户&修改配置文件
  • 4.1.7 重启服务&发送邮件测试&查看结果
  • 4.2 接收方配置
  • 4.2.1 安装 dovecot 相关软件
  • 4.2.2 配置 dovecot 能够去数据库里读数据
  • 4.2.3 重启 dovecot 验证是否能连接
  • 4.3 MAIL+WEB 页面
  • 4.3.1 修改/etc/httpd/conf/httpd.conf 配置文件,能加载邮件 web 页面
  • 4.3.2 extmail 目录中更改 cgi 的属组属主,让 vmail 有权限执行
  • 4.3.3 extman 中更改 cgi 的属组属主,让 vmail 有权限执行
  • 4.3.4 安装 Unix-Syslog 软件
  • 4.3.5 测试访问


一、邮件概述

电子邮件服务器是处理邮件交换的软硬件设施的总称,包括电子邮件程序、电子邮箱等。为用户提供基于 E-mail 服务的电子邮件系统,人们通过访问服务器实现邮件的交换。

类型

名称

特点

服务器端

Sendmail

资格最古老,运行稳定,但安全性欠佳

Postfix

采用模块化设计,在投递效率、稳定性、性能及安全性方面表现优秀,与 sendmail 保持足够的兼容性。

Qmail

采用模块化设计,速度快、执行效率高,配置稍微复杂点

客户端

Outlook

都是用来收邮件的客户端!

foxmail

浏览器

常见的邮件服务器


二、邮件应用协议

  • SMTP 简单邮件传输协议(发邮件)TCP 25 端口,加密时使用 TCP 465 端口
  • POP3 第三版邮局协议(收邮件)TCP 110 端口,加密时使用 TCP 995 端口
  • IMAP4 第四版互联网邮件访问协议(收邮件)TCP 143 端口,加密时使用 TCP 993 端口


三、软件相关

软件名: Postfix
主目录: /etc/postfix
主配置文件: main.cf
  myhostname:邮件服务器主机名
  mydomain:邮件域
  myorigin:设置允许发信的用户的邮件域
  mydestination:设置允许收信的用户的邮件域



四、企业级邮件服务

前提条件:要有一个 DNS 服务器,将准备好的软件包导入虚拟机

4.1 发送方配置

4.1.1 DNS 搭建
[root@localhost ~]$ yum -y install bind
[root@localhost ~]$ vim /etc/named.conf
 #修改监听地址和访问控制为 any
 options {
        listen-on port 53 { 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";
        allow-query     { any; };
        .......
}

 
[root@localhost ~]$ vim /etc/named.rfc1912.zones
 #使用 extmail.org 作为解析域,只保留正向解析即可
 zone "extmail.org" IN {
        type master;
        file "extmail.localhost";
        allow-update { none; };
};

 
[root@localhost ~]$ vim /var/named/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.88.30
mail    A       192.168.88.30

使用 nslookup 测试 dns 是否能解析

[root@localhost ~]$ service httpd start
[root@localhost ~]$ nslookup www.extmail.org



4.1.2 安装 gcc 以及其他依赖软件
[root@localhost ~]$ yum -y install gcc* mysql-server mysql httpd mailx
#启动 MySQL(Apache)并设置开机自启
[root@localhost ~]$ chkconfig mysqld on && chkconfig httpd on
[root@localhost ~]$ service mysqld start && service httpd start



4.1.3 将 web 页面放到 Apache 的网页目录下

软件包百度网盘:
链接:https://pan.baidu.com/s/1rQ7_9XU2xSsg691bp-QrPw 提取码:u1mi

[root@localhost ~]$ mkdir -p /var/www/extsuite
#创建一个单独的目录

[root@localhost ~]$ tar -xf extmail-1.2.tar.gz -C /var/www/extsuite/
[root@localhost ~]$ tar -xf extman-1.1.tar.gz -C /var/www/extsuite/
#将 extmail 和 extman 解压到创建的目录中

[root@localhost ~]$ cd /var/www/extsuite
[root@localhost ~]$ mv extmail-1.2/ extmail
[root@localhost ~]$ mv extman-1.1/ extman
[root@localhost ~]$ chown -R root.root *
#将两个解压后的目录去掉版本号,并修改文件归属



4.1.4 将成品数据库文件导入到 MySQL 中(没设置密码,空密码登录)
[root@localhost ~]$ cd /var/www/extsuite/
[root@localhost ~]$ mysql < ./extman/docs/extmail.sql
#将./extman/docs 中模板和数据导入到数据库中

[root@localhost ~]$ vim ./extman/docs/init.sql
INSERT INTO `manager` VALUES (‘root@extmail.org’,’123456’,’admin’,’root’)
#将此文件中该位置的密码修改为 123456,切记先修改,再导入

[root@localhost ~]$ mysql < ./extman/docs/init.sql



4.1.5 将邮件模板拷贝到邮件服务器的主目录下
[root@localhost ~]$ cd /var/www/extsuite/extman/docs/
[root@localhost ~]$ cp -a mysql_virtual_alias_maps.cf mysql_virtual_domains_maps.cf mysql_virtual_mailbox_maps.cf /etc/postfix/



4.1.6 创建映射用户&修改配置文件
[root@localhost ~]$ useradd -u 600 -s /sbin/nologin vmail
[root@localhost ~]$ vim /etc/postfix/main.cf
inet_interfaces = all #将此选项取消注释
#inet_interfaces = localhost #将此选项注释掉
#在尾部添加下列内容
virtual_mailbox_base = /home/vmail
virtual_uid_maps = static:600
virtual_gid_maps = static:600
virtual_alias_maps = mysql:/etc/postfix/mysql_virtual_alias_maps.cf
virtual_mailbox_domains = mysql:/etc/postfix/mysql_virtual_domains_maps.c



4.1.7 重启服务&发送邮件测试&查看结果
[root@localhost ~]$ service postfix restart
[root@localhost ~]$ echo "hello" | mail -s test support@extmail.org
[root@localhost ~]$ ls /home/vmail/extmail.org/postmaster/Maildir/new/

启动报错
Nov 12 04:21:29 centos6 postfix[2431]: warning: valid_hostname: numeric hostname: 8
Nov 12 04:21:29 centos6 postfix[2431]: fatal: file /etc/postfix/main.cf: parameter mydomain: bad parameter value: 8

解决办法
修改配置文件
/etc/postfix/main.cf 修改如下内容即可
myhostname = www.extmail.org
#myhostname = virtual.domain.tld



4.2 接收方配置



4.2.1 安装 dovecot 相关软件
[root@localhost ~]$ yum -y install dovecot dovecot-devel dovecot-mysql
[root@localhost ~]$ chkconfig dovecot on
[root@localhost ~]$ service dovecot start



4.2.2 配置 dovecot 能够去数据库里读数据

修改/etc/dovecot/conf.d/10-mail.conf 在配置文件中增加下列两行

[root@localhost ~]$ vim /etc/dovecot/conf.d/10-mail.conf
mail_location = maildir:/home/vmail/%d/%n/Maildir #定义 dovecot 查询邮件的位置(顶头写)
first_valid_uid = 600

修改/etc/dovecot/conf.d/10-auth.conf

[root@localhost ~]$ vim /etc/dovecot/conf.d/10-auth.conf
!include auth-sql.conf.ext #取消调用数据库的记录注释

修改数据库连接配置文件(需要拷贝模板生成)

[root@localhost ~]$ cp -a /usr/share/doc/dovecot-2.0.9/example-config/dovecot-sql.conf.ext /etc/dovecot/ && cd /etc/dovecot
[root@localhost ~]$ vim 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'
#查询虚拟用户对应的邮箱目录



4.2.3 重启 dovecot 验证是否能连接

安装 telnet 客户端进行登录验证

[root@localhost ~]$ yum -y install telnet 
[root@localhost ~]$ service dovecot restart

[root@localhost ~]$ telnet mail.extmail.org 110
user postmaster@extmail.org #登录 postmaster 用户
pass extmail #密码是 extmail
retr 1 #查看第一封邮件



4.3 MAIL+WEB 页面

4.3.1 修改/etc/httpd/conf/httpd.conf 配置文件,能加载邮件 web 页面
[root@localhost ~]$ vim /etc/httpd/conf/httpd.conf
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>

[root@localhost ~]$ httpd -t && service httpd restart



4.3.2 extmail 目录中更改 cgi 的属组属主,让 vmail 有权限执行
[root@localhost ~]$ cd /var/www/extsuite/extmail
[root@localhost ~]$ chown -R vmail.vmail cgi/
[root@localhost ~]$ cp -a webmail.cf.default webmail.cf 
[root@localhost ~]$ vim webmail.cf
#修改如下内容
SYS_MAILDIR_BASE = /home/vmail #邮件存放目录
SYS_CRYPT_TYPE = plain #加密类型
SYS_MYSQL_USER = extmail #MySQL 用户名
SYS_MYSQL_PASS = extmail #MySQL 密码



4.3.3 extman 中更改 cgi 的属组属主,让 vmail 有权限执行
[root@localhost ~]$ cd /var/www/extsuite/extman
[root@localhost ~]$ chown -R vmail.vmail cgi/
[root@localhost ~]$ cp -a webman.cf.default webman.cf
[root@localhost ~]$ vim webman.cf
SYS_MAILDIR_BASE = /home/vmail
SYS_SESS_DIR = /tmp
SYS_CAPTCHA_ON = 0 #1生产环境中开启,实验环境无法显示校验码
SYS_CRYPT_TYPE = plain



4.3.4 安装 Unix-Syslog 软件

解压缩 Unix-Syslog-1.1.tar.gz 软件,软件包前面百度网盘已提供

[root@localhost ~]$ cd /root/extmail && tar -zxvf Unix-Syslog-1.1.tar.gz
[root@localhost ~]$ cd Unix-Syslog-1.1
[root@localhost ~]$ perl Makefile.PL
Checking if your kit is complete...
Looks good
Writing Makefile for Unix::Syslog

[root@localhost ~]$ make && make install



4.3.5 测试访问

在浏览器上访问,windows 测试需要手动指向 dns 服务器
修改windoews的C:\Windows\System32\drivers\etc文件

192.168.88.30 mail.etxmail.org
#  ip地址        域名

浏览器输入http://mail.etxmail.org/访问,用户名postmaster@extmail.org,密码extmail 邮箱管理密码123456