動態

詳情 返回 返回

如何在Linux雲服務器上通過Docker Compose部署安裝Halo,搭建個人博客網站? - 動態 詳情

前置步驟

首先你需要一套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實例的配置。

  1. 創建 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:
  1. 創建 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:
  1. 使用默認的 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/
  1. 僅創建 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 中一鍵備份和恢復完整的數據。

  1. 備份
    在 Console 中,點擊左側菜單的 備份,進入備份頁面。點擊右上角的 創建備份 按鈕,即可創建一個新的備份請求,需要注意的是,創建備份請求並不會立即開始備份,而是會在後台異步執行,因此需要等待一段時間才能看到備份的結果。
  2. 更新Halo服務
    修改 docker-compose.yaml 中配置的鏡像版本。

    services:
      halo:
     image: registry.fit2cloud.com/halo/halo:2.17
    docker-compose up -d
  3. 恢復備份

    • 在 Console 中,點擊左側菜單的 備份,進入備份頁面,然後點擊 恢復 選項卡即可進入恢復界面,閲讀完注意事項之後點擊 開始恢復 按鈕即可顯示備份文件上傳界面。
    • 選擇備份文件後,點擊 上傳 按鈕即可開始上傳備份文件,上傳完成後會自動開始恢復。
    • 恢復完成,會提示重啓 Halo,點擊 確定 按鈕即可重啓 Halo。
    • 最後,建議去服務器檢查 Halo 的運行狀態,如果沒有設置自動重啓,需要手動重啓。

原文鏈接:如何在Linux雲服務器上通過Docker Compose部署安裝Halo,搭建個人博客網站?

Add a new 評論

Some HTML is okay.