一个教程“Hexo部署到VPS”给自己留档。

一、本地操作。

本地配置 hexo,详见官方。

http://hexo.io

  • 安装git – git官方下载就好

  • 生成ssh认证

    git config --global user.name "yourname"
    git config --global user.email [email protected]
    ssh-keygen -t rsa -C "[email protected]

最后获取到的ssh认证在C:\Users\yourname.ssh中
也可能在你所右键 git bash here 的位置会得到两个你命名过的文件

二、VPS操作

  • 安装git

Ubuntu 18.04 系统

  • 步骤1.
    首先,通过运行以下命令确保您的系统和apt包列表完全更新:

apt-get update -y
apt-get upgrade -y

  • 第2步。
    在Ubuntu 18.04上安装Git。

现在让我们安装git:

apt install git

您可以使用以下命令来检查已安装的git版本:

git --version
git version 2.15.1

  • 第3步。
    在Ubuntu 18.04上配置Git。

安装后您可能想要做的第一件事是在Git中配置自己的名称和电子邮件地址,以便您提交的更改包含正确的信息。 您可以通过使用以下命令来完成此操作:

git config --global user.name "linuxidc"
git config --global user.email "[email protected]"

  • 接下来,我们将通过查看.gitconfig来验证配置更改:

git config --list

user.name=linuxidc
[email protected]

  • 创建git用户

adduser git
根据提示填写内容

su git
// 这步很重要,不切换用户后面会很麻烦

cd /home/git/

mkdir -p projects/blog
// 项目存在的真实目录 (也可以是服务器现有的文件夹),也就是网站存在的目录

mkdir repos && cd repos
// 这个文件夹也可以没有,如果没有这个文件
下面的文件路径将来就是/home/git/blog.git

git init --bare blog.git
// 创建一个裸露的仓库

cd blog.git/hooks

vi post-receive
// 创建hook钩子函数,输入了内容如下(原理可以参考上面的链接)

#!/bin/sh
git --work-tree=/home/git/projects/blog --git-dir=/home/git/repos/blog.git checkout -f

按esc输入 :wq(要有冒号)保存

添加完毕后修改权限,执行如下命令

chmod +x post-receive

exit
// 退出到 root 登录

chown -R git:git /home/git/repos/blog.git
// 添加权限

测试git仓库是否可用,另找空白文件夹,执行如下命令

git clone [email protected]_ip:/home/git/repos/blog.git

PS:这里要注意文件路径和文件名,要跟上面点文件路径和文件名一致。
在这里我还遇到了端口不是22的问题,把上面的命令按照以下方式写就能成功

git clone ssh://[email protected]_ip:8120/home/git/repos/blog.git

有三个地方改动

  1. 增加了ssh://
  2. 增加了端口号
  3. 把用户名前面的冒号改成了斜杠(/)

执行以上代码后,如果能把空仓库拉下来,就说明git仓库搭建成功了。

  • 建立ssh信任关系
    在本地电脑,执行如下命令

ssh-copy-id -i C:/Users/yourname/.ssh/id_rsa.pub [email protected]_ip

ssh [email protected]_ip
// 测试能否登录

  • 为了安全起见禁用git用户的 shell 登录权限,从而只能用git clone,git push等登录,执行如下命令

cat /etc/shells
// 查看git-shell是否在登录方式里面,有则跳过

which git-shell
// 查看是否安装

vi /etc/shells
添加上2步显示出来的路径,通常是 /usr/bin/git-shell

修改/etc/passwd中的权限,将原来的

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

  • 也可以用以下方法配置SSH

su git
cd /home/git
mkdir .ssh
//创建.ssh目录

cd .ssh
vim authorized_keys

然后将本地的公钥复制到authorized_keys文件里(公钥即上文中本地执行cat ~/.ssh/id_rsa.pub查看的内容)

然后ESC
输入

:wq
//保存推出vi编辑

  • 用户组管理
    执行:
    ll /home/git/
    ll /home/git/projects/ //这个目录可以是

确保blog.git、.ssh、blog目录的用户组权限为 git:git

如果不是,执行下列命令
sudo chown git:git -R /home/git/projects/blog
sudo chown git:git -R /home/git/blog.git

  • 这里要注意的是debian系统默认没有ll命令。
  • 可以用下面的方法来解决
    cd
    echo "alias ll='ls -l'" >> ~/.bashrc && source ~/.bashrc

三、搭建nginx服务器

安装宝塔面板
我只安装了Nginx。

  1. 添加网站
  2. 填写域名
  3. 根目录改成 /home/git/projects/blog (即域名指向的文件路径)

四、本地操作

  • 尝试连接
    在本地打开Git Bash: 输入

ssh [email protected]的IP

之前如果设置了git密码,输入密码
如果得到欢迎信息,就说明服务器配置完成。

如果是VPS端口不是22,会报错。
没有找到指定端口的方法,所以可以修改VPS的端口。

在服务器下输入命令如下:

vi /etc/ssh/sshd_config

拉到最下面会看到端口数字,

输入
i
修改端口为22

输入

:wq

修改好后输入

reboot
重启服务器。

  • 配置Hexo
    打开本地博客根目录下的_config.yml文件,找到最后的deploy配置,修改为:

deploy:
type: git
repo: [email protected]的IP:/home/git/blog.git
//git仓库地址
branch: master

如果还是遇到不是默认端口(22)的时候要写成

deploy:
type: git
repo: ssh://[email protected]的IP:端口/home/git/blog.git
//git仓库地址
branch: master

本文参考文章

带你跳过各种坑,一次性把 Hexo 博客部署到自己的服务器

Hexo搭建个人博客并使用Git部署到VPS