前置步驟
首先你需要一套linux服務器,這裏默認你已經有了。如果沒有可以在雲服務器優惠合集選擇,如果你是個人博客選擇性價比最高,最低配置就夠用了。
環境搭建
按照Docker官方文檔安裝Docker和Docker Compose,部分Linux發行版軟件倉庫中的 Docker版本可能過舊。
- Docker 安裝文檔:https://docs.docker.com/engine/install/
- Docker Compose 安裝文檔:https://docs.docker.com/compose/install/
創建容器組
下面是Halo官方維護的Docker鏡像倉庫,根據自己的需求選擇合適的鏡像源:
- registry.fit2cloud.com/halo/halo
- halohub/halo
- ghcr.io/halo-dev/halo
Halo 2有時候沒有及時的更新Docker的latest標籤鏡像,因為Halo 2不兼容1.x版本,防止使用者誤操作。推薦使用固定版本的標籤,比如2.17或者2.17.0。
在系統任意位置創建一個文件夾
此文檔以 ~/halo為例,後續操作中,Halo 產生的所有數據都會保存在這個目錄。
mkdir ~/halo && cd ~/halo
創建docker-compose.yaml
halo 2默認使用H2數據庫,這個主要用於方便開發測試,不推薦在生產使用。因為操作不當可能導致數據文件損壞。如果因為某些原因(如內存不足以運行獨立數據庫)必須要使用,建議按時備份數據。
docker-compose.yaml文件路徑一般放在下面這個路徑。
~/halo/docker-compose.yaml
下面給出幾種docker-compose.yaml實例的配置。
- 創建 Halo + PostgreSQL 的實例:
這裏的PostgreSQL使用默認端口5432,如果需要改端口,要顯性標註出來。
version: "3"
services:
halo:
image: registry.fit2cloud.com/halo/halo:2.17
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
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=halo
networks:
halo_network:
- 創建 Halo + MySQL 的實例:
這裏的PostgreSQL使用默認端口3306,如果需要改端口,要顯性標註出來。
version: "3"
services:
halo:
image: registry.fit2cloud.com/halo/halo:2.17
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
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=halo
networks:
halo_network:
- 使用默認的 H2 數據庫
version: "3"
services:
halo:
image: registry.fit2cloud.com/halo/halo:2.17
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
command:
# 外部訪問地址,請根據實際需要修改
- --halo.external-url=http://localhost:8090/
- 僅創建 Halo 實例(使用已有外部數據庫,MySQL 為例)
version: "3"
services:
halo:
image: registry.fit2cloud.com/halo/halo:2.17
restart: on-failure:3
network_mode: "host"
volumes:
- ./halo2:/root/.halo2
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
參數配置
| 參數名 | 描述 |
|---|---|
spring.r2dbc.url |
數據庫連接地址,詳細可查閲下方的 數據庫配置 |
spring.r2dbc.username |
數據庫用户名 |
spring.r2dbc.password |
數據庫密碼 |
spring.sql.init.platform |
數據庫平台名稱,支持 postgresql、mysql、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
配置反向代理以及域名解析
這裏以Nginx為例子,halo2還支持Caddy 2、Traefik等。
- 通過nginx.conf文配置
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;
}
}
- 通過Nginx Proxy Manager配置
參考使用Nginx Proxy Manager配置Halo的反向代理和申請 SSL 證書
Halo初始化頁面。
用瀏覽器訪問 /console 即可進入 Halo 管理頁面,首次啓動會進入初始化頁面。
更新新版本的halo
從 Halo 2.8 開始,Halo 內置了備份和恢復的功能,可以在 Console 中一鍵備份和恢復完整的數據。
- 備份
在 Console 中,點擊左側菜單的 備份,進入備份頁面。點擊右上角的 創建備份 按鈕,即可創建一個新的備份請求,需要注意的是,創建備份請求並不會立即開始備份,而是會在後台異步執行,因此需要等待一段時間才能看到備份的結果。 -
更新Halo服務
修改 docker-compose.yaml 中配置的鏡像版本。services: halo: image: registry.fit2cloud.com/halo/halo:2.17docker-compose up -d -
恢復備份
- 在 Console 中,點擊左側菜單的 備份,進入備份頁面,然後點擊 恢復 選項卡即可進入恢復界面,閲讀完注意事項之後點擊 開始恢復 按鈕即可顯示備份文件上傳界面。
- 選擇備份文件後,點擊 上傳 按鈕即可開始上傳備份文件,上傳完成後會自動開始恢復。
- 恢復完成,會提示重啓 Halo,點擊 確定 按鈕即可重啓 Halo。
- 最後,建議去服務器檢查 Halo 的運行狀態,如果沒有設置自動重啓,需要手動重啓。
原文鏈接:如何在Linux雲服務器上通過Docker Compose部署安裝Halo,搭建個人博客網站?