naviemail的升级之路-孵化mailrouter

naviemail部署上线经过实际应用后,发现了一些问题。

这些问题是早有预料的。

危机就是转机,问题就是前进的加油站!

为了学习的目的,保留naivemail简单的代码、明了的结构,以naivemail为基础,孵化出 mailrouter !

mail router

1、mailrouter 增加了状态控制,严格控制命令序列执行的状态顺序。不允许未经 HELO 或者 EHLO 发送其他命令。

2、实现了单端口从明文通讯到加密通讯的升级。通过(25端口)明文连接,在接到 starttls 命令后,开启TLS端口,升级到 TLS加密连接。

3、服务启动后,自动生成认证密钥,无需手动生成。

4、支持 Enhanced Status Code。

5、支持多附件。

6、增强安全机制。

  • 发送数据请求限时30秒,如果读取的数据非常长,可能会导致阻塞,设置超时机制,防止恶意阻塞。
  • 设置30秒的读取超时并限制读取长度,防止内存耗尽攻击。

7、体积非常小,仅有 7.2M 。

8、golang原生开发,不依赖其他开发库 。

9、支持docker安装 。

docker 运行

复制代码
docker run -p 25:25 -v /data/volumes/mail-router/emails:/emails -v /data/volumes/mail-router/cert:/cert -v /etc/localtime:/etc/localtime:ro -v /etc/timezone:/etc/timezone:ro --label description="电子邮件路由" --label 启动日期="2025-12-28"  -d --name mailrouter  go-mail-router

Todo List

1、增加对 EHLO 或者 HELO 携带域名参数的检查;

2、对域名参数进行 SPF 验证,验证未通过的全部加入永久黑名单。

3、根据需要对认证签名文件实现动态匹配和加载。

源码地址

https://github.com/golangle/mailrouter

相关推荐
一抹轻笑动人4 小时前
Viger笔记
笔记·golang
思成Codes7 小时前
Go语言的多返回值是如何实现的?
开发语言·后端·golang
Grassto7 小时前
Go 是如何解析 `import path` 的?第三方包定位原理
开发语言·golang·go module·go import
福大大架构师每日一题7 小时前
go-zero v1.9.4 版本发布详解:云原生适配升级与稳定性性能全面提升
开发语言·云原生·golang
molaifeng1 天前
像搭积木一样理解 Golang AST
开发语言·后端·golang
捧 花1 天前
前端如何调用后端接口(HTML + JS & Vue )
服务器·golang·vue·api·前后端交互
bybitq1 天前
Go 语言之旅方法(Methods)与接口(Interfaces)完全指南
开发语言·golang·xcode
saber_andlibert1 天前
【C++转GO】初阶知识
开发语言·c++·golang
IT艺术家-rookie1 天前
golang--解决 Go 并发场景下的数据竞争问题的方案
golang