从邮件原理来看 postfix和docecot
好早好早以前计算机网络老师就教了说,邮件嘛,就三个协议smtp,imap,pop3。
smtp 用来发邮件,imap,pop3用来收邮件。噢?是么。难道没有发现这句话有非常多的漏洞,根本就不能说清楚这个邮件发送的整个过程。发邮件? 往哪里发? 收邮件? 往哪里收。当真的编程的时候就无比蛋疼了。
首先总结一句话。完成邮件发送这个整个过程,不管是你发给别人,还是别人发给你,只是通过了smtp协议。换一句话说就是只用postfix,你就可以搭一个邮件服务器。你可以通过它给你的qq邮箱发送,更可以通过qq邮件发送给他。
我们还是先跟随一个典型的发送邮件的到接受邮件的过程,看一看smtp ,imap ,pop3以及postfix, dovecot在这个过程中到底扮演了什么角色。
从最开始,小明用邮件代理(MUA mail user-agent ),可以是你foxmail,outlook,或者是你的web-qq-mail,或者是Thunderbird 。 无论是哪种MUA 邮件创建之后被送到了用户的邮件传输代理服务器(MTA mail transform-agent) ,这个就正是postfix——传输的协议使用smtp协议。然后MTA 也就是postFix 检测你的用户合法性,以及一系列检测(包括你发邮件的限制数量,是否含有什么流氓信息之类的)。等postfix检测完了之后,它就去找DNS找寻 你的目标。例如:你发送给 11111@qq.com , 此时他就去找DNS问 qq.com的ip是多少(详细过程更为复杂一些,例如, qq.com的服务器和 她的邮件服务器很有可能不在一个网段内部,也就是说qq.com那台并不是mail服务器,但是我们的mail服务器又很想用qq.com的域名,怎么搞,总不可能要求别个把mail服务器丢到web服务器的网段嘛。这个时候就可以设置qq.com的mx记录,并且设置到目标主机,详细过程不再赘述)。然后将这封邮件投递给qq.com mx 记录指向的主机的25(默认)端口——此时也是使用smtp协议。当然,考虑到不同的网络配置,可能邮件在传输的过程中很有可能被转移到了另外的MTA,但是最终会有一个MTA接管这封邮件,并且负责投递。然后MTA将邮件转移给某个MDA(邮件投递代理) ——她主要的作用是将邮件保存到本地磁盘中,有些MTA也包揽了这个工作——如postfix就是包含MTA,MDA。
Ok这个时候,邮件发送的整个过程已经结束了(服务器层面上的),也就是说现在你可以给qq.com发,qq.com也可以给你发了,编程实现的投递过程也就到此结束。
你可以ssh到你的邮件服务器,去看下,/hom/mail/...你的目录下面你的邮件了,(显然各个邮件系统的存储方式不尽相同,这只是举个例子)
那么这个时候你nmap一下你的邮件服务器,就会发现多了一个25端口,你可以通过这个端口指示它向mail.qq.com投递,同理qq.com 也可以通过他给你投递一封邮件。
这个时候我们再来看一看Dovecot尼玛在这个过程中到底起到了什么狗屎作用,我好不容易配了一个Postfix,尽然还要装个这货。所以再重复一次,Dovecot并不负责邮件的投递或者存储,这两方面出现了问题,应该考虑你的MTA或者MDA是否正确。
Dovecot的主要配置包括,邮件存储位置,邮件存储类型,用户列表和密码列表,她支持多种用户密码格式。你用该选择一种邮件服务全局都可以接受的用户名和密码格式。以便你的postfix和dovecot沟通咯。
那么有了这个狗屎货之后有什么用呢,你再nmap 一下你的端口,发现多了110,143端口,她们分别是pop和imap端口,这个时候你就可以通过你的outlook等等MUA来查收你的邮件咯,当然如果你设置smtp为本机的话,也就可以发了。大概这个时候一个非常非常简单的邮件服务器就搭起来咯。
所以总的来说dovecot没起到任何作用,pop,imap也没有起到作用。开玩笑哈~
当然如果想要通过这个邮件服务器去给你的用户发送邮件,那显然是不靠谱的,她们妥妥地会出现在你用户的垃圾邮箱,甚至直接就被别人的MTA拦截住了。
从邮件原理来看 postfix和docecot的更多相关文章
- 工程师技术(二):postfix基础邮件服务、postfix空客户端邮件服务、搭建mariadb数据库系统、配置一个数据库、使用数据库查询
一.postfix基础邮件服务 目标: 本例要求在虚拟机server0上配置 postfix 基础服务,具体要求如下: 1> 监听本机的所有接口 2> 将邮件域和邮件服务主机名都改为 ...
- Linux中Postfix邮件原理介绍(一)
邮件相关协议 SMTP(Simple Mail Transfer Protocol)即简单邮件传输协议, 工作在TCP的25端口.它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式 ...
- CentOS7下搭建邮件服务器(dovecot + postfix + SSL)
CentOS 花了基本上两天的时间去配置CentOS7下的邮件服务器.其中艰辛太多了,一定得总结下. 本文的目的在于通过一系列配置,在CentOS 7下搭建dovecot + postfix + ...
- 邮件报警(postfix)
postfix是Wietse Venema在IBM的GPL协议之下开发的MTA(邮件传输代理)软件.postfix是Wietse Venema想要为使用最广泛的sendmail提供替代品的一个尝试.在 ...
- 基础邮件原理(MUA,MTA,MDA)
电子邮件基本概念: MUA(Mail User Agent)接收邮件所使用的邮件客户端,使用IMAP或POP3协议与服务器通信: MTA(Mail Transfer Agent) 通过SMTP协议发送 ...
- 最新ubuntu搭建公网个人邮件服务器(基于postfix,dovecot,mysql)
最近做了一个应用,需要用邮件发通知,但是免费的邮箱每天发信数量是有限制的,所以呢就想着搭建一个自己的邮件服务器,能够实现邮件的发送和接收即可,其中大概花了一个星期找资料,测试,终于成功了,写个教程 ...
- 搭建邮件服务器 使用Postfix与Dovecot
首先需要从yum中下载安装三个服务:bind-chroot postfix dovecot 配置文件依次: /etc/named.conf 下载安装完后要开启的服务:named ...
- 从 React 原理来看 ahooks 是怎么解决 React 的闭包问题的?
本文是深入浅出 ahooks 源码系列文章的第三篇,该系列已整理成文档-地址.觉得还不错,给个 star 支持一下哈,Thanks. 本文来探索一下 ahooks 是怎么解决 React 的闭包问题的 ...
- 邮件服务器启动postfix时的问题:master 已死,但 pid 文件仍存
[root@linux115 ~]# service postfix restart // 重启postfix关闭 postfix:[失败] 启动 postfix: [确定][root@linux ...
随机推荐
- 重温CLR(十五) 托管堆和垃圾回收
本章要讨论托管应用程序如何构造新对象,托管堆如何控制这些对象的生存期,以及如何回收这些对象的内存.简单地说,本章要解释clr中的垃圾回收期是如何工作的,还要解释相关的性能问题.另外,本章讨论了如何设计 ...
- [Luogu4715]「英语」Z 语言
luogu description 你有一个长度为\(n\)的串\(A\)和一个长度为\(m\)的串\(B\),字符集大小\(2^{31}\),且同一个串中没有相同的元素. 定义\(B\)串与\(A_ ...
- 静态和全局变量的作用域zz
全局变量和静态变量的存储方式是一样的,只是作用域不同.如果它们未初始化或初始化为0则会存储在BSS段,如果初始化为非0值则会存储在DATA段,见进程的地址空间分配一文. 静态变量的作用域是当前源文件, ...
- [深度学习]实现一个博弈型的AI,从五子棋开始
好久没有写过博客了,多久,大概8年???最近重新把写作这事儿捡起来……最近在折腾AI,写个AI相关的给团队的小伙伴们看吧. 搞了这么多年的机器学习,从分类到聚类,从朴素贝叶斯到SVM,从神经网络到深度 ...
- cocos2dx 3.0 编译工程
下载完2dx,运行setup.py,参考设置ANDROID_SDK,NDK_ROOT,ANT_ROOT变量 创建工程 cocos new testGame -p com.game.test -l cp ...
- cpp分解质因数
原理有点像埃氏筛. #include <stdio.h> #include <iostream> #include <stdlib.h> using namespa ...
- java http头信息
JAVA 从http请求头中获取Header信息: request.getHeader(),request.getHeaderNames(),request.getHeaders() Java获取Ht ...
- Python项目打包成exe文件
这里我们使用pyinstaller这个软件即可,使用pip即可完美安装,在要打包的程序目录下打开cmd输入 pyinstaller -F 文件名.py 即可成功,运行成功后生成一个dict文件夹,东西 ...
- windows python文件拷贝到linux上执行问题-换行符问题/r/n
之前在Windows下写好了一个Python脚本,运行没问题,今天在Linux下,脚本开头的注释行已经指明了解释器的路径,也用chmod给了执行权限,但就是不能直接运行脚本. 1 问题1: 报错:: ...
- MySQL重启端口被占用处理
1,查看日志的ERROR 2018-05-23T01:26:59.230382Z 0 [Warning] 'NO_AUTO_CREATE_USER' sql mode was not set. 201 ...