使用 Docker 部署
Hollo 在 GitHub Packages 上提供了官方的 Docker 镜像。您可以使用这些镜像在您的服务器或本地机器上部署 Hollo:
docker pull ghcr.io/fedify-dev/hollo:latest
要运行 Hollo,您需要设置一个 PostgreSQL 数据库和一个用于媒体存储的 S3 兼容对象存储。您可以使用 PostgreSQL 的官方 Docker 镜像,也可以使用 MinIO 作为 S3 兼容对象存储。或者,您也可以使用其他托管服务,如 AWS 的 RDS、ElastiCache 和 S3。
要将 Hollo 连接到这些服务,您需要通过 docker run
命令的 -e
/--env
选项或 --env-file
选项 设置环境变量。要查看 Hollo 支持的环境变量,请参阅 环境变量 章节。
Docker Compose
要连接这些服务,您可以使用 Docker Compose。以下是一个示例 compose.yaml 文件:
services: hollo: image: ghcr.io/fedify-dev/hollo:canary ports: - "3000:3000" environment: DATABASE_URL: "postgres://user:password@postgres:5432/database" SECRET_KEY: "${SECRET_KEY}" LOG_LEVEL: "${LOG_LEVEL}" BEHIND_PROXY: "${BEHIND_PROXY}" DRIVE_DISK: s3 ASSET_URL_BASE: http://localhost:9000/hollo/ S3_REGION: us-east-1 S3_BUCKET: hollo S3_ENDPOINT_URL: http://minio:9000 S3_FORCE_PATH_STYLE: "true" AWS_ACCESS_KEY_ID: minioadmin AWS_SECRET_ACCESS_KEY: minioadmin depends_on: - postgres - minio - create-bucket restart: unless-stopped
postgres: image: postgres:17 environment: POSTGRES_USER: user POSTGRES_PASSWORD: password POSTGRES_DB: database volumes: - postgres_data:/var/lib/postgresql/data restart: unless-stopped
minio: image: minio/minio:RELEASE.2024-09-13T20-26-02Z ports: - "9000:9000" environment: MINIO_ROOT_USER: minioadmin MINIO_ROOT_PASSWORD: minioadmin volumes: - minio_data:/data command: ["server", "/data", "--console-address", ":9001"]
create-bucket: image: minio/mc:RELEASE.2024-09-16T17-43-14Z depends_on: - minio entrypoint: | /bin/sh -c " /usr/bin/mc alias set minio http://minio:9000 minioadmin minioadmin; /usr/bin/mc mb minio/hollo; /usr/bin/mc anonymous set public minio/hollo; exit 0; "
volumes: postgres_data: minio_data:
将此文件保存为 compose.yaml 到您的工作目录中,然后运行以下命令:
docker compose up -d