Git环境之前我们已经在本地安装过了,现在也可以用SSH连接到服务器上了,那么接下来就是要在服务器上面安装Git,并且建立一个远程仓库来帮助我们完成部署过程。
这篇文章,我会告诉你如何升级Linux系统的Git版本,以及建立远程仓库,用钩子实现分离仓库和文件内容,最后用一条命令行完成部署Hexo博客。
时隔四年,重启Hexo历险计划!
Hexo历险记之九Git远程仓库
其实在本系列的第三篇文章中,已经与伙伴们详细解释了如何安装Git环境,可能当时还不甚理解。我也不是故意卖关子,说不用着急配置他,而是因为只有到了这个需要远程部署的时候,才是真的需要使用他。一语带过我是解释不清的,而详细展开又会影响到安装Hexo的理解,所以才放到这里。
张三:我有问题,你不给我解答,我就不看你叨叨的这一堆东西了。明明SSH也是可以复制文件的啊,为什么还要用Git呢?
君匡:因为我们要用Git实现版本控制啊,编写完一篇博客后,提交部署,其实只是需要更新这一篇内容吧,其他内容都不会涉及改动的。虽然用SCP命令也可以复制渲染页面,但是就会缺少版本管理的功能,发生文件丢失,缺损,当我们想要找回之前删除的一句话时,连回滚文件都做不到。
张三:好吧好吧,你说的有道理。那么我用低版本的Git也不行,非得要我升级?
君匡:其实没必要非得追求最新版的Git,低版本的Git也可以实现版本控制的,比如1.8.*
。但是过低的版本会缺少功能且有安全隐患,比如CVE-2022-24765、CVE-2022-24767
就是低版本Git无法抵御的问题,只有升级到2.35.2
才能起到限制作用,所以建议你升级Git。
张三:那么,我们为什么要创建远程仓库呢?明明本地已经有一个仓库了呀,还要单独配置真的很麻烦,难道不能够省略么?
君匡:必须使用Git建立一个远程仓库,我们才可以将本地渲染出来的文章页面用命令传输到服务器上,而这种传输方式以后是经常用的。单独配置远程仓库则是为了能够保存文件变动记录的同时,将具体的文件也保存到路径里。
张三:行,那我就再看看你叨叨的这一堆东西。
君匡:(/和蔼笑/握拳)
之前已经在本地安装过Git环境了,那么接下来就是要配置Git了。
在拉取和上传文件的时候,Git会记录是谁发起了变动,而标识的方式就是用名字和邮箱,所以必须全局配置。
# 格式 git config --global user.name "yourname"
# 格式 git config --global user.email [email protected]
git config --global user.name "junkuang"
git config --global user.email [email protected]
为了以后上传博客时候不会出现下图警告,就再加上一条禁用自动转换。
image-20210530142928758
git config --global core.autocrlf false
在Git 客户端上设置缓冲区大小,以增加仓库对单个文件大小的限制,当推送大量数据时尤为有用。
git config --global http.postBuffer 157286400
正如在前言所说,如果你不升级,低版本的也是可以正常实现功能的,但是在骇客的眼里就几乎是不设防的。如果你认为在远程服务器上又没有什么重要的东西,不想费力升级,那么你可以直接跳到建立远程仓库的部分。
在安装新版本的时候,你其实有两个选择,一个就是仍然使用包管理进行安装,好处是方便快捷,缺点就是无法指定小版本。另一个就是直接从网站上下载压缩包,直接编译安装,缺点是操作繁杂,优点是可以任意选择版本,也可以离线。
运行命令查看Git版本,发现自带了1.8.3.1
版本的。
git --version
image-20220729115401064
示例服务器的系统为CentOS,所以包管理器就是yum
,如果你是其他的LInux系统,那么你就用你的包管理器来卸载应用。
: 卸载低版本的 Git
yum remove git -y
新增Rpm第三方源IUS,然后使用yum
即可安装。
# 新增Rpm第三方源IUS
yum install -y \
https://repo.ius.io/ius-release-el7.rpm \
https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
# 搜寻Git2.*版本
yum search git2 --color=auto
从结果可以知道,现在仓库里可以安装的版本为2.36
,于是直接用命令安装即可。
# 安装git2.36
yum install -y git236
在任意可以联网的机器打开git的下载网页,以安装2.35.2
版本为例,下载安装包git-2.35.2.tar.gz
。也可以直接在服务器上用wget
命令直接下载。
: 下载到文件夹/usr/local/git里,会自动创建目录
wget -P /usr/local/git https://www.kernel.org/pub/software/scm/git/git-2.35.2.tar.gz
: 如果上一条报错了,就加上不检查的参数重新下载
wget -P /usr/local/git --no-check-certificate https://www.kernel.org/pub/software/scm/git/git-2.35.2.tar.gz
-P
: 指定下载目录,于是下载下来就是/usr/local/git/git-2.35.2.tar.gz
--no-check-certificate
: 不检查直接下载
image-20220729125101943
在服务器上先安装依赖,然后切换到存放目录,解压后配置安装路径,接着编译并安装。
: 安装依赖
yum install curl-devel expat-devel gettext-devel openssl-devel zlib-devel gcc perl-ExtUtils-MakeMaker -y
: 切换到存放目录
cd /usr/local/git
: 解压到同级目录
tar -zxvf git-2.22.1.tar.gz
: 进入路径,此时可删除安装包,也可以留作备份
cd git-2.22.1
: 配置git安装路径
./configure prefix=/usr/local/git/
: 编译并且安装
make && make install
修改服务器上的/etc/profile
文件,添加内容如下,目的是在任何目录都可以使用git
命令。
注意:一定要备份文件/etc/profile
,否则很可能就要重装系统了!!!
export PATH=/usr/local/git/bin:$PATH
修改后重新加载该配置文件,在任意目录调用git
命令,测试是否生效。
source etc/profile
如果/usr/bin/
目录下没有git-upload-pack
和git-receive-pack
文件,那么还要多设置软连接,不然后面克隆时有可能会报错。
: 格式 ln [-sf] 源文件 目标文件
ln -s /usr/local/git/bin/git-upload-pack /usr/bin/git-upload-pack
ln -s /usr/local/git/bin/git-receive-pack /usr/bin/git-receive-pack
-s
: 就表示创建软链接了,不加的话就是创建硬链接
-f
: 表示存在的时候删除再创建
新建立一个仓库时,是需要区分该仓库是裸仓库还是空仓库。
一般来说,裸仓库是不储存文件的,所有变动都会以变动记录的方式存储在仓库里;而空仓库是既有变动记录又有具体文件的,但是其他主机就不能够提交信息内容给master
分之了。
: 新建空仓库
git init demo1.git
: 新建裸仓库
git init --bare demo1.git
那可就难过了,因为我们要在服务器上面建立一个既能储存文件还要能够接受信息提交的仓库啊。
不过没关系,在裸仓库接受信息后用一个钩子文件
指定具体文件的位置就可以解决了。
由于Linux系统的限制,所有文件都要归属到用户的权限上来,以此维护系统关键文件不会轻易被改动。这里要求新建一个用户,目的是为了更好地管理文件权限,尤其是在下一篇,我会详细说如何用Nginx
实现端口转发。那时侯这个新建的用户就会起到大作用了。
新建一个用户,用户名以keen
为例。配置密码后,将他添加到用户组里以获得sudo权限。
: 新增用户
adduser keen
: 修改密码,之后要输入两次同样的密码
passwd keen
: 添加到wheel用户组里,获取sudo的权限
usermod -aG wheel keen
在服务器上切换到刚刚新增的用户,创建一个项目真实存在的目录,再创建一个仓库目录。
: 切换用户
su keen
: 项目存在的真实目录
mkdir -p /home/keen/projects/blog
: 项目仓库目录
mkdir -p /home/keen/repos
: 进入仓库目录并
cd /home/keen/repos
: 创建一个名为blog.git的裸露仓库
git init --bare blog.git
测试Git仓库是否可用,在本地创建空白文件夹,执行如下命令。
: 格式 git clone 仓库目录
git clone [email protected]:/home/keen/repos/blog.git
: Cloning into 'myblog'...
: warning: You appear to have cloned an empty repository.
输入密码之后,如果能把空仓库拉取下来,就说明 git 仓库搭建成功了。
使用的是 post-receive
,这个会在我们每次推送消息之后,把部署目录更新到博客的最新生成状态,这样便可以达到部署最新博客的目的。关于 hooks
的详情内容可以参考这里。
先修改下面的内容,注意具体地址要跟实际情况一致!
#!/bin/sh
git --work-tree=/home/keen/projects/blog --git-dir=/home/keen/repos/blog.git checkout -f
--work-tree
: 指定实际文件存储目录
--git-dir
: 指定仓库目录
接着用如下命令创建钩子文件,先按i
,底下出现一个插入的文字。将上面的内容粘贴进来,之后按esc键
再输入:wq
保存并退出。
: 建立钩子文件
vim /home/keen/repos/blog.git/hooks/post-receive
不要忘记设置权限,不然是不会生效的。
: 用keen用户赋予post-receive权限
chmod +x /home/keen/repos/blog.git/hooks/post-receive
: 退出到root
exit
: 用root用户赋予权限
chown -R keen:keen /home/keen/repos/blog.git/
chown -R keen:keen /home/keen/projects/blog/
注意:如果你是在本地Windows上创建的文件,修改后再上传到服务器,那么你需要使用工具dos2unix
转换回车符。
yum install -y dos2unix
dos2unix post-receive
经过上面的操作,远程仓库已经成功建立起来了。我们接下来就是要把本地的变动推送到远程服务器,实现Hexo博客部署。
致敬官网hexo-deployer-git。
一般来说博客初始化的时候,自己就会安装这个插件。即使没有,用下面的命令也可以安装插件。
npm install hexo-deployer-git --save
修改博客根目录的配置文件,可以同时部署多个仓库。
deploy:
- type: git
repo:
ali1: [email protected]:/home/keen/repos/blog.git
ali2: [email protected]:/home/keen/repos/blog.git
从此以后,在编写博客后,就可以直接在博客根目录运行命令,同时发布多个博客了。
hexo deploy
image-20220729143509855
现在,已经将博客完整地推送到了远程服务器上,但是还无法直接访问,下一篇,我会演示如何安装并使用Nginx
实现端口转发,让你能够随时随地访问博客内容。
感谢过去的好奇,也幸好有现在的重温,为了能成为更好的自己。
使用 Git Hook 自动部署 Hexo 到个人 VPS
"remote:error:refusing to update checked out branch:refs/heads/master"的解决办法
git init 和git –bare init 的具体区别
git-upload-pack:command not found问题
centos7下git的安装和配置
centos7.4git安装
linux类似于Windows的桌面快捷方式