以docker-compose方式部署halo

1. 安装****docker

curl -fsSL https://get.docker.com | bash -s docker --mirror Aliyun

安装完成后,使用以下命令启动docker

systemctl start docker

接下来,使用以下命令将docker设置为开机自启;并重启服务使得更改生效

systemctl enable docker
systemctl reboot

可以通过一下命令来验证docker服务是否已设置为开机自启

systemctl is-enabled docker

2. 运行以下命令以下载 最新版Docker-Compose

curl -SL https://github.com/docker/compose/releases/download/v2.23.3/docker-compose-linux-x86_64 -o /usr/local/bin/docker-compose

将可执行权限应用于二进制文件:

 chmod +x /usr/local/bin/docker-compose

以下是docker-compose的一些常用命令
在后台自动容器,并且不会将日志输出到命令行

docker-compose up -d

如果需要查看容器日志,可以使用以下命令

docker-compose logs -f

列出项目中目前所有的容器

docker-compose ps

停止正在运行的容器

docker-compose stop

docker-compose stop [options] [SERVICE...] 选项包括: -t, –timeout TIMEOUT 停止容器时候的超时(默认为10秒)
启动已存在的服务容器

docker-compose start

更多常用命令可参考:https://juejin.cn/post/7051057669896929288

3. 通过docker-compose部署halo

内容引自halo官方文档:https://docs.halo.run/getting-started/install/docker-compose

在系统任意位置创建一个文件夹,此文档以 ~/halo 为例。

mkdir ~/halo && cd ~/halo

创建 Halo + PostgreSQL 的实例:

version: "3"

services:
  halo:
    image: halohub/halo:2.11
    container_name: halo
    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
    container_name: halodb
    restart: on-failure:3
    networks:
      halo_network:
    volumes:
      - ./db:/var/lib/postgresql/data
    ports:
      - "5432:5432"
    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 的实例:

version: "3"

services:
  halo:
    image: halohub/halo:2.11
    container_name: halo
    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
    container_name: halodb
    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
    ports:
      - "3306:3306"
    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:

启动 Halo 服务

docker-compose up -d

实时查看日志:

docker-compose logs -f

用浏览器访问 /console 即可进入 Halo 管理页面,首次启动会进入初始化页面。
更新容器组
修改 docker-compose.yaml 中配置的镜像版本。

services:
  halo:
    image: halohub/halo:2.11
    container_name: halo

重新启动halo服务

docker-compose up -d

4. 使用Nginx Proxy Manager进行反向代理

首先,我们创建一个文件夹来存放 NPM 的 docker-compose.yml 文件:

mkdir -p ~/data/docker_data/nginxproxymanager   # 创建一个 npm 的文件夹
cd ~/data/docker_data/nginxproxymanager    # 进入该文件夹
vi docker-compose.yml

Nginx Proxy Manager

version: '3'
services:
  app:
    image: 'jc21/nginx-proxy-manager:latest'
    restart: unless-stopped
    ports:
      - '80:80'              # 不建议修改端口
      - '81:81'              # 可以把冒号左边的 81 端口修改成你服务器上没有被占用的端口
      - '443:443'            # 不建议修改端口
    volumes:
      - ./data:/data         # 点号表示当前文件夹,冒号左边的意思是在当前文件夹下创建一个 data 目录,用于存放数据,如果不存在的话,会自动创建
      - ./letsencrypt:/etc/letsencrypt  # 点号表示当前文件夹,冒号左边的意思是在当前文件夹下创建一个 letsencrypt 目录,用于存放证书,如果不存在的话,会自动创建

启动npm

docker-compose up -d     # -d 表示后台运行
docker compose up -d     # 如果你用的是 docker-compose-plugin 的话,用这条命令

使用 docker-compose up -d 之后,访问浏览器 IP:81 端口。
默认的用户名和密码:
​ ● admin@example.com
​ ● changeme
后续在Nginx Proxy Manager设置代理的流程详见原文档
https://docs.halo.run/getting-started/install/other/nginxproxymanager/

posted @ 2024-05-11 13:44  lsblk0402  阅读(189)  评论(0编辑  收藏  举报