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

相关推荐
codeejun2 小时前
每日一Go-66、K8s 蓝绿发布 & 金丝雀发布实战:Service 切流量 + Ingress 灰度一次讲透
开发语言·golang·kubernetes
青春喂了后端3 小时前
Go Sidecar Repository 并发锁改造:让并发请求安全地进入 Git 仓库层
git·安全·golang
2501_931803753 小时前
Go 接口学习笔记:从语法到心法
笔记·学习·golang
pixcarp4 小时前
Redis ZSet:底层设计与实践
数据库·redis·后端·学习·golang·web
极客小云6 小时前
【用 Go 写一个统一的 LLM Token 统计库:tokencalc 的设计与实现】
开发语言·后端·golang
Vect__6 小时前
C++转go的之路:变量声明、iota、函数、切片、init、defer
开发语言·后端·golang
比特森林探险记16 小时前
go 语言中的context 解读和用法
开发语言·后端·golang
jieyucx1 天前
从基础语法到面向对象:Go语言如何实现封装、继承与多态?
开发语言·后端·golang
littleschemer1 天前
Go:实现游戏服务器网关
服务器·网关·游戏·golang
念何架构之路1 天前
Go依赖管理
开发语言·后端·golang