标签:
前言废话:很早之前就打算写博客,但是一直因为在创业,抽不出时间。如今朝九晚五,打算利用晚上的时间,开始写博客。
本类博客是一个系列,将完整的讲述纯手工开发一个邮件服务器的过程,并附有关键代码。演示地址 作者邮箱: longge93@cliyun.com
这一篇先说整个系统的架构。邮箱系统主要分为几个模块,根据消息发起与传递的对象不同。我把它们分为以下几类:
- 客户端(手机、foxmail等)发起,目的地是各大邮箱服务商的服务器。(协议:SMTP,端口:25)
- 各大邮箱服务商的服务器发起,到该邮件的收件人所在邮箱服务商的服务器。(协议:SMTP,端口:25)
- 有客户端请求,从邮箱服务商服务器商拉取邮件信息或内容。(协议:POP、IMAP,端口:110等)
以上步骤,按照序号依次就是一封邮件从你手机或电脑发出,到达对方终端的过程。
所以,如果要完成一个邮箱服务器,第一步就是实现各种协议。所谓协议,就是在建立socket连接之后,按照事先规定好的“暗号”,传递信息。具体每种协议的规矩,百度可以轻松知道。也可访问协议制定机构的网站获取。
然后我们来整理一下,实现一个邮件服务器,我们需要几个模块:
- 邮件接收器:在服务器上建立socket服务端,监听25端口。接收其他邮件服务器通过SMTP协议发过来的邮件。通常垃圾邮件过滤就是从这里开始的。
- 邮件发送器:当有用户要发送邮件时,在服务器上建立socket客户端,连接到目的邮箱的邮件接收器,通过SMTP协议发出邮件。
- POP、IMAP服务器:收到邮件后,还得让客户通过客户端能拉取到,这个模块的作用就是从数据库读取已经收到的邮件,传递给客户端。不能主动推,只能被动的等待拉取。如果要主动推,可以研究一下微软的exchange协议。
- 邮件转发器:当客户要通过手机等客户端发送邮件时,会先把邮件通过socket传递给你的服务器,然后再由邮件发送器发出。那么,邮件转发器的作用就是从客户端手里接收邮件,传递给发送器发送。该过程使用SMTP协议。
以上几个模块均使用JAVA实现。那么第一个问题来了,当用户使用WEB端,在网页上写好一封邮件,当他点击发送后,我们如何触发JAVA写的邮件发送器呢?这时候就要引入我们的消息中间件模块了。
消息中间件模块是基于redis的,消息发布、订阅机制。阿里云的KVstore对其做了封装。简单的说,就是你可以创建一个管道,这个管道有很多很多分支,你往这个管道里丢什么东西,所有分支都将及时收到这些东西。
利用消息中间件,我们通过WEB端发布管道,JAVA发件器订阅该管道。即可实施触发邮件发送动作。
第二个问题是邮件附件、邮件原EML文件的保存问题。直接保存成文件对服务器压力很大,而且不利于查询等动作。所以我把这些全部推到阿里云的OSS存储上去。把存储路径保存下来。
第三个问题是邮件EML文件的解析、生成的问题。众所周知的javamail遇到中文后,其实蛮多问题。需要慢慢优化,做到更高的效率和正确率。
第四个问题是如何通过WEB端上传大附件。通常的解决办法是安装控件,我这里采用百度的开源项目webuploader,该项目允许用户选择flash和HTML5两种方式之一,来上传附件。并且具有大文件切片、文件上传前HASH验证等功能。
第五个问题是垃圾邮件的过滤问题,参考了很多过滤算法后,打算从神经网络算法延伸一套垃圾邮件过滤算法出来。具体的后面慢慢讲。
第六个问题是如何防止邮件攻击。每天都有大量的垃圾IP试图发送过来,如果每次都在建立socket之后再通过算法判断该IP是否在黑名单等等,太浪费资源。应该自动将其加入防火墙,以后就不用再处理该IP了。
正文从下一篇开始~
JAVA+PHP+阿里云组件纯手工实现POP、SMTP、IMAP开发邮件服务器(一)
标签:
原文地址:http://www.cnblogs.com/cliyun/p/4970708.html