# Docker Mailserver docker-mailserver,简称 DMS,是一个可用于生产的全栈但简单的邮件服务器(SMTP、IMAP、LDAP、反垃圾邮件、反病毒等)。它只使用配置文件,不使用 SQL 数据库。其形象以 "保持简单和版本化 "为口号。 ## 前置准备 - `域名` - `DNS 解析` - `服务器` - `Docker` 服务 - `推荐配置`: 1核2G内存 容器已启用交换功能 - `最小配置`: 1核512M内存 (禁用 ClamAV 服务) ### DNS 配置 假设你的域名是 `example.com` 邮件服务器的完全限定域名 (FQDN) 是 mail.example.com,你需要配置以下记录: - `A` 记录: `mail.example.com` 指向你的服务器 IP 地址 - MX 记录告诉每个人哪个 (DNS) 名称负责您域中的电子邮件。 - `MX` 记录: `example.com` 指向 `mail.example.com` - A 记录告诉每个人 DNS 名称 - `PTR` 记录(可选): 你的服务器 IP 地址指向 `mail.example.com` - PTR 记录是 A 记录的对应记录 当然,您也可以完全在 example.com 上配置,您需要更改您的 MX 记录: - `MX` 记录: `example.com` 指向 `example.com` - `A` 记录: `example.com` 指向您的服务器 IP 地址 什么是 PTR 记录?[请参阅](https://en.wikipedia.org/wiki/Reverse_DNS_lookup) 此项服务在 DNS 解析商中可能存在收费,如您不想使用此项服务,可以不配置 PTR 记录。 ### 证书准备 您需要一个有效的 SSL 证书,您可以使用 `Let's Encrypt` 或者其他证书颁发机构颁发的证书。 将证书文件放置在 持久化目录的 `certs` 目录下,文件名为 `public.crt` 和 `private.key`。 ### 端口占用检查 - `25` SMTP 端口 ```sh netstat -tuln | grep 25 ``` 停止Linux 邮件服务 `postfix` 服务, 释放 25 端口, 避免端口占用。 ```sh systemctl status postfix.service systemctl stop postfix.service systemctl disable postfix.service ``` ## 安装完成 首次启动至少要添加一个账户,您有两分钟的时间来执行此操作。请在容器终端中运行以下命令。 如果您错过了这个时间,您可以通过删除容器并重新启动来重新启动此过程。 > 创建 用户 > > `setup email add ` ```sh setup email add user@example.com ``` > 设置别名 > > `setup alias add ` ```sh setup alias add postmaster@example.com user@example.com ``` > 更新证书 将证书文件放置在 持久化目录的 `certs` 目录下,文件名为 `public.crt` 和 `private.key`。 重启容器,即可更新证书。 ## 通过 中继服务器 发送邮件 如果您的 ISP 阻止了 25 端口,您可以使用中继服务器发送邮件。 ### `SMTP 中继主机` 配置 常见的 SMTP 服务器配置如下: - `Gmail`: `smtp.gmail.com` - `QQ`: `smtp.qq.com` - `163`: `smtp.163.com` - `126`: `smtp.126.com` ### `SMTP 中继端口` 配置 常见的 SMTP 服务器端口配置如下: - `Gmail`: `587` - `QQ`: `465` - `163`: `465` - `126`: `465` - `25` 通常也可以使用 ### `SMTP 中继用户名` 配置 常见的 SMTP 服务器用户名配置如下: - `Gmail`: `邮箱地址` - `QQ`: `qq账户` - `163`: `邮箱地址` - `126`: `邮箱地址` ### `SMTP 中继密码` 配置 常见的 SMTP 服务器密码配置如下: > `授权码` 是指在邮箱设置中生成的授权码,不是邮箱密码。 > > `应用密码` 是指在邮箱设置中生成的应用密码,不是邮箱密码。 - `Gmail`: `应用密码` - `QQ`: `授权码` - `163`: `授权码` - `126`: `授权码`