Docker 部署
使用 Docker 部署 Message Nest,支持多种配置方式。
推荐指数
🍀🍀🍀🍀🍀 最推荐的部署方式
镜像源
Message Nest 提供两个镜像源:
- GitHub Container Registry (推荐):
ghcr.io/engigu/message-nest:latest - Docker Hub (备选):
engigu/message-nest:latest
方式一:挂载配置文件
1. 准备配置文件
新建 conf/app.ini 文件:
ini
[app]
JwtSecret = message-nest
LogLevel = INFO
[server]
RunMode = release
; docker模式下端口配置文件中只能为8000
HttpPort = 8000
ReadTimeout = 60
WriteTimeout = 60
; 注释EmbedHtml,启用单应用模式
; EmbedHtml = disable
[database]
; 关闭SQL打印
; SqlDebug = enable
; Type = sqlite
Type = mysql
User = root
Password = Aa123456
Host = vm.server
Port = 3308
Name = yourDbName
TablePrefix = message_端口限制
Docker模式下,配置文件中的端口只能为8000,通过 -p 参数映射到宿主机端口。
2. 拉取镜像
bash
# 从 GitHub Container Registry (GHCR) 拉取(推荐)
docker pull ghcr.io/engigu/message-nest:latest
# 或从 Docker Hub 拉取
docker pull engigu/message-nest:latest3. 启动容器
bash
# 测试运行(GHCR 镜像,推荐)
docker run --rm -ti \
-p 8000:8000 \
-v /your/path/conf:/app/conf \
ghcr.io/engigu/message-nest:latest
# 测试运行(Docker Hub 镜像)
docker run --rm -ti \
-p 8000:8000 \
-v /your/path/conf:/app/conf \
engigu/message-nest:latest
# 正式运行(GHCR 镜像,推荐)
docker run -d \
-p 8000:8000 \
-v /your/path/conf:/app/conf \
ghcr.io/engigu/message-nest:latest
# 正式运行(Docker Hub 镜像)
docker run -d \
-p 8000:8000 \
-v /your/path/conf:/app/conf \
engigu/message-nest:latest方式二:环境变量(推荐)
推荐
这是最简单的部署方式,无需准备配置文件。
环境变量说明
| 变量 | 说明 |
|---|---|
| JWT_SECRET | jwt秘钥,可选,默认为message-nest |
| LOG_LEVEL | 日志等级,可选,默认为INFO,DEBUG/INFO/ERROR |
| RUN_MODE | 运行模式,可选,默认release,为debug将自动添加跨域 |
| DB_TYPE | 数据库类型,sqlite/mysql。默认为sqlite,存储路径为conf/database.db |
| MYSQL_HOST | mysql-host,DB_TYPE=mysql必填 |
| MYSQL_PORT | mysql端口,DB_TYPE=mysql必填 |
| MYSQL_USER | mysql用户名,DB_TYPE=mysql必填 |
| MYSQL_PASSWORD | mysql数据库密码,DB_TYPE=mysql必填 |
| MYSQL_DB | mysql数据库名字,DB_TYPE=mysql必填 |
| MYSQL_TABLE_PREFIX | mysql数据表前缀,DB_TYPE=mysql必填 |
| SSL | 是否开启SSL |
| SQL_DEBUG | 是否打印SQL,可选,默认关,设置enable为开启 |
使用 MySQL
bash
# 正式运行(GHCR 镜像,推荐)
docker run -d \
-p 8000:8000 \
-e MYSQL_HOST=192.168.64.133 \
-e MYSQL_PORT=3308 \
-e MYSQL_USER=root \
-e MYSQL_PASSWORD=Aa123456 \
-e MYSQL_DB=test_11 \
-e MYSQL_TABLE_PREFIX=message_ \
--name message-nest \
ghcr.io/engigu/message-nest:latest
# 或使用 Docker Hub 镜像
docker run -d \
-p 8000:8000 \
-e MYSQL_HOST=192.168.64.133 \
-e MYSQL_PORT=3308 \
-e MYSQL_USER=root \
-e MYSQL_PASSWORD=Aa123456 \
-e MYSQL_DB=test_11 \
-e MYSQL_TABLE_PREFIX=message_ \
--name message-nest \
engigu/message-nest:latest使用 SQLite
bash
# 正式运行(GHCR 镜像,推荐)
docker run -d \
-p 8000:8000 \
-v /your/path/database.db:/app/conf/database.db \
--name message-nest \
ghcr.io/engigu/message-nest:latest
# 或使用 Docker Hub 镜像
docker run -d \
-p 8000:8000 \
-v /your/path/database.db:/app/conf/database.db \
--name message-nest \
engigu/message-nest:latest访问服务
启动后访问 http://localhost:8000
- 默认账号:
admin - 默认密码:
123456
常见问题
容器无法启动
- 检查端口是否被占用
- 检查数据库连接配置
- 查看容器日志:
docker logs message-nest
数据持久化
使用SQLite时,记得挂载数据库文件:
bash
-v /your/path/database.db:/app/conf/database.db查看日志
bash
# 查看实时日志
docker logs -f message-nest
# 查看最近100行日志
docker logs --tail 100 message-nest停止和删除容器
bash
# 停止容器
docker stop message-nest
# 删除容器
docker rm message-nest