1.搭建环境
系统:Debian 10
域名一枚,并做好解析到服务器上
安装好Docker、Docker-compose
安装好Nginx Proxy Manager
2.搭建方式
2.1 搭建
sudo -i # 切换到root用户
apt update -y # 升级packages
apt install wget curl sudo vim git # Debian系统比较干净,安装常用的软件
2.1.1 使用 Docker 镜像
Halo 在 Docker Hub 上发布的镜像为 halohub/halo
1)创建工作目录
mkdir ~/.halo && cd ~/.halo
2)下载示例配置文件到 工作目录
wget https://dl.halo.run/config/application-template.yaml -O ./application.yaml
3)编辑配置文件,配置数据库或者端口等,如需配置请参考 配置参考
vim application.yaml
4)拉取最新的 Halo 镜像
docker pull halohub/halo:latest
查看最新版本镜像:https://hub.docker.com/r/halohub/halo
5)创建容器
docker run -it -d --name halo -p 8090:8090 -v ~/.halo:/root/.halo --restart=unless-stopped halohub/halo
注意:此命令默认使用自带的 H2 Database 数据库。如需使用 MySQL,请参考:使用 Docker 部署 Halo 和 MySQL
-it: 开启输入功能并连接伪终端
-d: 后台运行容器
–name: 为容器指定一个名称
-p: 端口映射,格式为 主机(宿主)端口:容器端口 ,可在 application.yaml 配置。
-v: 工作目录映射。形式为:-v 宿主机路径:/root/.halo,后者不能修改。
–restart: 建议设置为 unless-stopped,在 Docker 启动的时候自动启动 Halo 容器。
6)打开 http://ip:端口号 即可看到安装引导界面。
如果需要配置域名访问,建议先配置好反向代理以及域名解析再进行初始化。如果通过 http://ip:端口号 的形式无法访问,请到服务器厂商后台将运行的端口号添加到安全组,如果服务器使用了 Linux 面板,请检查此 Linux 面板是否有还有安全组配置,需要同样将端口号添加到安全组。
注意:如果VPS的内存比较小 ,推荐设置一下SWAP,一般为内存的1-1.5倍即可~
设置SWAP可以用脚本:
wget -O box.sh https://raw.githubusercontent.com/BlueSkyXN/SKY-BOX/main/box.sh && chmod +x box.sh && clear && ./box.sh
查看端口是否被占用,输入:
lsof -i:8090 #查看8090端口是否被占用,如果被占用,重新自定义一个端口
如果出现:
-bash: lsof: command not found
运行:
apt install lsof #安装lsof
如果端口被占用,可以换一个端口运行。
访问:http:服务ip:8090 即可。
注意:
1、不知道服务器IP,可以直接在命令行输入:curl ip.sb,会显示当前服务器的IP。
2、遇到访问不了的情况,请在宝塔面板的防火墙和服务商的后台防火墙里打开对应端口。
2.2 更新
我们假设您的容器是按照 使用 Docker 部署 Halo 中的命令构建的。如有不同,请根据实际情况修改。
2.2.1停止并删除当前运行中的容器
docker stop halo
docker rm -f halo
你的容器名称不一定为 halo,在执行前可以先执行 docker ps -a 查看一下。
2.2.2备份数据**(重要)**
cp -r ~/.halo ~/.halo.archive
需要注意的是,.halo.archive 文件名不一定要根据此文档命名,这里仅仅是个示例。
2.2.3清空 leveldb 缓存(如果有使用 leveldb 作为缓存策略)
rm -rf ~/.halo/.leveldb
2.2.4拉取最新的 Halo 镜像
docker pull halohub/halo:1.5.2
查看最新版本镜像:https://hub.docker.com/r/halohub/halo ,我们推荐使用具体版本号的镜像,但也提供了 latest 标签的镜像,它始终是最新的。
2.2.5创建容器
docker run -it -d --name halo -p 8090:8090 -v ~/.halo:/root/.halo --restart=unless-stopped halohub/halo:1.5.2
-it: 开启输入功能并连接伪终端
-d: 后台运行容器
–name: 为容器指定一个名称
-p: 端口映射,格式为 主机(宿主)端口:容器端口 ,可在 application.yaml 配置。
-v: 工作目录映射。形式为:-v 宿主机路径:/root/.halo,后者不能修改。
–restart: 建议设置为 unless-stopped,在 Docker 启动的时候自动启动 Halo 容器。
2.3 卸载
sudo -i # 切换到root
docker stop halo
docker rm -f halo
rm -rf ~/.halo # 完全删除映射到本地的数据
利用Docker搭建的应用,删除也非常容易~
3.反向代理(必须)
3.1 利用Nginx Proxy Manager
在添加反向代理之前,确保你已经完成了域名解析
之后,登陆Nginx Proxy Manager
直接丢几张图:
注意填写对应的 域名、IP和端口,按文章来的话,应该是8090
IP填写:
如果Nginx Proxy Manager和reader在同一台服务器上,可以在终端输入:
ip addr show docker0
查看对应的Docker容器内部IP。
否则直接填docker所在的服务器IP就行。
完成之后,记得再次打开这个,把Force SSL再勾选上(小BUG)
然后就可以用域名来安装访问了。
评论区