listmonk 开源邮件列表系统安装指南
listmonk 是一款高性能、开源的邮件列表和通讯管理系统,采用 Go 语言开发,具有轻量级、易部署的特点。本文将详细介绍 listmonk 的多种安装方式,帮助您快速搭建自己的邮件列表系统。
系统要求
在开始安装前,请确保您的环境满足以下基本要求:
- 数据库:PostgreSQL 12 或更高版本
- 操作系统:支持 Linux、macOS 和 Windows
- 内存:建议至少 1GB 可用内存
- 存储空间:根据邮件列表规模而定,建议至少 10GB
二进制安装方式
二进制安装是最简单直接的部署方式,适合大多数 Linux 服务器环境。
1. 下载二进制文件
首先需要下载最新版本的 listmonk 二进制文件。根据您的 CPU 架构选择合适的版本(amd64 适用于大多数 Intel 和 AMD 处理器)。
2. 生成配置文件
解压下载的文件后,执行以下命令生成默认配置文件:
./listmonk --new-config
这将在当前目录下生成 config.toml 文件,您需要编辑此文件配置数据库连接等参数。
3. 初始化数据库
配置好数据库连接信息后,执行安装命令初始化数据库表结构:
./listmonk --install
专业提示:可以通过环境变量预设管理员账号:
LISTMONK_ADMIN_USER=admin LISTMONK_ADMIN_PASSWORD=yourpassword ./listmonk --install
4. 启动服务
完成安装后,直接运行二进制文件启动服务:
./listmonk
默认情况下,服务会监听 9000 端口,您可以通过浏览器访问 http://localhost:9000 进入管理界面。
Docker 容器化部署
Docker 部署方式更加便捷,特别适合需要快速部署或测试环境的用户。
1. 准备 docker-compose 文件
首先需要获取官方提供的 docker-compose.yml 文件,该文件已经配置好了 listmonk 和 PostgreSQL 服务。
2. 启动容器
使用以下命令启动所有服务:
docker compose up -d
专业提示:首次启动时可以通过环境变量设置管理员账号:
LISTMONK_ADMIN_USER=admin LISTMONK_ADMIN_PASSWORD=yourpassword docker compose up -d
3. 自定义配置
如果需要使用自定义配置文件,可以按照以下步骤操作:
- 创建 config.toml 文件并配置必要参数
- 修改 docker-compose.yml,添加卷挂载配置
- 更新启动命令指向自定义配置文件路径
从源代码编译
对于开发者或需要定制功能的用户,可以从源代码编译 listmonk。
编译环境准备
需要安装以下工具:
- Go 语言环境(1.16+)
- Node.js 和 Yarn(用于前端构建)
编译步骤
- 克隆源代码仓库
- 进入项目目录执行
make dist命令 - 编译完成后会在目录下生成可执行文件
Kubernetes 部署
对于生产环境,可以使用 Helm Chart 在 Kubernetes 集群中部署 listmonk。
部署步骤
- 准备 values.yaml 配置文件
- 使用 Helm 命令部署:
helm upgrade --install listmonk --namespace listmonk --values values.yaml
生产环境建议
- 数据库优化:对于大型邮件列表,建议对 PostgreSQL 进行性能调优
- 反向代理:建议使用 Nginx 或 Apache 作为反向代理,并配置 SSL
- 备份策略:定期备份数据库和配置文件
- 监控:设置适当的监控告警机制
常见问题解答
Q:listmonk 支持哪些邮件发送服务? A:listmonk 支持 SMTP 协议,可以与大多数邮件服务(如 SendGrid、Mailgun、Amazon SES 等)集成。
Q:如何升级 listmonk? A:二进制方式只需替换二进制文件并重启服务;Docker 方式更新镜像版本即可。
Q:listmonk 支持多租户吗? A:目前 listmonk 是单租户设计,每个实例只能服务一个组织。
通过本文介绍的多种安装方式,您可以根据实际需求选择最适合的部署方案。listmonk 作为一款功能强大的邮件列表系统,能够满足从个人到中小企业的各种邮件营销需求。
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin07
compass-metrics-modelMetrics model project for the OSS CompassPython00