基础部分之SMTP相关配置

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了基础部分之SMTP相关配置相关的知识,希望对你有一定的参考价值。

SMTP

一、准备工作

修改两个主机的主机名 1.mailqq.qq.com 2.mail163.163.com

先配置dns 邮件域名 在mailqq.qq.com主机上配置dns

配置/etc/named.rfc1912.zones

配置qq.com 163.com 两个域名

技术分享

技术分享

二、配置邮件

mta: 邮件软件 postfix sendmail qmail

mtp:

1.先查看自己的mta是什么软件

alternatives --display mta

技术分享

2.配置 /etc/postfix/main.cf

技术分享

技术分享

技术分享

技术分享

两个主机都要写

3.配置火墙(两台主机都配置)

firewall-cmd --permanent --add-service=smtp

firewall-cmd --reload

163.com主机还需要配置 firewall-cmd --permanent --add-service=dns

firewall-cmd --reload

mailq: 邮件等待队列(未发出去的邮件会存在这)

postqueue -f 刷新邮件等对队列(重新发送一遍)

postsuper -d (邮件队列中的邮件编码) 删除该邮件

rm -fr /var/spool/postfix/maildrop/ (清空邮件队列)

/var/log/maillog (邮件日志)

三、远程发送

1.远程机器连接qq.com发送邮件

如果没有telnet先下载安装telnet

其他同网段机器 telnet 172.25.15.10 25

(qq.com主机) (25端口)

技术分享

ehlo hello (查看设备信息(打招呼))

mail from:[email protected] (发送者)

rcpt to:[email protected] (接受者)

data (输入邮件内容)

2.拒绝某一个机器远程发送

postconf -d (查看默认配置)

postconf -e (修改或者添加选项直接将命令写入文件中) 写入到 /etc/postfix/main.cf

postconf -d | grep client

技术分享

postconf -e “smtpd_client_restrictions = check_client_access hash:/etc/postfix/access”

把 172.25.15.250 REJECT 写入 /etc/postfix/access

(被禁止的机器的IP)

postmap /etc/postfix/access (hash加密生成 .db 文件)

测试:

技术分享

3.禁止某一用户发送邮件

先删除掉上一步的禁止机器发送邮件

在/etc/postfix/access中删除 172.25.15.250 REJECT 那一行

postmap access (重新生成hash加密文件 access.db)

postconf -d | grep sender

查找到 smtpd_sender_restrictions = 那一行

postconf -e “smtpd_sender_restrictions = check_sender_access hash:/etc/postfix/sender”

/etc/postfix/sender 这个文件不存在 需要自己创建

vim /etc/postfix/sender

[email protected] REJECT 写入该文件

postmap /etc/postfix/sender (hash加密 生成.db 文件)

重启 postfix 服务

测试:

技术分享

4.禁止某一用户接受邮件

Postconf -d | grep recip

查找到 smtpd_recipient_restrictions =

postconf -e

“smtpd_recipient_restrictions = check_recipient_access hash:/etc/postfix/dest”

自己创建 /etc/postfix/dest 文件

[email protected] REJECT 写入到上文件中

postmap dest (hash加密该文件生成 .db 文件)

重启 postfix 服务

测试:

技术分享

5.空壳邮件服务器 (保护主服务器 空壳服务器不留存邮件 直接转发到主服务器)

两台机器 mailqq.qq.com 修改为 null.qq.com(空壳邮件服务器)

mail163.163.com 修改为 mailserver.qq.com (主服务器)

修改server主机的配置

vim /etc/postfix/main.cf

技术分享

技术分享

技术分享

技术分享

重启postfix服务

修改 null主机的配置

/etc/postfix/main.cf

技术分享技术分享技术分享

重启postfix服务

测试:

在空壳服务器上接受不到该邮件:

技术分享

在主服务器上收到了该邮件:

技术分享

6.远程接受邮件

安装 dovecot 软件

技术分享

firewall-cmd --reload

将端口添加到防火墙

vim /etc/dovecot/dovecot.conf

技术分享技术分享

接着配置 /etc/dovecot/conf.d/10-mail.conf

技术分享

测试: 在测试机器上安装 mutt 软件

