本文共 4042 字,大约阅读时间需要 13 分钟。
工作需要学习,学习需要积累。网上有很多好的博客系统。我们可以去"CSDN","博客园"等这种大厂提供的博客空间,也可以自己搭建高逼格的独立博客。例如,适合github的hexo,大众的wordpress,OneBlog,Tale等。对比了一波,我选择halo这款博客系统。对于我它有以下几个优点:
(1)java语言实现,适合java程序员。
(2)动态的主题切换(特别炫支持移动端,响应式页面)
(3)完善的后台管理功能操作方便。
(4)部署超级简单,五分钟完成搭建。
(5)站点迁移方便,复制文件一键迁移。
下面讲讲如何搭建Halo,在这之前,购买自己的云服务器,备案自己的域名。这是搭建自己站点,拉取流量的基础;我这里是阿里云,域名备案也直接在阿里云备案:
使用 Docker 部署 Halo 的指南,假设你已经 并了解它的基本使用。本篇教程以 CentOS 7.x 为例,其他系统大同小异。
为了在使用过程中不出现意外的事故,给出下列推荐的配置 CentOS 7.x 1G 以上内存
sudo yum update -y
sudo systemctl start docker
考虑到部分用户的需要,可能需要自定义比如端口等设置项,我们提供了公共的配置文件,并且该配置文件是完全独立于安装包的。当然,你也可以使用安装包内的默认配置文件,但是安装包内的配置文件是不可修改的。请注意:配置文件的路径为 ~/.halo/application.yaml。
curl -o ~/.halo/application.yaml --create-dirs http://halo.ryanc.cc/config/application-template.yaml
完成上一步操作,我们就可以自己配置 Halo 的运行端口,以及数据库相关的配置了。
vim ~/.halo/application.yaml
打开之后我们可以看到:
H2 配置如下:
port: 8090spring: datasource: type: com.zaxxer.hikari.HikariDataSource # H2 Database 配置 driver-class-name: org.h2.Driver url: jdbc:h2:file:~/.halo/db/halo username: admin password: openadmin h2: console: settings: web-allow-others: false path: /h2-console enabled: false
MySQL 配置如下:
port: 8090spring: datasource: # MySQL 配置 driver-class-name: com.mysql.cj.jdbc.Driver url: jdbc:mysql://127.0.0.1:3306/halodb?characterEncoding=utf8&useSSL=false&serverTimezone=Asia/Shanghai username: root password: openroot
sudo docker pull ruibaby/halo
docker run --name halo -d -p 8090:8090 -v ~/.halo:/root/.halo ruibaby/halo
完成以上操作即可通过 ip:端口 访问了。端口默认是8090可以在配置文件或者启动时添加参数修改。虽然可以访问,但是端口暴露很不安全,后续第5步是如何配置域名访问。
4.1 打开博客进行博客的初始化操作。初始化完成进入admin管理页面。
点击右上角头像位置最左边的按钮,跳转到博客首页。设置主题!
4.2 创建数据库,不需要创建表结构,初始化应用的时候自动生成。
重启服务,打开地址,我们再一次初始化博客。打开数据库,可以看到表和数据已经初始化好了:
服务搭建完成,解释一下后台配置,特别是主题配置
4.3 菜单分为仪表盘,文章,页面,附件,评论,外观,用户,系统这几个,重点解释一下外观。外观菜单可以设置博客的主题显示效果。打开菜单如下:
4.4 如何修改主题打开编辑主题页面:
可以根据自己的喜好设置自己的页面效果,可以自定义友情链接,社交网点等。
使用 Caddy 进行反向代理。Caddy 是一款使用 Go 语言开发的 Web 服务器。其配置更为简洁,并可以自动申请及配置 SSL 证书(这里推荐使用)。
5.1 安装 Caddy
# 安装 Caddy 软件包yum install caddy -y
5.2 配置 Caddy
# 下载 Halo 官方的 Caddy 配置模板curl -o /etc/caddy/conf.d/Caddyfile.conf --create-dirs http://halo.ryanc.cc/config/Caddyfile
5.3 下载完成之后,我们还需要对其进行修改。
# 使用 vim 编辑 Caddyfilevim /etc/caddy/conf.d/Caddyfile.conf
5.4 打开之后我们可以看到
https://www.simple.com { gzip tls xxxx@xxx.xx proxy / localhost:port { transparent }}
(1)请把 https://www.simple.com 改为自己的域名。
(2)tls 后面的 xxxx@xxx.xx 改为自己的邮箱地址,这是用于自动申请 SSL 证书用的。需要注意的是,不需要你自己配置 SSL 证书,而且会自动帮你续签。
(3)localhost:port 请将 port 修改为 Halo 的运行端口,默认为 8090。
5.5 修改完成之后启动 Caddy 服务即可。
# 开启自启 Caddy 服务systemctl enable caddy# 启动 Caddyservice caddy start# 停止运行 Caddyservice caddy stop# 重启 Caddyservice 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修改为自己需要的网址就行了,比如我要求访问 ryanc.cc 跳转到www.ryanc.cc ,完整的配置如下:
http://ryanc.cc { redir https://www.ryanc.cc{url}}https://www.ryanc.cc { gzip tls i@ryanc.cc proxy / localhost:8090 { transparent }}
最后我们(service caddy restart)重启 Caddy 即可。
到这里,关于 Caddy 反向代理的配置也就完成了,现在你可以访问一下自己的域名,并进行 Halo 的初始化了。
注意: 在设置了反向代理之后,请一定记得去 halo 的管理端设置一下正确的博客地址,否则会造成资源获取不成功。
参考:
个人博客:
官网:
转载地址:http://lbpgj.baihongyu.com/