一个教程“Hexo部署到VPS”,留着自用。


title: 一个教程“Hexo部署到VPS”给自己留档。
date: 2018-11-27 12:38:22
tags:


一、本地操作。

本地配置 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 git@server_ip:/home/git/repos/blog.git

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

git clone ssh://git@server_ip:8120/home/git/repos/blog.git

有三个地方改动

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

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

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

ssh-copy-id -i C:/Users/yourname/.ssh/id_rsa.pub git@server_ip

ssh git@server_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 git@VPS的IP

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

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

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

vi /etc/ssh/sshd_config

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

输入
i
修改端口为22

输入

:wq

修改好后输入

reboot
重启服务器。

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

deploy:
type: git
repo: git@VPS的IP:/home/git/blog.git
//git仓库地址
branch: master

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

deploy:
type: git
repo: ssh://git@VPS的IP:端口/home/git/blog.git
//git仓库地址
branch: master

本文参考文章

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

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

自有了VPS以后,只放扶墙程序觉得比较浪费,就考虑怎么弄blog,开始用wordpress,总觉得缺少点什么;后来想到还有hexo可以折腾一下。
在这里只是给自己留个步骤做个总结,我也是小白一个,自己遇到问题也是百度解决。

你可能感兴趣的:(一个教程“Hexo部署到VPS”,留着自用。)