halo 安装
环境要求
- CentOS 7.x
- 512 MB 以上内存
服务器配置
更新软件包
sudo yum update -y
安装 Java 运行环境
# 安装 OpenJRE
sudo yum install java-1.8.0-openjdk -y
# 检测是否安装成功
java -version
创建用户
创建用户
useradd -m asaawan
给予 sudo 权限
usermod -aG wheel asaawan
创建密码
passwd asaawan
登录到 asaawan
su - asaawan
安装 Halo
下载配置文件
# 下载配置文件到 ~/.halo 目录
curl -o ~/.halo/application.yaml --create-dirs https://dl.halo.run/config/application-template.yaml
修改配置文件
# 使用 Vim 工具修改配置文件
vim ~/.halo/application.yaml
打开之后我们可以看到
server:
port: 8090
# Response data gzip.
compression:
enabled: false
spring:
datasource:
# H2 database configuration.
driver-class-name: org.h2.Driver
url: jdbc:h2:file:~/.halo/db/halo
username: admin
password: 123456
# MySQL database configuration.
# driver-class-name: com.mysql.cj.jdbc.Driver
# url: jdbc:mysql://127.0.0.1:3306/halodb?characterEncoding=utf8&useSSL=false&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true
# username: root
# password: 123456
# H2 database console configuration.
h2:
console:
settings:
web-allow-others: false
path: /h2-console
enabled: false
halo:
# Your admin client path is https://your-domain/{admin-path}
admin-path: admin
# memory or level
cache: memory
- 如果需要自定义端口,修改
server节点下的port即可。 - 默认使用的是
H2 Database数据库,这是一种嵌入式的数据库,使用起来非常方便。需要注意的是,默认的用户名和密码为admin和123456,这个是自定义的,最好将其修改,并妥善保存。 - 如果需要使用
MySQL数据库,需要将H2 Database的所有相关配置都注释掉,并取消MySQL的相关配置。另外,MySQL的默认数据库名为halodb,请自行配置MySQL并创建数据库,以及修改配置文件中的用户名和密码。 h2节点为H2 Database的控制台配置,默认是关闭的,如需使用请将h2.console.settings.web-allow-others和h2.console.enabled设置为true。控制台地址即为域名/h2-console。注意:非紧急情况,不建议开启该配置。server.compression.enabled为Gzip功能配置,如有需要请设置为true,需要注意的是,如果你使用Nginx或者Caddy进行反向代理的话,默认是有开启Gzip的,所以这里可以保持默认。halo.admin-path为后台管理的根路径,默认为admin,如果你害怕别人猜出来默认的admin(就算猜出来,对方什么都做不了),请自行设置。仅支持一级,且前后不带/。halo.cache为系统缓存形式的配置,可选memory和level,默认为memory,将数据缓存到内存,使用该方式的话,重启应用会导致缓存清空。如果选择level,则会将数据缓存到磁盘,重启不会清空缓存。如不知道如何选择,建议默认。
注意
使用 MySQL 之前,必须要先新建一个 halodb 数据库,MySQL 版本需 5.7 以上。
create database halodb character set utf8mb4 collate utf8mb4_bin;
运行 Halo
创建安装目录
mkdir ~/app && cd ~/app
下载运行包
wget https://dl.halo.run/release/halo-1.3.2.jar -O halo-latest.jar
启动测试
cd ~/app && java -jar halo-latest.jar
打开 http://ip:端口号 即可看到安装引导界面。
进阶配置
登录 root 用户
su root
下载 halo.service
sudo curl -o /etc/systemd/system/halo.service --create-dirs https://dl.halo.run/config/halo.service
修改 halo.service
sudo vim /etc/systemd/system/halo.service
打开之后我们可以看到
[Unit]
Description=Halo Service
Documentation=https://halo.run
After=network-online.target
Wants=network-online.target
[Service]
User=asaawan
Type=simple
ExecStart=/usr/bin/java -server -Xms256m -Xmx256m -jar /home/asaawan/app/halo-latest.jar
ExecStop=/bin/kill -s QUIT $MAINPID
Restart=always
StandOutput=syslog
StandError=inherit
[Install]
WantedBy=multi-user.target
参数:
- -Xms256m:为 JVM 启动时分配的内存,请按照服务器的内存做适当调整,512 M 内存的服务器推荐设置为 128,1G 内存的服务器推荐设置为 256,默认为 256。
- -Xmx256m:为 JVM 运行过程中分配的最大内存,配置同上。
- YOUR_JAR_PATH:Halo 安装包的绝对路径,例如
/home/halo/app/halo-latest.jar。 - USER:运行 Halo 的系统用户,如果有按照上方教程创建新的用户来运行 Halo,修改为你创建的用户名称即可。反之请删除
User=USER。
提示
- 如果你不是按照上面的方法安装的 JDK,请确保
/usr/bin/java是正确无误的。 - systemd 中的所有路径均要写为绝对路径,另外,
~在 systemd 中也是无法被识别的,所以你不能写成类似~/halo-latest.jar这种路径。 - 如何检验是否修改正确:把 ExecStart 中的命令拿出来执行一遍。
halo 服务命令
# 修改 service 文件之后需要刷新 Systemd
sudo systemctl daemon-reload
# 使 Halo 开机自启
sudo systemctl enable halo
# 启动 Halo
sudo service halo start
# 重启 Halo
sudo service halo restart
# 停止 Halo
sudo service halo stop
# 查看 Halo 的运行状态
sudo service halo status
Nginx 反向代理
安装 Nginx
# 添加 Nginx 源
sudo rpm -Uvh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm
# 安装 Nginx
sudo yum install -y nginx
# 启动 Nginx
sudo systemctl start nginx.service
# 设置开机自启 Nginx
sudo systemctl enable nginx.service
配置 Nginx
# 下载 Halo 官方的 Nginx 配置模板
curl -o /etc/nginx/conf.d/halo.conf --create-dirs https://dl.halo.run/config/nginx.conf
下载完成之后,我们还需要对其进行修改
# 使用 vim 编辑 halo.conf
vim /etc/nginx/conf.d/halo.conf
打开之后我们可以看到
server {
listen 80;
server_name asaawan.com www.asaawan.com;
location / {
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;
proxy_pass http://127.0.0.1:8090/;
}
}
修改完成之后
# 检查配置是否有误
sudo nginx -t
# 重载 Nginx 配置
sudo nginx -s reload
配置 SSL 证书
# 安装 certbot 以及 certbot nginx 插件
sudo yum install certbot python2-certbot-nginx -y
# 执行配置,中途会询问你的邮箱,如实填写即可
sudo certbot --nginx
# 自动续约
sudo certbot renew --dry-run
Caddy 反向代理
安装 Caddy
# 安装 Caddy 软件包
yum install caddy -y
配置 Caddy
# 下载 Halo 官方的 Caddy 配置模板
curl -o /etc/caddy/conf.d/Caddyfile.conf --create-dirs https://dl.halo.run/config/Caddyfile
下载完成之后,我们还需要对其进行修改
# 使用 vim 编辑 Caddyfile
vim /etc/caddy/conf.d/Caddyfile.conf
打开之后我们可以看到
https://www.simple.com {
gzip
tls xxxx@xxx.xx
proxy / localhost:port {
transparent
}
}
- 请把
https://www.simple.com改为自己的域名。 tls后面的xxxx@xxx.xx改为自己的邮箱地址,这是用于自动申请 SSL 证书用的。需要注意的是,不需要你自己配置 SSL 证书,而且会自动帮你续签。localhost:port请将port修改为 Halo 的运行端口,默认为 8090。
修改完成之后启动 Caddy 服务即可。
# 开启自启 Caddy 服务
systemctl enable caddy
# 启动 Caddy
service caddy start
# 停止运行 Caddy
service caddy stop
# 重启 Caddy
service caddy restart
# 查看 Caddy 运行状态
service caddy status
如果 Caddy 启动出现诸如 [/usr/lib/systemd/system/caddy.service:23] Unknown lvalue 'AmbientCapabilities' in section 'Service' 这样的问题,请使用 yum update -y 更新系统。然后再使用 service caddy restart 重启,已知 CentOS 7.3 会出现该问题。
进阶设置
多网址重定向到主网址,比如访问 simple.com 跳转到 www.simple.com 应该怎么做呢?
# 使用 vim 编辑 Caddyfile
vim /etc/caddy/conf.d/Caddyfile.conf
打开之后我们在原有的基础上添加以下配置
https://simple.com {
redir https://www.simple.com{url}
}
将 https://simple.com 和 https://www.simple.com{url} 修改为自己需要的网址就行了,比如我要求访问 ryanc.cc 跳转到 www.ryanc.cc,完整的配置如下:
https://ryanc.cc {
redir https://www.ryanc.cc{url}
}
https://www.ryanc.cc {
gzip
tls i@ryanc.cc
proxy / localhost:8090 {
transparent
}
}
最后我们重启 Caddy 即可。
到这里,关于 Caddy 反向代理的配置也就完成了,现在你可以访问一下自己的域名,并进行 Halo 的初始化了。
在设置了反向代理之后,请一定记得去 Halo 的管理端设置一下正确的博客地址,否则可能会造成资源获取不成功。
更新 Halo
# 备份数据
cp -r ~/.halo ~/.halo.bak
# 备份旧的安装包
mv halo-latest.jar halo-latest.jar.bak
# 下载最新的 Halo 安装包,{{version}} 为版本号,不带 v,更多下载地址请访问 https://halo.run/archives/download.html
wget https://dl.halo.run/release/halo-{{version}}.jar -O halo-latest.jar
# 测试是否能够正常启动
java -jar halo-latest.jar
# 重启应用
service halo restart

浙公网安备 33010602011771号