news 2026/6/23 1:55:06

Halo Docker 迁移方法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Halo Docker 迁移方法

Halo Docker 迁移方法

以下是针对使用Docker部署的Halo博客(假设Halo 2.x版本,数据库为默认H2或外部MySQL)迁移到新服务器的详细方案。迁移目标是实现全站数据迁移,包括文章、评论、附件、主题、插件、配置和数据库。方案基于Halo官方文档和社区经验,确保数据完整性。适用于CentOS或其他Linux服务器。

重要前提和注意事项
  • Halo版本确认:检查旧服务器Halo版本(后台 > 系统 > 关于,或查看~/.halo2/application.yaml)。新服务器使用相同版本的Docker镜像(例如halo.run/release/halo-2.x.x.jar,但Docker镜像通常为halohub/halo或ruibaby/halo)。
  • 数据库类型:默认H2(数据在/.halo2/db),或外部MySQL(需单独备份)。查看/.halo2/application.yaml确认。
  • Docker环境:旧/新服务器需安装Docker和Docker Compose(可选)。迁移核心是持久化卷(-v挂载的目录,如~/.halo2)。
  • 备份前停止容器docker stop halo以避免数据不一致。
  • 工具准备:scp/rsync用于传输;如果MySQL,需mysqldump。
  • 风险:传输大文件时使用rsync增量;迁移后验证数据(如文章数量、附件URL)。如果域名变化,需更新数据库中的URL。
  • 假设:新服务器干净,root权限;使用H2数据库。如果Halo 1.x,目录为~/.halo,步骤类似。
  • 时间估计:30-60分钟,取决于数据大小。
  • 最佳实践:先备份整个~/.halo2目录;测试迁移后更新DNS指向新IP。
迁移方案概述
  1. 备份旧服务器数据(文件和数据库)。
  2. 在新服务器安装Docker环境
  3. 传输和恢复数据
  4. 启动容器并验证
  5. 可选:配置Nginx/SSL和数据库URL更新

Halo官方推荐使用后台备份工具,但对于Docker,优先备份挂载卷(~/.halo2)。如果数据大,可直接打包整个卷目录。

详细操作步骤
步骤1: 备份旧服务器数据

在旧服务器上执行,确保容器停止。

  1. 停止Docker容器

    docker stop halo docker rm halo # 如果需要移除旧容器
  2. 使用Halo后台备份(推荐,包含配置/附件/主题/插件)

    • 启动容器临时访问后台:docker start halo
    • 登录Halo后台(IP:8090/admin)。
    • 导航到系统 > 备份
    • 点击“备份站点”,生成ZIP文件。
    • 下载ZIP到服务器(如/tmp/halo-backup.zip)。
    • 停止容器再次。
  3. 手动备份挂载卷(~/.halo2,整个数据目录)

    • 备份整个目录(包括db、indices、keys、logs、plugins、themes、upload等)。
    • 命令:
      cd ~ tar -czvf /tmp/halo-volume-backup.tar.gz .halo2
    • 这包含H2数据库。如果使用H2,无需额外备份数据库。
  4. 备份外部数据库(如果使用MySQL)

    • 确认数据库名(通常halo,查看application.yaml)。
    • 导出:
      mysqldump -u root -p halo > /tmp/halo.sql
      (替换用户/密码)。
  5. 备份Docker Compose文件(如果使用)

    • 复制docker-compose.yml/tmp/
  6. 验证备份:检查文件大小,确保完整。

步骤2: 在新服务器安装环境
  1. 安装Docker

    sudo yum update -y sudo yum install -y yum-utils device-mapper-persistent-data lvm2 sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo sudo yum install -y docker-ce docker-ce-cli containerd.io sudo systemctl start docker && sudo systemctl enable docker
  2. 拉取Halo镜像(使用与旧服务器相同版本):

    docker pull halohub/halo:2.x.x # 替换为实际版本,如2.12.2

    或使用ruibaby/halo如果旧服务器是这个。

  3. 安装数据库(如果用外部MySQL)

    sudo yum install -y mariadb-server sudo systemctl start mariadb && sudo systemctl enable mariadb sudo mysql_secure_installation
    • 创建数据库:
      mysql -u root -p CREATE DATABASE halo CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci; GRANT ALL ON halo.* TO 'halo_user'@'localhost' IDENTIFIED BY 'password'; FLUSH PRIVILEGES; EXIT;
步骤3: 传输和恢复数据
  1. 传输备份文件

    • 从旧服务器执行(推荐rsync):
      rsync -avz -e ssh /tmp/halo-volume-backup.tar.gz root@new_ip:/tmp/ rsync -avz -e ssh /tmp/halo.sql root@new_ip:/tmp/ # 如果有
      (替换new_ip)。
  2. 恢复卷数据

    • 在新服务器:
      mkdir -p ~/.halo2 tar -xzvf /tmp/halo-volume-backup.tar.gz -C ~
      • 或如果用后台ZIP:解压到~/.halo2。
    • 调整权限:
      chown -R root:root ~/.halo2 chmod -R 755 ~/.halo2
  3. 恢复数据库(如果MySQL)

    mysql -u root -p halo < /tmp/halo.sql
    • 更新~/.halo2/application.yaml中的数据库连接(如果主机变)。
