Halo博客+Traefik网关部署配置
title: 与 Traefik 配合使用 description: 使用 Traefik 管理 Halo 服务的反向代理
Halo 部署
:::info
「反向代理」
部分不进行操作,保证 Halo 服务运行无误即可。
:::
简介
Traefik 是一款开源的反向代理与负载均衡工具,它监听后端的变化并自动更新服务配置。 而且能够实现Let's Encrypt证书的自动签发、验证与续期。
创建Traefik
下面的配置中,创建了Traefik实例。并且做了基础的几项配置:
- 监听了宿主机的80、443端口,并自动将80端口的请求重定向到443端口。文档
- 开启Docker服务发现,监听检测docker容器声明的服务关系。文档
- 开启dashboard,dashboard域名建议使用二级域名的形式(示例:traefik.yourdomain.com)。文档
- 开启证书自动生成,通过ACME自动管理TLS证书的申请、校验与续期。文档
:::caution
ACME证书(/acme.json
)一定要持久化,否则每次重启traefik都会去申请签发证书。可能会触发Let's
Encrypt的速率限制
,导致一段时间内无法签发新的证书。
:::
version: "3.8"
networks:
traefik:
name: traefik
attachable: true
services:
traefik:
image: traefik:v2.9
container_name: traefik
networks:
- traefik
ports:
- "80:80"
- "443:443"
volumes:
- /var/run/docker.sock:/var/run/docker.sock
- ./acme.json:/acme.json
command: >
--api.dashboard=true
--entrypoints.web.address=:80
--entrypoints.websecure.address=:443
--entrypoints.web.http.redirections.entrypoint.to=websecure
--entrypoints.web.http.redirections.entrypoint.scheme=https
--providers.docker=true
--providers.docker.endpoint=unix:///var/run/docker.sock
--providers.docker.watch=true
--providers.docker.exposedByDefault=false
--certificatesResolvers.myresolver.acme.httpChallenge.entryPoint=web
--certificatesresolvers.myresolver.acme.email=your-mail@mail.com
labels:
traefik.enable: "true"
traefik.docker.network: traefik
traefik.http.routers.dashboard.rule: Host(`traefik.yourdomain.com`)
traefik.http.routers.dashboard.tls: "true"
traefik.http.routers.dashboard.tls.certresolver: myresolver
traefik.http.routers.dashboard.service: "api@internal"
traefik.http.routers.dashboard.middlewares: auth
# 账号密码admin/P@88w0rd 生成 echo $(htpasswd -nb user password) | sed -e s/\\$/\\$\\$/g
traefik.http.middlewares.auth.basicauth.users: "admin:$$apr1$$q8q0qpzT$$lvzMP7VYd9EUcG/wkIsAN."
声明服务
这里以最简配置(h2数据库)halo服务的Docker配置举例。只需做以下调整:
- 顶层networks中加入了
traefik
,和service>halo>networks中添加了traefik网络 - 添加了供traefik识别路由配置用到的labels
- 开启tls,指定了服务端口为8090
version: "3.8"
networks:
traefik:
external: true
halo:
services:
halo:
image: halohub/halo:2.1.0
container_name: halo
restart: on-failure:3
volumes:
- ./:/root/.halo2
networks:
- traefik
- halo
command:
# 外部访问地址,请根据实际需要修改
- --halo.external-url=https://yourdomain.com
# 初始化的超级管理员用户名
- --halo.security.initializer.superadminusername=admin
# 初始化的超级管理员密码
- --halo.security.initializer.superadminpassword=P@88w0rd
labels:
traefik.enable: "true"
traefik.docker.network: traefik
traefik.http.routers.halo.rule: Host(`yourdomain.com`)
traefik.http.routers.halo.tls: "true"
traefik.http.routers.halo.tls.certresolver: myresolver
traefik.http.services.halo.loadbalancer.server.port: 8090
本文链接:
/2023/1674903886993
版权声明:
本站所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自
if(xyz!=null)!
喜欢就支持一下吧
打赏
微信
支付宝