0. 前言
0.1 说在后面
之前始终有在各大平台公布博客内容,而后集体博客始终应用的是 Hexo + Github Pages 的形式,但随着内容增多,Github Pages 拜访的也不稳固,所以想着本人搞个服务器和域名搭个博客,最终选定 Halo 这个博客框架,搭建属于本人的博客。
此内容从零到一手把手记录如何搭建,记录本人的搭建过程,也给前面的敌人们提供一个指南,少走些冤枉路,尽快上手。
0.2 环境配置
本人花了 210 左右在 UCloud 买了三年的服务器,而后在腾讯花了将近 200 买了个域名,服务器版本是 Ubuntu 18.04 64 位,实践上讲上面的配置适宜于 Ubuntu 系所有版本,个别有出入的中央还请谅解。所以在正式开始之前,你须要满足以下几个条件:
- 一台 Ubuntu 零碎的服务器(Centos 零碎的参考 官网教程 即可);
- 一个域名;
1. Java 环境配置
1.1 装置
- 首先去 官网 下载 JDK,抉择本人想要的版本即可,个别举荐 JDK 1.8+ 的版本;
- 解压下载后的文件;
tar -zxvf jdk-11.0.9_linux-x64_bin.tar.gz
- 配置环境变量,切换到 root 用户,而后编辑
/etc/profile
文件,增加如下内容(留神门路切换为你本人搁置解压缩包后的地位);
export JAVA_HOME=/environment/jdk/jdk-11.0.9
export PATH=$JAVA_HOME/bin:$PATH
1.2 验证
装置好之后就是验证是否胜利,个别咱们用如下命令进行检测;
# 查看 jdk 版本
java -version
# 编译命令
javac
# 运行命令
java
2. 装置 Halo
2.1 下载 Halo 运行包
要下载 Halo 运行包,能够通过两种形式,更举荐第二种,下载起来更快:
- Github releases:https://github.com/halo-dev/h…
- Nova 提供的下载站:https://dl.halo.run
利用如下命令进行下载,以 1.4.2 版本为例,如果要下载其余版本,换版本号即可!
wget https://dl.halo.run/release/halo-1.4.2.jar
2.2 配置
- 下载配置文件(下载后的文件寄存在
~/.halo/application.yaml
);
curl -o ~/.halo/application.yaml --create-dirs https://dl.halo.run/config/application-template.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
2.3 运行 Halo
配置好 Java 环境,同时下载好 Halo 运行包之后,咱们就能够应用如下命令运行了;
java -jar halo-latest.jar
而后在本地浏览器中拜访如下地址即可;
http://ip:8090
3. 进阶配置
3.1 开机自启
- 下载 Halo 官网
service
模板,而后对其进行批改(此时须要管理员权限);
sudo curl -o /etc/systemd/system/halo.service --create-dirs https://dl.halo.run/config/halo.service
- 批改配置文件
具体能够参考 官网文档;
须要留神的几点:
- 填写你的 JDK 绝对路径;
- 填写你的 Halo 运行包所在绝对路径;
- 填写运行 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
3.2 Halo 更新
Halo 是一个沉闷的社区,目前始终在开发迭代中,后续如果公布了新的版本,而咱们又想要降级,这时候就能够依照如下步骤来进行操作了;
- 首先,咱们须要对咱们原有数据进行备份,避免失落
cp -r ~/.halo ~/.halo.bak
- 接着备份久的 Halo 安装包,避免新的安装包呈现问题后无奈回滚;
mv halo-latest.jar halo-latest.jar.bak
- 做好备份工作之后,就是下载最新的 Halo 安装包了,其中
{{verison}}
对应最新版本号;
wget https://dl.halo.run/release/halo-{{version}}.jar -O halo-latest.jar
- 测试一下最新版的 Halo 是否运行胜利;
java -jar halo-latest.jar
- 测试步骤如果胜利了,那咱们间接重启 Halo 服务就好了;
sudo service halo restart
4. 域名拜访
通过下面的配置之后,咱们只能通过 ip:port
的形式进行拜访,如果咱们想让他人来拜访,那么有一个域名就非常有必要了。在正式进行配置域名之前,须要确保如下几件筹备工作:
- Halo 曾经可能正确运行,且运行端口不是
80
端口; - 确保域名解析到服务器 IP,而且确保服务器曾经备案(国内服务器都须要,国外无需);
- 关上服务器的
80
和443
端口;
4.1 配置域名解析服务器 IP
因为我的域名是在腾讯买的,所以这里以腾讯为例;
- 首先关上 域名解析列表,并点击右侧解析进入解析界面;
- 接着增加记录;
增加如下两条记录,其余字段放弃默认即可;
主机记录 | 记录类型 | 记录值 |
---|---|---|
@ |
A |
你的服务器 IP |
www |
A |
你的服务器 IP |
4.2 关上服务器对应端口
- 登录你的服务器,而后关上主机治理界面;
- 接着编辑防火墙,将须要关上的端口关上即可,个别关上如下的协定端口就能够了;
- ICMP
- 3389
- 80
- 443
- 21
- 22
- 8090
4.4 利用 Nginx 进行反向代理
- 装置 Nginx
sudo apt-get install nginx
- 设置开机自启动 Nginx
systemctl enable nginx
- 启动 Nginx
sudo service nginx start
- 配置 Nginx
首先下载 Halo 官网的 Nginx 配置模板;
curl -o /etc/nginx/conf.d/halo.conf --create-dirs https://dl.halo.run/config/nginx.conf
而后对其进行批改;
sudo vim /etc/nginx/conf.d/halo.conf
只须要将其中的 example.com
批改成本人的域名即可,比方我的域名是 cunyu1943.site
;
server {
listen 80;
server_name example.com www.example.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/;
}
}
- 主动配置 SSL 证书
首先装置 certbot nginx 插件;
sudo apt-get install python-certbot-nginx
接着执行配置,过程中会询问为哪个域名增加证书,以及是否重定向,如实抉择即可;
sudo certbot --nginx
最初,设置主动续约即可;
sudo certbot renew --dry-run
- 实现上述步骤之后,功败垂成了,咱们就能够通过本人的域名来拜访本人的博客了,比方我的博客就是:
https://cunyu1943.site
5. 总结
好了,通过下面的一系列设置,咱们的博客就搭建实现了,是不是好简略的说,那就别犹豫,连忙入手搞起来吧!
最初再贴以下本人的博客地址,欢送大家来留言,替换友链呀!
https://cunyu1943.site