#################################
配置dns邮件服务
#################################
1.安装dns服务
yum install bind -y
2.配置dns服务
vim /etc/named.conf ###配置dns服务主配置文件
将11 17行注释 表示对外开放53端口并允许访问

vim /etc/named.rfc1912.zones
添加westos.com mmm.com域名的指向配置

编写westos及mmm的域名解析文件
cp -p /var/named/named.localhost westos.com.zone
cp -p /var/named/named.localhost mmm.com.zone


测试


##########################
postfix
##########################
1.概述
postfix提供smtp 协议用来投递邮件
默认端口25
/var/log/maillog ###服务日志
mail root@westos.com ###发送邮件给westos.com
Subject: dsaf
test
test
test
. ###"."表示结束录入并发送
mailq ###查看邮件队列
postqueue -f ###重新处理邮件队列
2.配置postfix
vim /etc/postfix/main.cf ###postfix服务主配置文件
76 myhostname = westos.com ###指定mta主机名称

83 mydomain = westos.com ###指定mta域名

99 myorigin = $mydomain ###指定邮件来源结尾

116 inet_interfaces = all ###25端口开启的网络接口

164 mydestination = $myhostname, $mydomain, localhost ###指定接受的邮件结尾

systemctl restart postfix.service
systemctl stop firewalld
测试
在westos.com端给mmm.com发邮件

在mmm.com端查看

3.邮件别名
在接受邮件的主机配置
vim /etc/aliasses
别名: 真名
别名: :include:filename ###邮件群发

vim filename
root
student

postalias /etc/aliases ###更新aliases文件
测试
在发送邮件端

在接收邮件端

4.通过远程主机发送邮件
[root@foundation78 kiosk]# telnet 172.25.254.216 25
Trying 172.25.254.216...
Connected to 172.25.254.216.
Escape character is '^]'.
220 westos.com ESMTP Postfix
mail from:root@westos.com
250 2.1.0 Ok
rcpt to:root@mmm.com
250 2.1.5 Ok
data
354 End data with <CR><LF>.<CR><LF>
1
1
1
.
250 2.0.0 Ok: queued as 3D21817E866

5.邮件客户端的访问控制
在mta上
postconf -e "smtpd_client_restrictions = check_client_access hash:/etc/postfix/access" ###添加访问控制功能


vim /etc/postfix/access ###添加拒绝访问名单
172.25.254.16 REJECT

postmap /etc/postfix/access ###刷新access
systemctl restart postfix.service ###重启postfix服务
测试
[root@foundation78 kiosk]# telnet 172.25.254.216 25
Trying 172.25.254.216...
Connected to 172.25.254.216.
Escape character is '^]'.
220 westos.com ESMTP Postfix
mail from:root@westos.com
250 2.1.0 Ok
rcpt to:root@mmm.com
554 5.7.1 <unknown[172.25.254.78]>: Client host rejected: Access denied

6.限制用户发送邮件
postconf -e "smtp_sender_restrictions = check_sender_access hash:/etc/postfix/sender"

vim /etc/postfix/sender
student@westos.com REJECT

postmap /etc/postfix/sender
systemctl restart postfix
测试
[root@foundation78 kiosk]# telnet 172.25.254.216 25
Trying 172.25.254.216...
Connected to 172.25.254.216.
Escape character is '^]'.
220 westos.com ESMTP Postfix
mail from:student@westos.com
250 2.1.0 Ok
rcpt to:root@mmm.com
554 5.7.1 <student@westos.com>: Sender address rejected: Access denied

7.限制用户接受邮件
postconf -e "smtpd_recipient_restritions = check_recipient_access hash:/etc/postfix/recip"

vim /etc/postfix/recip
studnet@westos.com REJECT

postmap /etc/postfix/recip
systemctl restart postfix
测试
[root@foundation78 kiosk]# telnet 172.25.254.216 25
Trying 172.25.254.216...
Connected to 172.25.254.216.
Escape character is '^]'.
220 westos.com ESMTP Postfix
mail from:root@westos.com
250 2.1.0 Ok
rcpt to:student@westos.com
554 5.7.1 <student@westos.com>: Recipient address rejected: Access denied

8.出站地址伪装
postconf -e "smtp_generic_maps = hash:/etc/postfix/generic"

vim /etc/postfix/generic
studnet@westos.com hello@world.com

postmap /etc/postfix/generic
systemctl restart postfix
测试
su - westos
mail root@qq.com

在mmm.com端查看邮件

9.入站地址转换
做world.com的dns解析

postconf -e "virtual_alias_maps = hash:/etc/postfix/virtual"

vim /etc/postfix/virtual
hello@world.com student@westos.com

postmap /etc/postfix/virtual
测试
mail hello@wrold.com

在westos.com端查看
mail -u studnet