步骤4: 启动并验证
  1. 运行Docker容器

    • 简单运行:
      docker run -d --name halo -p 8090:8090 -v ~/.halo2:/root/.halo2 --restart=always halohub/halo:2.x.x
      • 如果用Docker Compose,创建docker-compose.yml:
        version: '3' services: halo: image: halohub/halo:2.x.x container_name: halo restart: always volumes: - ~/.halo2:/root/.halo2 ports: - 8090:8090
        然后:docker-compose up -d
  2. 验证数据

    • 访问新IP:8090/admin,检查内容。
    • 查看日志:docker logs halo
    • 如果错误,检查卷挂载和权限。
  3. 更新数据库URL(如果域名变化)

    • 对于H2:使用h2-console访问数据库,运行SQL替换URL(例如REPLACE函数更新POSTS表的ORIGINAL_CONTENT等列)。
    • 对于MySQL:直接在mysql中运行类似SQL。
步骤5: 可选优化和清理
  • 配置Nginx反向代理:安装Nginx,配置server块代理到8090端口。
  • SSL:使用certbot。
  • 高可用:设置MySQL主从复制(主服务器配置log_bin,从服务器CHANGE MASTER)。
  • 镜像打包迁移(可选,如果频繁迁移):构建自定义Dockerfile包含备份,push到仓库,然后在新服务器pull运行。
  • 清理:迁移成功后删除旧备份。

如果使用Halo 1.x,替换目录为~/.halo,镜像为ruibaby/halo等。遇到问题,参考Halo社区(bbs.halo.run)或官方文档。如果数据库复杂,优先使用外部MySQL以便迁移。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/21 5:14:15

Qwen3-8B-AWQ性能优化与最佳实践

Qwen3-8B-AWQ性能优化与最佳实践 在当前大模型快速普及的背景下&#xff0c;如何在有限硬件条件下实现高效、稳定且高质量的语言推理&#xff0c;成为开发者面临的核心挑战。尤其对于中小企业、个人研究者和边缘部署场景而言&#xff0c;动辄百亿参数、需多卡并行的大模型显然不…

作者头像 李华
网站建设 2026/6/22 20:23:26

LLaMA-Factory 微调 DeepSeek-R1 模型实战指南

LLaMA-Factory 微调 DeepSeek-R1 模型实战指南 在大模型日益普及的今天&#xff0c;如何让一个通用语言模型真正“懂你”&#xff0c;成为个性化的智能助手&#xff1f;答案就是——微调。而对大多数开发者而言&#xff0c;传统微调流程复杂、门槛高、依赖多&#xff0c;常常望…

作者头像 李华
网站建设 2026/6/17 15:36:17

Langflow自定义组件开发与界面集成详解

Langflow自定义组件开发与界面集成详解 在构建现代 AI 应用时&#xff0c;我们常常面临一个核心矛盾&#xff1a;快速原型设计 vs. 深度定制能力。一方面&#xff0c;团队需要快速验证想法&#xff1b;另一方面&#xff0c;业务逻辑又往往复杂且独特。Langflow 正是在这一背景…

作者头像 李华
网站建设 2026/6/22 20:00:41

LobeChat能否协助撰写简历?求职者福音来了

LobeChat&#xff1a;当求职遇上AI助手&#xff0c;简历还能这样写&#xff1f; 在招聘旺季的深夜&#xff0c;你盯着电脑屏幕反复修改简历——已经删改了第七遍&#xff0c;却总觉得“哪里不够专业”。投出去十几份&#xff0c;回复寥寥无几。是不是关键词没对上&#xff1f;经…

作者头像 李华
网站建设 2026/6/21 2:15:15

使用Miniconda创建Python 3.8环境的完整步骤

使用 Miniconda 创建 Python 3.8 环境&#xff1a;从零开始的实践指南 在真实项目中&#xff0c;你有没有遇到过这样的情况&#xff1f;一个原本运行正常的机器学习脚本&#xff0c;在换了一台电脑或升级了某个库之后突然报错——可能是 numpy 不兼容&#xff0c;也可能是 ten…

作者头像 李华
网站建设 2026/6/22 12:50:44

搭建Ollama并运行qwen,简单RAG实现

1、wsl环境中安装ollamacurl -fsSL https://ollama.com/install.sh | sh2、启动ollama serve3、拉取模型# 拉取模型&#xff08;此过程会下载约4-5GB的数据&#xff09; ollama pull qwen2.5:7b # 推荐&#xff1a;中文能力强&#xff0c;综合性能优秀 # 或者ollama pull llam…

作者头像 李华