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
有三个地方改动
- 增加了ssh://
- 增加了端口号
- 把用户名前面的冒号改成了斜杠(/)
执行以上代码后,如果能把空仓库拉下来,就说明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。
- 添加网站
- 填写域名
- 根目录改成 /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可以折腾一下。
在这里只是给自己留个步骤做个总结,我也是小白一个,自己遇到问题也是百度解决。