热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【基础部分】之SMTP相关配置

SMTP一、准备工作修改两个主机的主机名1.mailqq.qq.com2.mail163.163.com先配置dns邮件域名在mailqq.qq.com主机上配置dns配置etcn

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:root@qq.com (发送者)

rcpt to:root@163.com (接受者)

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

把 student@qq.com 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 文件

将 student@qq.com 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://student@172.25.15.11

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

技术分享

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

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

> /var/log/maillog

继续在测试机器上 输入指令 mutt -f pop://student@172.25.15.11

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

技术分享

在student下

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

在测试机器上 输入指令 mutt -f pop://student@172.25.15.11

成功

7.postfix 数据库

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

技术分享

技术分享

安全初始化 mysql

mysql -uroot -predhat

CREATE USER postfixuser@localhost identified by ‘redhat’ (创建数据库用户)

GRANTS SELECT,INSERT ON emali.* TO postfixuser@localhost;(给用户添加权限)

创建数据库 创建数据表

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 可查找到

重启服务

测试: mail@test.163.com

写入内容,发送成功。 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: user@domain 中的 user

%d: user@domain 中的 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相关配置


推荐阅读
  • Python学习day3网络基础之网络协议篇
    一、互联网协议连接两台计算机之间的Internet实际上就是一系列统一的标准,这些标准称之为互联网协议,互联网的本质就是一系列网络协议。二、为什么要有互联网协议互联网协议就相当于计 ... [详细]
  • 本文介绍了SIP(Session Initiation Protocol,会话发起协议)的基本概念、功能、消息格式及其实现机制。SIP是一种在IP网络上用于建立、管理和终止多媒体通信会话的应用层协议。 ... [详细]
  • Java EE 平台集成了多种服务、API 和协议,旨在支持基于 Web 的多层应用程序开发。本文将详细介绍 Java EE 中的 13 种关键技术规范,帮助开发者更好地理解和应用这些技术。 ... [详细]
  • 网站访问全流程解析
    本文详细介绍了从用户在浏览器中输入一个域名(如www.yy.com)到页面完全展示的整个过程,包括DNS解析、TCP连接、请求响应等多个步骤。 ... [详细]
  • 在分析和解决 Keepalived VIP 漂移故障的过程中,我们发现主备节点配置如下:主节点 IP 为 172.16.30.31,备份节点 IP 为 172.16.30.32,虚拟 IP 为 172.16.30.10。故障表现为监控系统显示 Keepalived 主节点状态异常,导致 VIP 漂移到备份节点。通过详细检查配置文件和日志,我们发现主节点上的 Keepalived 进程未能正常运行,最终通过优化配置和重启服务解决了该问题。此外,我们还增加了健康检查机制,以提高系统的稳定性和可靠性。 ... [详细]
  • 二维码的实现与应用
    本文介绍了二维码的基本概念、分类及其优缺点,并详细描述了如何使用Java编程语言结合第三方库(如ZXing和qrcode.jar)来实现二维码的生成与解析。 ... [详细]
  • publicclassBindActionextendsActionSupport{privateStringproString;privateStringcitString; ... [详细]
  • 本文详细介绍了在Windows系统中如何配置Nginx以实现高效的缓存加速功能,包括关键的配置文件设置和示例代码。 ... [详细]
  • 本文将从基础概念入手,详细探讨SpringMVC框架中DispatcherServlet如何通过HandlerMapping进行请求分发,以及其背后的源码实现细节。 ... [详细]
  • 说明Python教程正在编写中,欢迎大家加微信sinbam提供意见、建议、纠错、催更。drymail是一个邮件发送库,封装了Python的smtplib ... [详细]
  • 本文详细介绍了如何解决DNS服务器配置转发无法解析的问题,包括编辑主配置文件和重启域名服务的具体步骤。 ... [详细]
  • TCP三次握手过程详解与图示解析
    本文详细解析了TCP三次握手的过程,并通过图示清晰展示了各个状态的变化。同时,文章还介绍了四次挥手的图解,解释了在TIME_WAIT状态中,客户端最后一次发送的ACK包的作用和重要性。 ... [详细]
  • 本文详细介绍了如何安全地手动卸载Exchange Server 2003,以确保系统的稳定性和数据的完整性。根据微软官方支持文档(https://support.microsoft.com/kb833396/zh-cn),在进行卸载操作前,需要特别注意备份重要数据,并遵循一系列严格的步骤,以避免对现有网络环境造成不利影响。此外,文章还提供了详细的故障排除指南,帮助管理员在遇到问题时能够迅速解决,确保整个卸载过程顺利进行。 ... [详细]
  • 本文详细介绍了JQuery Mobile框架中特有的事件和方法,帮助开发者更好地理解和应用这些特性,提升移动Web开发的效率。 ... [详细]
  • 调试利器SSH隧道
    在开发微信公众号或小程序的时候,由于微信平台规则的限制,部分接口需要通过线上域名才能正常访问。但我们一般都会在本地开发,因为这能快速的看到 ... [详细]
author-avatar
Twosssss
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有