簡(jiǎn)介
在我們的開(kāi)發(fā)過(guò)程中,我們不可避免的會(huì)用到版本控制。當(dāng)然,這也致使你對(duì) Git 和 SVN 有所了解。兩者都是出色的版本控制工具,我個(gè)人比較習(xí)慣用 Git,當(dāng)然這可能和個(gè)人習(xí)慣有關(guān)。不知道大家一開(kāi)始是怎么使用 git 進(jìn)行開(kāi)發(fā)的,反正我個(gè)人是先將代碼提交到 github 倉(cāng)庫(kù),然后用 SSH 登錄到服務(wù)器,然后進(jìn)行克隆或者版本更新。聽(tīng)起來(lái)就很麻煩,當(dāng)然實(shí)際操作中也很麻煩,那么有什么可以 “一勞永逸 “ 的辦法呢?請(qǐng)往下看!
簡(jiǎn)單使用
Git 鉤子
什么是 git 鉤子呢?官方解釋有些長(zhǎng),簡(jiǎn)單來(lái)說(shuō)就是一個(gè)在特定環(huán)境下觸發(fā)的腳本。這個(gè)解釋可能不太準(zhǔn)確,但是我認(rèn)為這樣更容易理解一些,想了解更多的,可以去 Git 官網(wǎng)查看,下面我們就用鉤子實(shí)現(xiàn)自動(dòng)化部署。
第一步:創(chuàng)建 git 用戶(hù)
登錄我們的服務(wù)器,這里默認(rèn)你已經(jīng)安裝好了 git。創(chuàng)建一個(gè) git 用戶(hù):
# 創(chuàng)建一個(gè)名叫jouzeyu的用戶(hù)
adduser jouzeyu
第二步:給 git 用戶(hù)添加權(quán)限
#在根目錄下的 home 文件夾下創(chuàng)建一個(gè)git文件夾
mkdir /home/git
#切換到創(chuàng)建好的git文件夾
cd /home/git
#創(chuàng)建 .ssh文件夾,里面主要用來(lái)放公鑰
mkdir .ssh
#切換到.ssh文件夾并創(chuàng)建authorized_keys文件
cd .ssh
touch authorized_keys
第三步:配置 git 并獲取公鑰
#在本地配置用戶(hù)名和郵箱,我的用戶(hù)名默認(rèn)為jouzeyu
git config --global user.name "jouzeyu"
git config --global user.email "your email"
注意:如果用了 --global 選項(xiàng),那么以后你所有的項(xiàng)目都會(huì)使用這里配置的用戶(hù)信息。如果要在某個(gè)特定的項(xiàng)目中使用其他名字或郵箱,只需在該項(xiàng)目下執(zhí)行:
git config user.name "xxx"
git config user.email "xxx"
OK,接下來(lái)我們獲取公鑰,請(qǐng)先查看你的用戶(hù)下的.ssh 文件夾中是否之前就含有公鑰和私鑰,我們需要尋找一對(duì)以 id_dsa 或 id_rsa 命名的文件,其中一個(gè)帶有 .pub 擴(kuò)展名。 .pub 文件是你的公鑰,另一個(gè)則是私鑰。如果沒(méi)有請(qǐng)運(yùn)行 ssh-keygen。
使用 cat ~/.ssh/id_rsa.pub 命令可以獲取公鑰,復(fù)制它,使用 vi 或者 vim 命令把它粘貼到我們之前創(chuàng)建的 authorized_keys 文件中,使用:wq 保存。
第四步:初始化倉(cāng)庫(kù)
創(chuàng)建一個(gè)存放 git 倉(cāng)庫(kù)的文件夾:
mkdir /www/wwwroot/git
cd /www/wwwroot/git
初始化倉(cāng)庫(kù):
#初始化一個(gè)裸倉(cāng)庫(kù)(強(qiáng)烈建議)
git init --bare website.git
#配置倉(cāng)庫(kù)的權(quán)限,讓我們之前創(chuàng)建好的git用戶(hù)jouzeyu能讀寫(xiě)
chown -R git:git website.git
這里必須注意,如果不給權(quán)限,后面的 git pull 將會(huì)報(bào)錯(cuò),原因是沒(méi)有權(quán)限寫(xiě)入。關(guān)于裸倉(cāng)庫(kù)和普通倉(cāng)庫(kù)的區(qū)別簡(jiǎn)單來(lái)說(shuō)就是裸倉(cāng)庫(kù)看不到項(xiàng)目文件,普通倉(cāng)庫(kù)和你的項(xiàng)目目錄一樣,只是多了一個(gè).git 文件夾。
第五步:生成項(xiàng)目倉(cāng)庫(kù)
這個(gè)也是在服務(wù)器上進(jìn)行的,同時(shí)說(shuō)明一下 /www/wwwroot/
是我的環(huán)境的根目錄。
#創(chuàng)建我服務(wù)器上的項(xiàng)目目錄test
mkdir /www/wwwroot/test
#克隆倉(cāng)庫(kù)
git clone /www/wwwroot/git/website.git
#設(shè)置權(quán)限
chown -R git website
注意:一定要注意我的路徑,git 倉(cāng)庫(kù)是 /www/wwwroot/git, 項(xiàng)目倉(cāng)庫(kù)是 /www/wwwroot/test。
第六步:克隆到本地
# 通過(guò)ip地址從配置好的線上倉(cāng)庫(kù)拉取下來(lái)
git clone git@47.97.121.XXX:/www/wwwroot/git/website.git
# 如果有配置域名的話也可以通過(guò)域名拉取
git clone git@www.XXX.XXX:/www/wwwroot/git/website.git
因?yàn)楣€的原因,這里是不需要密碼的,如果成功你的電腦上會(huì)出現(xiàn)一個(gè) website 的文件夾,如果報(bào)錯(cuò)請(qǐng)檢查后再進(jìn)行下面的操作。
第七步:測(cè)試上傳(git pull)
# 打開(kāi)剛才克隆下來(lái)的本地倉(cāng)庫(kù)
cd website
# 創(chuàng)建README.md文件
touch README.md
git add .
git commit -m"創(chuàng)建README.md文件"
git push
不出意外已經(jīng)正常上傳了,如果報(bào)錯(cuò)請(qǐng)檢查權(quán)限,上文提到過(guò),如果還不行可以在下方評(píng)論。
第八步:添加鉤子
終于到重頭戲了,寫(xiě)的比較細(xì),所以比較麻煩一些?;氐轿覀兙€上的服務(wù)器,下面的是在線上操作的:
#切換到這個(gè)目錄
cd /www/wwwroot/git/website.git/hooks
# 生成post-receive文件
touch post-receive
# 使用vim編輯
vim post-receive
在 post-receive 文件里面粘貼:
#!/bin/sh
# 打印輸出
echo '======上傳代碼到服務(wù)器======'
# 打開(kāi)線上項(xiàng)目文件夾
cd /www/wwwroot/test/website
# 這個(gè)很重要,如果不取消的話將不能在cd的路徑上進(jìn)行g(shù)it操作
unset GIT_DIR
git pull origin master
# 自動(dòng)編譯vue項(xiàng)目,如有需要請(qǐng)去掉前面的#號(hào)
# npm run build
# 自動(dòng)更新composer(我暫時(shí)沒(méi)試過(guò))
# composer update
echo $(date) >> hook.log
echo '======代碼更新完成======'
保存后給 post-receive 文件加上運(yùn)行權(quán)限:
最后一步
在本地修改部分內(nèi)容,然后提交推送 git push,可以看到我們已經(jīng)實(shí)現(xiàn)了自動(dòng)化部署。
![](http://img.jbzj.com/file_images/article/201911/20191124151208406.png?20191024151226)
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:- 利用php + Laravel如何實(shí)現(xiàn)部署自動(dòng)化詳解