首页 > 代码库 > 邮件服务

邮件服务

#################################

配置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的收件情况

技术分享












邮件服务