在接收服务器上给student 发送邮件

在接受服务器上清空 邮件日志 排错

> /var/log/maillog

在测试机器上 输入指令 mutt -f pop://s[email protected]

提示错误 查看接收服务器的邮件日志

技术分享

在studnet下创建 mkdir /home/student/mail/.imap

在接收服务器上清空 邮件日志 继续排错

> /var/log/maillog

继续在测试机器上 输入指令 mutt -f pop://[email protected]

提示错误 继续查看接收服务器的邮件日志

技术分享

在student下

touch /home/student/mail/.imap/INBOX

在测试机器上 输入指令 mutt -f pop://[email protected]

成功

7.postfix 数据库

yum install mariadb mariadb-server php php-mysql http -y

技术分享

技术分享

安全初始化 mysql

mysql -uroot -predhat

CREATE USER [email protected] identified by ‘redhat’ (创建数据库用户)

GRANTS SELECT,INSERT ON emali.* TO [email protected];(给用户添加权限)

创建数据库 创建数据表

1.图形界面模式

下载phpMyAdmin-3.4.0-all-languages.tar.bz2

tar jxf phpMyAdmin-3.4.0-all-languages.tar.bz2 -C /var/www/html/

将解压后的文件 修改名字为 mysqladmin

cp -p config.sample.inc.php config.inc.php

修改 config.inc.php 中添加 cookie

firewall-cmd --permanent --add-service=http

firewall-cmd --reload

通过火狐浏览器 登陆 创建数据库和表(很简单)

表有4个列 username password domain(域名) maildir (mail存放目录)

2.命令模式

CREATE DATABASE email (创建email数据库) 创建表如下

技术分享

录入数据

技术分享

3.网络用户邮件服务配置

写文件 /etc/postfix/my-emailuser.cf

where_field = username (在哪一列查找所输入的内容)

技术分享

写文件 /etc/postfix/my-emaildomain.cf

技术分享

写文件 /etc/postfix/my-emailmaildir.cf

技术分享

检测这几个文件

技术分享

技术分享

技术分享

在主机上创建 用户vmail uid=1092 gid=1092

将指令写入到文件中 /etc/postfix/main.cf

技术分享

上述命令通过指令 postconf -d | grep virtual 可查找到

重启服务

测试: [email protected]

写入内容,发送成功。 cd /home/vmail/163.com/test/ 查看文件内容 为 邮件内容。

邮件底层发送接收服务架设

通过dovecot 收取 邮件

postfix dovecot

1.邮件服务器的配置

yum install dovecot -y

vim /etc/dovecot/dovecot.conf

技术分享

技术分享

vim /etc/dovecot/conf.d/10-auth.conf

技术分享

上面的文件可以看出来 要去修改auth-sql.conf.ext 文件

查看 auth-sql.conf.ext

技术分享

可以看出 文件内容要求复制

/usr/share/doc/dovecot-2.2.10/example-confis/dovecot-sql.conf.ext

到 /etc/dovecot/ 下

接着配置该文件(/etc/dovecot/dovecot-sql.conf.ext)

技术分享

技术分享

技术分享(密码类型为明文)

技术分享

技术分享

%u: username

%n: [email protected] 中的 user

%d: [email protected] 中的 domain

%h: home directory

接着修改 /etc/dovecot/conf.d/10-mail.conf

技术分享

在邮件服务器的机器上 安装 dovecot-mysql 软件

重启服务

测试:

在其他测试机器上 telnet 172.25.15.10 110

技术分享

接着在测试机器上 安装 雷鸟邮件客户端

yum install thunderbird-31.2.0-1.el7.x86_64.rpm

技术分享

选择左下角

技术分享

添加数据库里有的 邮件账户

技术分享

技术分享

即可登陆成功

技术分享

以上是关于基础部分之SMTP相关配置的主要内容,如果未能解决你的问题,请参考以下文章

基础部分之FTP相关配置

基础部分之ISCSI的相关配置

Nginx基础入门之相关配置模板样例参考

Centos 7下postfix采用dovecot做为smtp验证相关问题?

Linux搭建smtp服务器+laravel5.2发邮件配置

spring boot基础之servlet3.0和spring4.x零配置相关文章