概要
使用docker-compose发布halo,并使用现有mysql数据库
docker-compose安装
docker-compose.yaml代码
services:
halo:
image: registry.fit2cloud.com/halo/halo:2.20 # 安装默认的halo的image镜像
restart: on-failure:3
networks:
- ruoyi_net # 我有一个名为 ruoyi_net 网络组,mysql,nginx都分配在这个网络段中
volumes:
- ./halo2:/root/.halo2
ports:
- "8090:8090" # halo博客部署端口
healthcheck:
test: ["CMD", "curl", "-f", "http://localhost:8090/actuator/health/readiness"]
interval: 30s
timeout: 5s
retries: 5
start_period: 30s
environment:
# JVM 参数,默认为 -Xmx256m -Xms256m,可以根据实际情况做调整,置空表示不添加 JVM 参数
- JVM_OPTS=-Xmx256m -Xms256m
command:
- --spring.r2dbc.url=r2dbc:pool:mysql://docker-mysql:3306/halo # 我的mysql镜像名为docker-mysql
- --spring.r2dbc.username=root
# MySQL 的密码,请保证与下方 MYSQL_ROOT_PASSWORD 的变量值一致。
- --spring.r2dbc.password=o#DwN&JSa56 # mysql密码
- --spring.sql.init.platform=mysql
# 外部访问地址,请根据实际需要修改
- --halo.external-url=http://localhost:8090/
networks:
ruoyi_net:
external: true # 表示这是一个外部已存在的网络
启动docker-compose
在docker-compose.yaml当前文件路径下加载.yaml配置
docker-compose up -d