在開發過程當中,咱們不可避免的會用到版本控制。你可能對 Git 和 SVN 有所瞭解。一開始基本都是在用SVN,如今可能都進化到用Git了吧,由於SVN缺點比較多。這裏就不過於多的介紹Git的優勢了。
不知道你們一開始是怎麼使用 git 進行開發的,小編一開始是先將本地的代碼所有提交到 github 倉庫,這個時候要讓服務器上的代碼更換成你提交的,那你就得登陸到服務器作一次git pull origin master 的操做。有什麼方法能讓這一步自動操做了呢?這個時候咱們就使用到了Git 鉤子了。
什麼是Git鉤子呢?
官網解釋:和其它版本控制系統同樣,Git 能在特定的重要動做發生時觸發自定義腳本。有兩組這樣的鉤子:客戶端的和服務器端的。客戶端鉤子由諸如提交和合並這樣的操做所調用,而服務器端鉤子做用於諸如接收被推送的提交這樣的聯網操做。你能夠爲所欲爲地運用這些鉤子。
簡單來講就是一個在特定環境下觸發的腳本。也就是說咱們把服務器要拉取咱們更新的代碼這一步自動觸發,自動拉取到最新。
下面咱們就用鉤子實現自動化部署
第一步:建立 git 用戶
登陸服務器,這裏默認你已經安裝好了 git。建立一個 git 用戶:vue
# 建立一個名叫jouzeyu的用戶 adduser jouzeyu
第二步:給 git 用戶添加權限git
#在根目錄下的 home 文件夾下建立一個git文件夾 mkdir /home/git #切換到建立好的git文件夾 cd /home/git #建立 .ssh文件夾,裏面主要用來放公鑰 mkdir .ssh #切換到.ssh文件夾並建立authorized_keys文件 cd .ssh touch authorized_keys
第三步:配置 git 並獲取公鑰github
#在本地配置用戶名和郵箱,個人用戶名默認爲jouzeyu git config --global user.name "jouzeyu" git config --global user.email "your email"
注意:若是用了 --global 選項,那麼之後你全部的項目都會使用這裏配置的用戶信息。若是要在某個特定的項目中使用其餘名字或郵箱,只需在該項目下執行:web
git config user.name "xxx" git config user.email "xxx"
接下來咱們獲取公鑰,請先查看你的用戶下的.ssh 文件夾中是否以前就含有公鑰和私鑰,咱們須要尋找一對以 id_dsa 或 id_rsa 命名的文件,其中一個帶有 .pub 擴展名。.pub 文件是你的公鑰,另外一個則是私鑰。若是沒有請運行 ssh-keygen。
使用 cat ~/.ssh/id_rsa.pub 命令能夠獲取公鑰,複製它,使用 vi 或者 vim 命令把它粘貼到咱們以前建立的 authorized_keys 文件中,使用:wq 保存。
第四步:初始化倉庫
建立一個存放 git 倉庫的文件夾:面試
mkdir /www/wwwroot/git cd /www/wwwroot/git
初始化倉庫:數據庫
#初始化一個裸倉庫(強烈建議) git init --bare website.git #配置倉庫的權限,讓咱們以前建立好的git用戶jouzeyu能讀寫 chown -R git:git website.git
這裏必須注意,若是不給權限,後面的 git pull 將會報錯,緣由是沒有權限寫入。關於裸倉庫和普通倉庫的區別簡單來講就是裸倉庫看不到項目文件,普通倉庫和你的項目目錄同樣,只是多了一個.git 文件夾。
第五步:生成項目倉庫
這個也是在服務器上進行的,同時說明一下 /www/wwwroot/
是個人環境的根目錄。npm
#建立我服務器上的項目目錄test mkdir /www/wwwroot/test #克隆倉庫 git clone /www/wwwroot/git/website.git #設置權限 chown -R git website
注意:必定要注意個人路徑,git 倉庫是 /www/wwwroot/git, 項目倉庫是 /www/wwwroot/test。vim
第六步:克隆到本地服務器
# 經過ip地址從配置好的線上倉庫拉取下來 git clone git@47.97.121.XXX:/www/wwwroot/git/website.git # 若是有配置域名的話也能夠經過域名拉取 git clone git@www.XXX.XXX:/www/wwwroot/git/website.git
由於公鑰的緣由,這裏是不須要密碼的,若是成功你的電腦上會出現一個 website 的文件夾,若是報錯請檢查後再進行下面的操做。
第七步:上傳代碼(git push)微信
# 打開剛纔克隆下來的本地倉庫 cd website # 建立README.md文件 touch README.md git add . git commit -m"建立README.md文件" git push
不出意外已經正常上傳了,若是報錯請檢查權限,上文提到過,若是還不行能夠在下方評論。
第八步:添加鉤子
寫的比較細,如今纔來說鉤子,回到咱們線上的服務器,下面的是在線上操做的:
#切換到這個目錄 cd /www/wwwroot/git/website.git/hooks # 生成post-receive文件 touch post-receive # 使用vim編輯 vim post-receive
在 post-receive 文件裏面粘貼:
#!/bin/sh # 打印輸出 echo '======上傳代碼到服務器======' # 打開線上項目文件夾 cd /www/wwwroot/test/website # 這個很重要,若是不取消的話將不能在cd的路徑上進行git操做 unset GIT_DIR git pull origin master # 自動編譯vue項目,若有須要請去掉前面的#號 # npm run build # 自動更新composer(我暫時沒試過) # composer update echo $(date) >> hook.log echo '======代碼更新完成======'
保存後給 post-receive 文件加上運行權限
chmod +x post-receive
最後一步
在本地修改部份內容,而後提交推送 git push,能夠看到咱們已經實現了自動化部署。
以上內容但願幫助到你們,更多PHP大廠PDF面試文檔,PHP進階架構視頻資料,PHP精彩好文免費獲取能夠微信搜索關注公衆號:PHP開源社區,或者訪問: