Halo是一款强大的开源建站工具,提供丰富的模板和插件,支持根据不同需求定制外观和功能,最大亮点就是建站速度飞快。Halo建站工具目前支持使用Docker、1Panel、Helm和Podman等方式部署。关于Halo建站工具的安装流程,下文将由站长百科详细介绍。
一、Halo建站工具价格
安装Halo建站工具之前首先需要确定所需版本,如果仅用于内容管理、邮箱验证、备份等用途,选择其免费版基本够用;但是如果需要移动端、AI建站以及更多自定义支持外,则需要升级至Halo专业版。Halo建站工具专业版目前推出按月、按年和买断版。要对比价格的话肯定是买断划算,如果只是想先体验推荐先试试短期专业版。
通过本链接购买Halo专业版按年/买断可享8.8折优惠,买断3个及以上8折!
Halo建站工具专属优惠链接:点击直达
二、创建容器组
目前Halo官方维护的Docker镜像仓库,可以根据自己的需求选择合适的镜像源:
- registry.fit2cloud.com/halo/halo
- halohub/halo
- ghcr.io/halo-dev/halo
注意:目前Halo 2并未更新Docker的latest 标签镜像,主要因为Halo 2不兼容1.x版本,防止使用者误操作。我们推荐使用固定版本的标签,比如2.21或者2.21.0。
- registry.fit2cloud.com/halo/halo:2:表示最新的2.x版本,即每次发布新版本都会更新此镜像;
- registry.fit2cloud.com/halo/halo:2.21:表示最新的2.21.x版本,即每次发布patch版本都会同时更新此镜像;
- registry.fit2cloud.com/halo/halo:2.21.0:表示一个具体的版本。
以下安装指引以egistry.fit2cloud.com/halo/halo:2.21为例:
1、在系统任意位置创建一个文件夹,此文档以~/halo为例。
mkdir ~/halo && cd ~/halo
注意:后续操作中,Halo产生的所有数据都会保存在这个目录,请妥善保存。
2、创建docker-compose.yaml
此文档提供几种场景的Docker Compose配置文件,请根据需要选择一种。
注意:为了更加方便的管理配置,所有与Halo相关的配置都使用Docker容器启动参数代替,所以无需创建application.yaml文件。
(1)Halo + PostgreSQL:
~/halo/docker-compose.yaml
version: “3”services:
halo:
image: registry.fit2cloud.com/halo/halo:2.21
restart: on-failure:3
depends_on:
halodb:
condition: service_healthy
networks:
halo_network:
volumes:
– ./halo2:/root/.halo2
ports:
– “8090:8090”
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:postgresql://halodb/halo
– –spring.r2dbc.username=halo
# PostgreSQL 的密码,请保证与下方 POSTGRES_PASSWORD 的变量值一致。
– –spring.r2dbc.password=openpostgresql
– –spring.sql.init.platform=postgresql
# 外部访问地址,请根据实际需要修改
– –halo.external-url=http://localhost:8090/
halodb:
image: postgres:15.4
restart: on-failure:3
networks:
halo_network:
volumes:
– ./db:/var/lib/postgresql/data
healthcheck:
test: [ “CMD”, “pg_isready” ]
interval: 10s
timeout: 5s
retries: 5
environment:
– POSTGRES_PASSWORD=openpostgresql
– POSTGRES_USER=halo
– POSTGRES_DB=halo
– PGUSER=halonetworks:
halo_network:
此示例的PostgreSQL数据库容器默认没有设置端口映射,如果需要在容器外部访问数据库,可以自行在halodb服务中添加端口映射,PostgreSQL的端口为5432。
(2)Halo + MySQL:
~/halo/docker-compose.yaml
version: “3”services:
halo:
image: registry.fit2cloud.com/halo/halo:2.21
restart: on-failure:3
depends_on:
halodb:
condition: service_healthy
networks:
halo_network:
volumes:
– ./halo2:/root/.halo2
ports:
– “8090:8090”
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://halodb:3306/halo
– –spring.r2dbc.username=root
# MySQL 的密码,请保证与下方 MYSQL_ROOT_PASSWORD 的变量值一致。
– –spring.r2dbc.password=o#DwN&JSa56
– –spring.sql.init.platform=mysql
# 外部访问地址,请根据实际需要修改
– –halo.external-url=http://localhost:8090/halodb:
image: mysql:8.1.0
restart: on-failure:3
networks:
halo_network:
command:
– –default-authentication-plugin=caching_sha2_password
– –character-set-server=utf8mb4
– –collation-server=utf8mb4_general_ci
– –explicit_defaults_for_timestamp=true
volumes:
– ./mysql:/var/lib/mysql
– ./mysqlBackup:/data/mysqlBackup
healthcheck:
test: [“CMD”, “mysqladmin”, “ping”, “-h”, “127.0.0.1”, “–silent”]
interval: 3s
retries: 5
start_period: 30s
environment:
# 请修改此密码,并对应修改上方 Halo 服务的 SPRING_R2DBC_PASSWORD 变量值
– MYSQL_ROOT_PASSWORD=o#DwN&JSa56
– MYSQL_DATABASE=halonetworks:
halo_network:
此示例的MySQL数据库容器默认没有设置端口映射,如果需要在容器外部访问数据库,可以自行在 halodb 服务中添加端口映射,MySQL的端口为3306。
(3)Halo + H2:
注意:不推荐在生产环境使用默认的H2数据库,这可能因为操作不当导致数据文件损坏。如果因为某些原因(如内存不足以运行独立数据库)必须要使用,建议按时备份数据。
~/halo/docker-compose.yaml
version: “3”services:
halo:
image: registry.fit2cloud.com/halo/halo:2.21
restart: on-failure:3
volumes:
– ./halo2:/root/.halo2
ports:
– “8090:8090”
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:
# 外部访问地址,请根据实际需要修改
– –halo.external-url=http://localhost:8090/(4)使用外部数据库:
~/halo/docker-compose.yaml
version: “3”services:
halo:
image: registry.fit2cloud.com/halo/halo:2.21
restart: on-failure:3
network_mode: “host”
volumes:
– ./halo2:/root/.halo2
environment:
# JVM 参数,默认为 -Xmx256m -Xms256m,可以根据实际情况做调整,置空表示不添加 JVM 参数
– JVM_OPTS=-Xmx256m -Xms256m
command:
# 修改为自己已有的 MySQL 配置
– –spring.r2dbc.url=r2dbc:pool:mysql://localhost:3306/halo
– –spring.r2dbc.username=root
– –spring.r2dbc.password=
– –spring.sql.init.platform=mysql
# 外部访问地址,请根据实际需要修改
– –halo.external-url=http://localhost:8090/
# 端口号 默认8090
– –server.port=8090
使用外部数据库时,需要提前手动创建好数据库,以MySQL为例:
create database halo character set utf8mb4 collate utf8mb4_bin;
运行参数详解:
- spring.r2dbc.url:数据库连接地址,详细可查阅下方的 数据库配置;
- spring.r2dbc.username:数据库用户名;
- spring.r2dbc.password:数据库密码;
- spring.sql.init.platform:数据库平台名称,支持 postgresql、mysql、mariadb、h2;
- halo.external-url:外部访问链接,如果需要在公网访问,需要配置为实际访问地址。
数据库配置:
| 链接方式 | 链接地址格式 | spring.sql.init.platform |
|---|---|---|
| PostgreSQL | r2dbc:pool:postgresql://{HOST}:{PORT}/{DATABASE} |
postgresql |
| MySQL | r2dbc:pool:mysql://{HOST}:{PORT}/{DATABASE} |
mysql |
| MariaDB | r2dbc:pool:mariadb://{HOST}:{PORT}/{DATABASE} |
mariadb |
| H2 Database | r2dbc:h2:file:///${halo.work-dir}/db/halo-next?MODE=MySQL&DB_CLOSE_ON_EXIT=FALSE |
h2 |
三、启动Halo服务
docker-compose up -d
实时查看日志:
docker-compose logs -f
用浏览器访问/console即可进入Halo管理页面,首次启动会进入初始化页面。
注意:如果需要配置域名访问,建议先配置好反向代理以及域名解析再进行初始化。如果通过 http://ip:端口号 的形式无法访问,请到服务器厂商后台将运行的端口号添加到安全组,如果服务器使用了Linux面板,请检查此Linux面板是否有还有安全组配置,需要同样将端口号添加到安全组。
四、更新容器组
1、备份数据。
2、更新Halo服务
修改docker-compose.yaml中配置的镜像版本。
services:
halo:
image: registry.fit2cloud.com/halo/halo:2.21docker-compose up -d
五、反向代理
可以在下面的反向代理软件中任选一项,我们假设你已经安装好了其中一项,并对其的基本操作有一定了解。
1、Nginx
upstream halo {
server 127.0.0.1:8090;
}
server {
listen 80;
listen [::]:80;
server_name www.yourdomain.com;
client_max_body_size 1024m;
location / {
proxy_pass http://halo;
proxy_set_header HOST $host;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}
2、Caddy 2
www.yourdomain.com
encode gzip
reverse_proxy 127.0.0.1:8090
3、Traefik
更新halo容器组的配置
networks 中引入已存在的网络 traefik(此网络需要提前创建);
services.halo.networks 中添加网络 traefik;
修改外部地址为你的域名;
声明路由规则、开启 TLS。
version: “3.8”
networks:
traefik:
external: true
halo:services:
halo:
image: registry.fit2cloud.com/halo/halo:2.21
restart: on-failure:3
volumes:
– ./halo2:/root/.halo2
networks:
– traefik
– halo
command:
# 外部访问地址,请根据实际需要修改
– –halo.external-url=https://yourdomain.com
labels:
traefik.enable: “true”
traefik.docker.network: traefik
traefik.http.routers.halo.rule: Host(`yourdomain.com`)
traefik.http.routers.halo.tls: “true”
traefik.http.routers.halo.tls.certresolver: myresolver
traefik.http.services.halo.loadbalancer.server.port: 8090
-
广告合作
-
QQ群号:4114653




