mirror of
https://github.com/QYG2297248353/appstore-1panel.git
synced 2024-11-25 03:18:48 +08:00
132 lines
3.5 KiB
Markdown
132 lines
3.5 KiB
Markdown
# 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 <NEW ADDRESS>`
|
||
|
||
```sh
|
||
setup email add user@example.com
|
||
```
|
||
|
||
> 设置别名
|
||
>
|
||
> `setup alias add <ALIAS> <EMAIL>`
|
||
|
||
```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`: `授权码`
|