从0开始在阿里云搭建一个halo博客

从0开始在阿里云搭建一个halo博客

Scroll Down

01.购买云服务器

  • 想要在阿里云搭建个人博客,就要先在阿里云购买服务器 阿里云官网
  • 搭建个人博客,选入门级就可以,然后根据自己钱包,选一个立即选配
    1.png
  • 地域 - 根据自己实际地址来选。
  • 其它的有钱,可以选高配置,不过不建议,人生艰辛,能省则省。
  • 然后立即购买 -> 付款 -> 进入控制台
    2.png
  • 进入控制台 -> 点有右上角 -> 云服务器ECS
    image.png
  • 点击箭头指的地方进入实例
    image00c33a675df74bb099876fa612760475.png
  • 点击更多 -> 重置密码
    image.png
  • 重置完密码就可以点 - 远程连接 - 到服务器控制台
  • 或者使用 Xshell 连接服务器
    • 用户:root
    • 密码: 你刚重置的密码
      imageab5c22d222cb49fda604c60730802962.png

02.开始配置halo博客

  • 本教程以 CentOS 7.x 为例,配置并运行 Halo,其他 Linux 发行版请参照 halo博客官网

1.更新软件包

sudo yum update -y

2.安装 Java 运行环境

# 安装 OpenJRE
sudo yum install java-1.8.0-openjdk -y

# 检测是否安装成功
java -version

3.下载halo配置文件

# 下载配置文件到 ~/.halo 目录
curl -o ~/.halo/application.yaml --create-dirs https://dl.halo.run/config/application-template.yaml

4.修改配置文件

# 使用 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
  1. 如果需要自定义端口,修改 server 节点下的 port 即可。
  2. 默认使用的是 H2 Database 数据库,这是一种嵌入式的数据库,使用起来非常方便。需要注意的是,默认的用户名和密码为 admin 和 123456,这个是自定义的,最好将其修改,并妥善保存。
  3. 如果需要使用 MySQL 数据库,需要将 H2 Database 的所有相关配置都注释掉,并取消 MySQL 的相关配置。另外,MySQL 的默认数据库名为 halodb,请自行配置 MySQL 并创建数据库,以及修改配置文件中的用户名和密码。
  4. h2 节点为 H2 Database 的控制台配置,默认是关闭的,如需使用请将 h2.console.settings.web-allow-others 和 h2.console.enabled 设置为 true。控制台地址即为 域名/h2-console。注意:非紧急情况,不建议开启该配置。
  5. server.compression.enabled 为 Gzip 功能配置,如有需要请设置为 true,需要注意的是,如果你使用 Nginx 或者 Caddy 进行反向代理的话,默认是有开启 Gzip 的,所以这里可以保持默认。
  6. halo.admin-path 为后台管理的根路径,默认为 admin,如果你害怕别人猜出来默认的 admin(就算猜出来,对方什么都做不了),请自行设置。仅支持一级,且前后不带 /。
  7. halo.cache 为系统缓存形式的配置,可选 memory 和 level,默认为 memory,将数据缓存到内存,使用该方式的话,重启应用会导致缓存清空。如果选择 level,则会将数据缓存到磁盘,重启不会清空缓存。如不知道如何选择,建议默认。

注意:
使用 MySQL 之前,必须要先新建一个 halodb 数据库,MySQL 版本需 5.7 以上。
create database halodb character set utf8mb4 collate utf8mb4_bin;

5.下载helo

# 下载最新的 Halo 安装包,{{version}} 为版本号,不带 v,更多下载地址请访问 https://halo.run/archives/download.html
wget https://dl.halo.run/release/halo-1.3.1.jar -O halo-latest.jar

6.进阶配置

# 下载 Halo 官方的 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]
Type=simple
ExecStart=/usr/bin/java -server -Xms256m -Xmx256m -jar YOUR_JAR_PATH
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 安装包的绝对路径,例如 /root/halo-latest.jar

提示
如果你不是按照上面的方法安装的 JDK,请确保 /usr/bin/java 是正确无误的。
systemd 中的所有路径均要写为绝对路径,另外,~ 在 systemd 中也是无法被识别的,所以你不能写成类似 ~/halo-latest.jar 这种路径。
如何检验是否修改正确:把 ExecStart 中的命令拿出来执行一遍。

# 修改 service 文件之后需要刷新 Systemd
sudo systemctl daemon-reload

# 使 Halo 开机自启
sudo systemctl enable halo

# 启动 Halo
sudo systemctl start halo

# 重启 Halo
sudo systemctl restart halo

# 查看 Halo 的运行状态
sudo systemctl status halo

03. 配置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

# 使用 vim 编辑 halo.conf
vim /etc/nginx/conf.d/halo.conf

halo.conf配置内容

server {
    listen 80;
    server_name www.lidexian.top;

    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/;
    }
}

注意: 请把 www.lidexian.top 改为自己的域名。
如果没有域名,可以直接 ip:8090的方式访问
如果申请了ssl,halo.conf配置如下面

server {
	listen 443 ssl;
	server_name www.lidexian.top;
    	client_max_body_size 1024m;	
	ssl_certificate ./ssl_key/wp.pem;
	ssl_certificate_key ./ssl_key/wp.key;
	
    	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/;
    }

}
server {
	listen 80;
	server_name www.lidexian.top;
	return 302 https://$server_name$request_uri;
}

注意:请把 www.lidexian.top 改为自己的域名。

以上都做完了,在浏览器输入域名,还是访问不了对吧,因为我们还少一步没做。

04.配置阿里云安全策略

  • 把左侧菜单栏拉到下面,看到 -> 网络与安全 -> 安全组 - 点进去
    image1f9c93c44bfc404d87dab25965269529.png

  • 点击配置规则
    image.png

  • 点击添加安全组
    image.png

  • 添加8090端口
    image.png

  • 以同样的方式添加 80 和 443 端口

  • 在浏览器再次输入域名就可以正常打开