前言

看到群里好多人问如何将Hexo部署到云服务器。按我的思想,如果有服务器谁还用Hexo?但居然还真有人。趁着上个月白嫖的腾讯云的机器还没过期,赶紧重装个系统,来咕一篇Hexo如何部署到云服务器。

开始操作

这篇文章并非从安装开始的教程。此教程建立在你已经能通过http://localhost:4000/访问到你的博客的基础上进行的教程。因此并不会涉及到Node的安装与配置,Hexo的下载等。如果还没完成可以自行百度或者看我以前的一篇水文:从零开始搭建Hexo博客

一、通过Git生成SSH密钥

1
2
3
4
5
6
7
// 假如没有设置git的全局信息需要先设置 设置过了可以忽略
git config --global user.name "yourname"
git config --global user.email youremail@example.com
// 生成SSH密钥
ssh-keygen -t rsa -C "youremail@example.com"
// 禁用自动转换,这个不设置后面上传时会出现警告
git config --global core.autocrlf false

然后Windows的同学生成的密钥在C:\Users\yourname\.ssh路径下,但是Linux或者MAC的小伙伴我就不知道了。毕竟没用这两个操作系统搞过。

二、配置GIT服务器

连接服务器可以使用Xshell或者FinalShell等工具。这里我已Xshell为例,另一款工具同理。

  1. 登录服务器

    由于是刚刚重装的系统,因此登录很简单。看到一如既往的黑底白字。

    image-20200520183403380

  2. 检查是否存在git,如果没有则需要安装

    通过git --version命令查看是否存在git命令,我这里显示not found。则代表没有git,需要安装。

    image-20200520183621113

  3. 安装Git

    1
    2
    yum install curl-devel expat-devel gettext-devel openssl-devel zlib-devel perl-devel -y
    yum install -y git

    安装很快就完成了!

    image-20200520183828839

  4. 创建用户并配置其仓库

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    // 创建用户
    useradd git
    // 设置密码
    passwd git
    // 切换用户
    su git
    // 进入git用户的家目录
    cd /home/git/
    // 项目存在的真实目录(当然你可以创建在其他地方)
    mkdir -p projects/blog
    // 创建文件夹
    mkdir repos && cd repos
    // 创建一个裸露的仓库
    git init --bare blog.git

    image-20200520185128363

    1
    2
    3
    4
    5
    6
    7
    cd blog.git/hooks
    // 创建 hook 钩子函数,输入了内容如下
    vi post-receive
    //-------------分割线不需要复制-------------
    #!/bin/sh
    git --work-tree=/home/git/projects/blog --git-dir=/home/git/repos/blog.git checkout -f
    //-------------分割线不需要复制-------------

    image-20200520185259732

    image-20200520185245454

    按住ESC,然后输出:wq可以保存退出哦!

    1
    2
    3
    4
    5
    6
    // 为刚才的文件添加可执行的权限
    chmod +x post-receive
    // 退出到 root 登录
    exit
    // 添加权限
    chown -R git:git /home/git/repos/blog.git

    image-20200520185328477

  5. 测试能否将其clone

    在你的电脑上随便找个位置新建一个文件夹,并且将bash或者其他命令行工具切换到这里。开始执行以下命令(注意替换成你的服务器ip),测试能否将仓库clone下来。

    1
    git clone git@server_ip:/home/git/repos/blog.git

    image-20200520185735240

  6. 建立SSH信任关系(免密登录

    在你自己的电脑上输入以下命令(注意替换成你的文件路径)

    1
    2
    3
    ssh-copy-id -i C:/Users/yourname/.ssh/id_rsa.pub git@server_ip
    // 测试能否登录
    ssh git@server_ip

    翻车了!?

    好吧,我居然没有这个ssh-copy-id命令,不过无妨,既然不能使用命令,那么我就手动。如果你上面的两个命令没有问题,那么可以跳过我手动建立信任关系的过程。

    手动设置:

    1. 依次执行以下命令

      1
      2
      3
      4
      5
      6
      7
      8
      9
      10
      11
      12
      13
      14
         // 切换到git用户
      su git
      //进入家目录,如果没有.ssh目录,那么需要创建。如果存在直接进入即可
      cd ~
      //创建.ssh目录
      mkdir .ssh
      // 赋予权限
      chmod 700 .ssh/
      // 进入.ssh目录
      cd .ssh
      // 编辑一个名为authorized_keys的文件,并写入公钥(id_rsa.pub)内容
      vi authorized_keys
      // 添加完成后赋予权限
      chmod 600 authorized_keys

      image-20200520191422039

      image-20200520191403277

      图片中的命令如果与给出代码命令有出入,请以给出代码为准,图片仅作参考。

    2. 在自己电脑测试能否连接成功。

      1
      ssh git@server_ip 

      此时登录就需要密码了。

    完成以上步骤后通过ssh git@server_ip连接服务器是不需要密码的。如果还是需要密码,请检查你是否遗漏的哪一步没有做

  7. 为了安全,禁用 git 用户的 shell 登录权限。从而只能用 git clone,git push 等登录

    在服务器端输入以下命令:

    1
    2
    3
    4
    5
    6
    7
    8
    // 如果不是root用户请切换至root用户
    su root
    // 查看 git-shell 是否在登录方式里面
    cat /etc/shells
    // 查看是否安装
    which git-shell
    vi /etc/shells
    // 添加上2步显示出来的路劲,通常在 /usr/bin/git-shell

    image-20200520193948936

    image-20200520194120628

    修改/etc/passwd中的权限

    1
    2
    // 修改passwd文件
    vi /etc/passwd
    1
    2
    3
    4
    5
    // 将原来的
    git:x:1000:1000::/home/git:/bin/bash

    // 修改为
    git:x:1000:1000::/home/git:/bin/git-shell

    image-20200520194259323

三、配置NGINX服务器

这一步主要是用来开启80端口的服务器。你不会以为要用hexo s吧?

  1. 安装NGINX服务器

    1
    2
    3
    4
    // 安装依赖
    sudo yum install -y yum-utils
    // 安装nginx服务
    sudo yum install -y nginx
  2. 检查是否安装成功。

    image-20200520194626609

    看到输出了版本号及代表成功了。

  3. 配置NGINX服务器

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    // 直接运行nginx
    nginx
    // 先停止nginx
    nginx -s stop
    // 切换到nginx的配置文件目录
    cd /etc/nginx
    // 编辑文件
    vi nginx.conf

    //
    同时,不然nginx无法访问

    将 user 改为 root 如下图

    image-20200520195059532

    修改 root 解析路径(/home/git/projects/blog/),如下图

    image-20200520201055427

    1
    nginx -s reload

    此时在浏览器直接访问你的服务器ip地址即可看到一个提示——404页面

四、配置Hexo发布

  1. 配置博客根目录下的_config.yml文件

    1
    2
    3
    4
    deploy:
    type: git #用户名
    repo: git@server_ip:/home/git/repos/blog.git #Git仓库
    branch: master #分支

    image-20200520195833894

  2. package.json 中添加 npm 脚本

    1
    2
    3
    4
    "scripts": {
    "deploy": "hexo clean && hexo g -d",
    "start": "hexo clean && hexo g && hexo s"
    },

  3. 这下在本地调试就用npm start,调试好了就上传到服务器,然后就可以通过服务器的IP访问了!

    image-20200520200238327

    image-20200520201210523

绑定域名

直接修改NGINX的文件即可。然后域名解析用A记录解析到服务器即可。

image-20200520201531011

配置HTTPS(SSL)

请自行参考百度!

原创不易,所有文字及图片都是我自己一个一个弄得。
搬砖党请尊重一下作者,转载请标明出处。