Docker搭建Maddy多合一邮件服务器

GitHub Chasing66/beautiful_docker
Docker enwaiax/maddy

*docker image support for AMD64 and ARM64

简介

基于 foxcpp/maddy 项目的 docker 镜像.

Maddy 是一款用 Go 语言开发的邮件服务器,它实现了运行电子邮件服务器所需的所有功能。

Maddy 用一个具有统一配置和最低维护成本的守护进程取代了 Postfix、Dovecot、OpenDKIM、OpenSPF、OpenDMARC 等程序。

通俗点讲就是部署特别方便, 资源占用少,非常适合个人使用的电子邮件服务器。

预置条件

检查 25 端口是否开放

1
telnet smtp.aol.com 25

部署步骤

1. 创建 docker volume

1
docker volume create maddydata

2. 创建 tls 证书

申请证书步骤略过,将证书 copy 并重命为tls_key.pemtls_cert.pem到 volume 目录

1
2
3
4
5
6
# docker volume 目录
cd $(docker volume inspect maddydata --format '{{.Mountpoint}}')

# 拷贝并重命名证书到当前目录
cp /etc/letsencrypt/live/mx1.example.org/cert.pem tls_cert.pem
cp /etc/letsencrypt/live/mx1.example.org/privkey.pem tls_key.pem

3. 设置 hostname 和 domainname

1
2
export MADDY_HOSTNAME=mx1.example.org
export MADDY_DOMAIN=example.org

4. 创建 maddy 实例

4.1 使用 docker 创建
1
2
3
4
5
docker run -d --name maddy \
  -e MADDY_HOSTNAME=$MADDY_HOSTNAME -e MADDY_DOMAIN=$MADDY_DOMAIN \
  -v maddydata:/data \
  -p 25:25 -p 143:143 -p 465:465 -p 587:587 -p 993:993 \
  enwaiax/maddy:latest
4.2 使用 docker-compose 创建
1
2
3
mkdir maddy && cd maddy
wget https://raw.githubusercontent.com/Chasing66/beautiful_docker/main/maddy/docker-compose.yml
docker-compose up -d

5. 配置 DNS 记录解析

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
# A记录
example.org   A     10.2.3.4
example.org   AAAA  2001:beef::1

# MX记录
example.org   MX    mx1.example.org.
# 同时最好配置mx1.example.org的A记录
mx1.example.org   A     10.2.3.4
mx1.example.org   AAAA  2001:beef::1

# SPF
example.org     TXT   "v=spf1 mx ~all"
mx1.example.org TXT   "v=spf1 mx ~all"

# _dmarc
_dmarc.example.org   TXT    "v=DMARC1; p=quarantine; ruf=mailto:postmaster@example.org"

# _mta-sts,_smtp.tls
_mta-sts.example.org   TXT    "v=STSv1; id=1"
_smtp._tls.example.org TXT    "v=TLSRPTv1;rua=mailto:postmaster@example.org"

# _dmarc
cd $(docker volume inspect maddydata --format '{{.Mountpoint}}')
cat dkim_keys/*.dns

default._domainkey.example.org   TXT    "v=DKIM1; k=ed25519; p=nAcUUozPlhc4VPhp7hZl+owES7j7OlEv0laaDEDBAqg="

6. 创建邮件发送账户

1
2
3
docker exec -it maddy sh
maddyctl creds create postmaster@example.org
maddyctl imap-acct create postmaster@example.org

备份

所有数据挂载在 volume 中,volum 路径为:

1
2
3
4
$ docker volume inspect maddydata --format '{{.Mountpoint}}'
/var/lib/docker/volumes/maddydata/_data
$ cd /var/lib/docker/volumes/maddydata/_data

备份该目录即可