一、拉取镜像
首先确保有docker
# 拉取镜像
docker pull halohub/halo:2.7.0
# 查看镜像
docker images
二、创建本地挂载目录
mkdir /usr/local/halo && cd /usr/local/halo
三、运行docker容器
docker run \
-it -d \
--name halo \
-p 9523:8090 \
-v /usr/local/halo:/root/.halo2 \
halohub/halo:2.7 \
--halo.external-url=http://localhost:9523/ \
--halo.security.initializer.superadminusername=admi \
--halo.security.initializer.superadminpassword=123456..
#查看镜像是否在运行
docker ps -a
下面对每个参数进行解释:
docker run: 运行一个新的容器。
-it: 以交互模式运行容器,并分配一个伪终端。
-d: 在后台(守护进程)运行容器。
--name halo: 将容器命名为"halo"。
-p 9523:8090: 将主机的9523端口映射到容器的8090端口。这使得可以通过 http://localhost:9523/ 在本地访问Halo博客平台。
-v /usr/local/halo:/root/.halo2: 将主机的 /usr/local/halo 目录挂载到容器内的 /root/.halo2 目录。这样做是为了持久化保存Halo配置和数据。
halohub/halo:2.7: 使用halohub/halo镜像的2.7版本作为基础镜像来运行容器。这是Halo博客平台的镜像。
--halo.external-url=http://localhost:9523/: 设置Halo的外部URL为http://localhost:9523/。
--halo.security.initializer.superadminusername=admin: 设置Halo的超级管理员用户名为"admi"(注意这里的用户名不能有大写字符)
--halo.security.initializer.superadminpassword=123456: 设置Halo的超级管理员密码为"123456"。
这个命令的目的是在Docker容器中运行Halo博客平台,并配置一些参数,如外部URL、超级管理员用户名和密码等。通过映射端口和挂载卷,可以访问Halo博客平台并持久化保存配置和数据。
请注意,命令中的参数和值根据您的需求进行适当修改。此处提供的只是一个示例。希望这解释了上述命令。如果您有任何进一步的问题,请随时提问。
四、开放端口
#查看已打开的端口
firewall-cmd --list-ports
#查看防火墙规则
firewall-cmd --list-all
# 查询端口是否开放
firewall-cmd --query-port=8080/tcp
# 开放80端口
firewall-cmd --permanent --add-port=80/tcp
# 移除端口
firewall-cmd --permanent --remove-port=8080/tcp
#重启防火墙(修改配置后要重启防火墙)
firewall-cmd --reload
五、开放端口后就能正常访问ip+端口
首先进入后台设置页面
配置完后就可以访问博客主页了