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 天前
Gin 框架中的规范响应格式设计与实现
golang·gin
qwfys2004 天前
How to install golang 1.26.0 to Ubuntu 24.04
ubuntu·golang·install
codeejun4 天前
每日一Go-25、Go语言进阶:深入并发模式1
开发语言·后端·golang
石牌桥网管4 天前
Go 泛型(Generics)
服务器·开发语言·golang
小二·4 天前
Go 语言系统编程与云原生开发实战(第21篇)
开发语言·云原生·golang
小二·4 天前
Go 语言系统编程与云原生开发实战(第20篇)
开发语言·云原生·golang
女王大人万岁4 天前
Golang实战Eclipse Paho MQTT库:MQTT通信全解析
服务器·开发语言·后端·golang
codeejun4 天前
每日一Go-24、Go语言实战-综合项目:规划与搭建
开发语言·后端·golang
石牌桥网管4 天前
Go类型断言
开发语言·后端·golang
普通网友5 天前
PHP语言的正则表达式
开发语言·后端·golang