####################################
#dovecot
####################################
1.
dovecot 用来提供收件协议
pop3 110
imap 143
pop3s 995
imaps 993

/etc/services ###所有服务的所有端口
2.安装devecot服务
yum install dovecot y

3.配置
vim /etc/dovecot/dovecot.conf
24 protocols = imap pop3 lmtp

48 login_trusted_networks = 0.0.0.0/0
49 disable_plaintext_auth = no

vim /etc/dovecot/conf.d/10-mail.conf
30 mail_location = mbox:~/mail:INBOX=/var/mail/%u

systemctl restart dovecot
mkdir /etc/skel/mail/.imap -p ###在用户骨架文件中建立所需目录及文件
touch /etc/skel/mail/.imap/INBOX

测试
yum install mutt -y
mutt -f pop://student@172.25.254.216

#########################
postfix + mariadb
#########################
准备工作
yum install httpd php php-mysql mariadb-server -y
config mariadb
mysql_secure_installation

create databs

create table




1.
vim /etc/postfix/mailuser.cf ##用户名称查询
host = localhost ##数据库所在主机
user = postuser ##登陆数据库的用户
password = 123 ##登陆数据库的密码
dbname = email ##postfix要查询的名称
table = emailuser ##postfix要查询的表的名称
select_field = username ##postfix要查询的字段
where_field = username ##用户给定postfix的查询条件

vim /etc/postfix/maildomain.cf ##用户域名查询
host = localhost
user = postuser
password = 123
dbname = email
table = emailuser
select_field = domain
where_field = domain

vim /etc/postfix/mailbox.cf ##用户邮箱位置查询
host = localhost
user = postuser
password = 123
dbname = email
table = emailuser
select_field = maildir
where_field = username

postmap -q "mmm@mmm.com" mysql:/etc/postfix/mailuser.cf
mmm@mmm.com
postmap -q "mmm.com" mysql:/etc/postfix/maildomain.cf
mmm.com
postmap -q "mmm@mmm.com" mysql:/etc/postfix/mailbox.cf
/mnt/mmm.com/mmm

配置postfix
groupadd -g 666 vmail
useradd -s /sbin/nologin -u 666 -g 666 vmail

postconf -e "virtual_mailbox_base = /home/vmail"##设定虚拟账户的邮件目录
postconf -e "virtual_uid_maps = static:666"##虚拟账户建立文件的uid
postconf -e "virtual_gid_maps = static:666"##虚拟用户建立文件的gid
postconf -e "virtual_alias_maps = mysql:/etc/postfix/mailuser.cf"
postconf -e "virtual_mailbox_domains = mysql:/etc/postfix/maildomain.cf"
postconf -e "virtual_mailbox_maps = mysql:/etc/postfix/mailbox.cf"

测试
mail mk@mk.com

查看mk@mk.com的收件情况

##############################
dovecot+mysql
##############################
1. 安装dovecot及插件
yum install dovecot dovecot-mysql -y
##dovecot-mysql devocot的插件,让devocot可以识别mysql

2.配置
vim /etc/dovecot/dovecot.conf
24 protocols = imap pop3 lmtp ##支持收件协议

48 login_trusted_networks = 0.0.0.0/0 ##信任网络

49 disable_plaintext_auth = no ##开启明文认证

vim /etc/dovecot/conf.d/10-auth.conf
123 !include auth-sql.conf.ext ##开启mysql的认证方式

##生成dovecot读取mysql的配置
cp /usr/share/doc/dovecot-2.2.10/example-config/dovecot-sql.conf.ext /etc/dovecot/dovecot-sql.conf.ext

vim /etc/dovecot/dovecot-sql.conf.ext
32 driver = mysql ##数据库类型
71 connect = host=localhost dbname=email user=postuser password=123
##查询时用到的 库,表,用户及秘密

78 default_pass_scheme = PLAIN ##默认认证方式为明文

107 password_query = \ ##查询密码匹配
108 SELECT username, domain, password \
109 FROM emailuser WHERE username = '%u' AND domain = '%d'

125 user_query = SELECT maildir, 666 AS uid, 666 AS gid FROM emailuser WHERE use rname = '%u'

vim /etc/dovecot/conf.d/10-mail.conf
30 mail_location = maildir:/home/vmail/%d/%n ##指定邮件位置

168 first_valid_uid = 666 ##邮件文件查询用户身份

175 first_valid_gid = 666

systemctl restart dovecot
测试
[root@foundation16 Desktop]# telnet 172.25.254.216 110
Trying 172.25.254.216...
Connected to 172.25.254.216.
Escape character is '^]'.
+OK [XCLIENT] Dovecot ready.
user mmm@mmm.com
+OK
pass 123
+OK Logged in.
本文转自Super_MONKEY 51CTO博客,原文链接:http://blog.51cto.com/supermk/1928772
网友评论