在网上看了很多文章,照着来,结果都跑不通。看的多了也慢慢发现了问题所在,每个教程似乎都不够完整。于是结合了两篇文章进行尝试,结果跑通了。
参考文章链接:
https://blog.51cto.com/yuntcloud/2151935
https://www.cnblogs.com/chenjiangfeng/p/9706498.html
https://blog.csdn.net/weixin_44049466/article/details/91986201
看完觉得有用记得给个赞奥,你的赞就是我的动力
环境win7系统上用虚拟机搭建的centos7环境。建议搭建完成之后将环境设置快照。这样之后操作有问题可以快速回滚环境到最初状态,不用再重新安装centos环境。(右键创建的虚拟机,快照->拍摄快照)
1.环境:
OS版本: centos7.7 64bit
mail-server ip: 192.168.65.133
mail-client ip:192.168.1.6
#关闭防火墙
systemctl stop ebtables firewalld
#重启不启动防火墙
systemctl disable ebtables firewalld
#设置selinux 状态为disabled
vim /etc/sysconfig/selinux
#临时将selinux设置为disabled
setenforce 0
#检测selinux是否关闭
getenforce
#查看IP地址
ifconfig ens33 |awk -F ‘[ :]+’ ‘NR==2{print $3}’
#查看主机名
hostname
#在这我把主机名改为了 mail.ajay.com
#修改指令为:
hostnamectl set-hostname mail.ajay.com
2.配置DNS解析
1.安装bind服务
yum -y install bind
2.编辑bing的主配置文件
vim /etc/named.conf
vim /etc/named.rfc1912.zones
在最后添加两项:
3.添加mail邮件解析记录
通过复制named.localhost来快速创建上一步named.rfc1912.zones中需要用到的两个文件,即file文件(如果未创建用到的两个文件xunlong.com.zone和192.168.65.arpa后面就会报错)创建命令为:
cp -p /var/named/named.localhost /var/named/ajay.com.zone
cp -p /var/named/named.localhost /var/named/192.168.65.arpa
编辑区域数据配置文件
vim /var/named/ajay.com.zone
修改为如下内容:
修改为自己的域名和服务器地址客户端地址即可,此处
$TTL 1D
@ IN SOA @ rname.invalid. (
0 ; serial
1D ; refresh
1H ; retry
1W ; expire
3H ) ; minimum
NS ns.ajay.com.
ns IN A 192.168.65.133
www IN A 192.168.65.6
oa IN A 192.168.65.201
blog IN A 192.168.65.6
@ IN MX 10 mail.ajay.com.
AAAA ::1
mail IN A 192.168.65.133
执行:
vim /var/named/192.168.65.arpa
保留不变就行,如下:
$TTL 1D
@ IN SOA @ rname.invalid. (
0 ; serial
1D ; refresh
1H ; retry
1W ; expire
3H ) ; minimum
NS @
A 127.0.0.1
AAAA ::1
4.重启DNS服务
systemctl restart named
systemctl enable named
systemctl status named
3.配置Postfix服务程序
1. 安装postfix软件
yum -y install postfix
2. 修改配置文件
vim /etc/postfix/main.cf
#修改如下:
myhostname = mail.ajay.com #约76行 根据自己的主机填写
mydomain = ajay.com #约83行 根据自己的修改
myorigin = $mydomain #约99行
inet_interfaces = all #约116行
mydestination = $myhostname , $mydomain #约164行
3. 重启服务
执行命令:
systemctl restart postfix
systemctl enable postfix
systemctl status postfix
4. 创建邮件账户
Postfix可以调用本地系统的账户和密码,因此在本地系统创建常规账户即可。
执行命令:
#创建chenjf,密码为chenjf
useradd chenjf
echo “chenjf” | passwd –stdin chenjf
#创建testuser,密码为testuser
useradd testuser
echo “testuser” | passwd –stdin testuser
4. 配置Dovecot服务程序
1. 安装Dovecot服务程序软件包。
yum -y install dovecot
2. 配置部署Dovecot服务程序。
vim /etc/dovecot/dovecot.conf
将24行注释去掉,即把Dovecot服务程序支持的电子邮件协议修改为imap、pop3和lmtp。然后在这一行下面添加一行参数,允许用户使用明文进行密码验证。之所以这样操作,是因为Dovecot服务程序为了保证电子邮件系统的安全而默认强制用户使用加密方式进行登录,而由于当前还没有加密系统,因此需要添加该参数来允许用户的明文登录。
在主配置文件中的第48行,设置允许登录的网段地址,也就是说我们可以在这里限制只有来自于某个网段的用户才能使用电子邮件系统。如果想允许所有人都能使用,则不用修改本参数: 此处我就仅允许我同一网段的使用
3. 配置邮件格式与存储路径。
在Dovecot服务程序单独的子配置文件中,定义一个路径,用于指定要将收到的邮件存放到服务器本地的哪个位置。这个路径默认已经定义好了,我们只需要将该配置文件中第25行前面的井号(#)删除即可。
vi /etc/dovecot/conf.d/10-mail.conf
切换到配置Postfix服务程序时创建的chenfj账户,并在家目录中建立用于保存邮件的目录。至此,对Dovecot服务程序的配置部署步骤全部结束。
执行命令:
su – chenjf
mkdir – p mail/.imap/INBOX
同理为testuser创建保存目录
su – testuser
mkdir – p mail/.imap/INBOX
最后修改接下来的两个配置文件,否则登录时会报错
vi /etc/dovecot/conf.d/10-auth.conf
去掉disable_plaintext_auth前面#,修改为: disable_plaintext_auth = no
vi /etc/dovecot/conf.d/10-ssl.conf
修改为: ssl = no
重启dovecot服务:
service dovecot restart
4. 重启Dovecot服务并将其添加到开机启动项中。
systemctl restart dovecot
systemctl enable dovecot
提示:
若之后登陆、活发送提示没有权限,可以将对应账号下的mail权限设置为700
如testuser 设置mail文件权限
chmod -R 700 /home/testuser/mail
5.客户端验证
如用Foxmail测试的话
下载安装Foxmail
登录用户:
前面创建的两个用户为:
账号1:chenjf
密码:chenjf
账号2:testuser
密码:testuser
用chenjf向testuser发送一封邮件
在ajay(testuser)上右键点击 “收取”即可收到
到此邮箱服务器就搭建完成了。
————————————————
版权声明:本文为CSDN博主「俊逸_Ajay」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_26616235/article/details/105813302