Centos/宝塔利用docker Compose快速安装Halo博客程序

Centos/宝塔利用docker  Compose快速安装Halo博客程序-技术经验分享-星泽V社

关于Halo

Halo 是一款强大易用的开源建站工具,它让你无需太多的技术知识就可以快速搭建一个博客、网站或者内容管理系统。具备可插拔架构、主题套用、富文本编辑器等多重特性,支持用户根据自己的喜好选择不同类型的插件及主题模板来定制化自己的站点功能及外观。让内容创作和发布更加便捷生动。

Centos/宝塔利用docker  Compose快速安装Halo博客程序-技术经验分享-星泽V社

有关halo的详细介绍请查看官网:Halo – 强大易用的开源建站工具

官方文档:安装指南 | Halo 文档

宝塔Docker搭建教程

在宝塔面板-应用商店/侧边栏docker组件中安装docker

Centos/宝塔利用docker  Compose快速安装Halo博客程序-技术经验分享-星泽V社

创建容器

1.在系统任意位置创建一个文件夹,以 opt/project/halo 为例。这里我习惯用代码,可以在宝塔面板文件管理出自行创建。

//进入文件夹
cd /opt/project/

//创建halo文件夹
mkdir halo
Centos/宝塔利用docker  Compose快速安装Halo博客程序-技术经验分享-星泽V社

2.创建docker-compose.yaml 文件

Centos/宝塔利用docker  Compose快速安装Halo博客程序-技术经验分享-星泽V社

这里我使用 Halo + MySQL 的实例,编辑docker-compose.yaml文件,修改相关信息后保存

version: "3"

services:
  halo:
    image: halohub/halo:2.13
    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:
Centos/宝塔利用docker  Compose快速安装Halo博客程序-技术经验分享-星泽V社

启动 Halo 服务

先进入刚刚创建的halo文件夹,然后执行启动halo服务,等待拉取镜像

//进入halo文件夹
cd ./halo/

//启动 Halo 服务
docker-compose up -d

//实时查看日志:
docker-compose logs -f
Centos/宝塔利用docker  Compose快速安装Halo博客程序-技术经验分享-星泽V社

创建完成后在宝塔docker面板容器中就会出现两个容器:halohalodb;mysql

Centos/宝塔利用docker  Compose快速安装Halo博客程序-技术经验分享-星泽V社

创建完成后在服务器和宝塔面板放开8090端口

用浏览器访问 ip:8090/console 即可进入 Halo 管理页面,首次启动会进入初始化页面。

Centos/宝塔利用docker  Compose快速安装Halo博客程序-技术经验分享-星泽V社
Centos/宝塔利用docker  Compose快速安装Halo博客程序-技术经验分享-星泽V社

配置域名

Centos/宝塔利用docker  Compose快速安装Halo博客程序-技术经验分享-星泽V社

创建一个纯静态网站,设置反向代理

Centos/宝塔利用docker  Compose快速安装Halo博客程序-技术经验分享-星泽V社

也可以使用Nginx

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;
  }
}

这样就结束了,后面可以装一些插件,主题。

温馨提示: 本文最后更新于2024-03-09 17:03:27,某些文章具有时效性,若有错误或已失效,请在下方 留言或联系 站长
© 版权声明
THE END
喜欢就支持一下吧
点赞6 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容