使用Git實現Laravel項目的自動化部署


簡介

不知道大家一開始是怎么使用 git 進行開發的,反正我個人是先將代碼提交到 github 倉庫,然后用 SSH 登錄到服務器,然后進行克隆或者版本更新。聽起來就很麻煩,當然實際操作中也很麻煩,那么有什么可以 “一勞永逸 “ 的辦法呢?請往下看!

簡單使用

Git 鈎子

什么是 git 鈎子呢?官方解釋有些長,簡單來說就是一個在特定環境下觸發的腳本。這個解釋可能不太准確,但是我認為這樣更容易理解一些,想了解更多的,可以去 Git 官網查看,下面我們就用鈎子實現自動化部署。

第一步:創建 git 用戶

登錄我們的服務器,這里默認你已經安裝好了 git。創建一個 git 用戶:

1 # 創建一個名叫jouzeyu的用戶
2 adduser jouzeyu

第二步:給 git 用戶添加權限

 1 #在根目錄下的 home 文件夾下創建一個git文件夾
 2 
 3 mkdir /home/git
 4 
 5 #切換到創建好的git文件夾
 6 
 7 cd /home/git
 8 
 9 #創建 .ssh文件夾,里面主要用來放公鑰
10 
11 mkdir .ssh
12 
13 #切換到.ssh文件夾並創建authorized_keys文件
14 
15 cd .ssh
16 
17 touch authorized_keys

第三步:配置 git 並獲取公鑰

1 #在本地配置用戶名和郵箱,我的用戶名默認為jouzeyu
2 
3 git config --global user.name "jouzeyu"
4 
5 git config --global user.email "your email"

注意:如果用了 --global 選項,那么以后你所有的項目都會使用這里配置的用戶信息。如果要在某個特定的項目中使用其他名字或郵箱,只需在該項目下執行:

1 git config user.name "xxx"
2 
3 git config user.email "xxx"

OK,接下來我們獲取公鑰,請先查看你的用戶下的.ssh 文件夾中是否之前就含有公鑰和私鑰,我們需要尋找一對以 id_dsa 或 id_rsa 命名的文件,其中一個帶有 .pub 擴展名。 

.pub 文件是你的公鑰,另一個則是私鑰。如果沒有請運行 ssh-keygen。

使用 cat ~/.ssh/id_rsa.pub 命令可以獲取公鑰,復制它,使用 vi 或者 vim 命令把它粘貼到我們之前創建的 authorized_keys 文件中,使用:wq 保存。

第四步:初始化倉庫

創建一個存放 git 倉庫的文件夾:

1 mkdir /www/wwwroot/git
2 
3 cd /www/wwwroot/git

初始化倉庫:

1 #初始化一個裸倉庫(強烈建議)
2 
3 git init --bare website.git
4 
5 #配置倉庫的權限,讓我們之前創建好的git用戶jouzeyu能讀寫
6 
7 chown -R git:git website.git

這里必須注意,如果不給權限,后面的 git pull 將會報錯,原因是沒有權限寫入。關於裸倉庫和普通倉庫的區別簡單來說就是裸倉庫看不到項目文件,普通倉庫和你的項目目錄一樣,只是多了一個.git 文件夾。

第五步:生成項目倉庫

這個也是在服務器上進行的,同時說明一下 /www/wwwroot/ 是我的環境的根目錄。

 1 #創建我服務器上的項目目錄test
 2 
 3 mkdir /www/wwwroot/test
 4 
 5 #克隆倉庫
 6 
 7 git clone /www/wwwroot/git/website.git
 8 
 9 #設置權限
10 
11 chown -R git website

注意:

一定要注意我的路徑:

git 倉庫是 /www/wwwroot/git,;

項目倉庫是 /www/wwwroot/test。

第六步:克隆到本地

# 通過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 pull)

 1 # 打開剛才克隆下來的本地倉庫
 2 
 3 cd website
 4 
 5 # 創建README.md文件
 6 
 7 touch README.md
 8 
 9 git add .
10 
11 git commit -m"創建README.md文件"
12 
13 git push

不出意外已經正常上傳了,如果報錯請檢查權限,上文提到過,如果還不行可以在下方評論。

第八步:添加鈎子

終於到重頭戲了,寫的比較細,所以比較麻煩一些。回到我們線上的服務器,下面的是在線上操作的:

#切換到這個目錄

cd /www/wwwroot/git/website.git/hooks

# 生成post-receive文件

touch post-receive

# 使用vim編輯

vim post-receive

在 post-receive 文件里面粘貼:

 1 #!/bin/sh
 2 
 3 # 打印輸出
 4 
 5 echo '======上傳代碼到服務器======'
 6 
 7 # 打開線上項目文件夾
 8 
 9 cd /www/wwwroot/test/website
10 
11 # 這個很重要,如果不取消的話將不能在cd的路徑上進行git操作
12 
13 unset GIT_DIR
14 
15 git pull origin master
16 
17 # 自動編譯vue項目,如有需要請去掉前面的#號
18 
19 # npm run build
20 
21 # 自動更新composer(我暫時沒試過)
22 
23 # composer update
24 
25 echo $(date) >> hook.log
26 
27 echo '======代碼更新完成======'

保存后給 post-receive 文件加上運行權限:

1 chmod +x post-receive

最后一步

在本地修改部分內容,然后提交推送 git pull,可以看到我們已經實現了自動化部署。

使用Git實現Laravel項目的自動化部署

 

鏈接:https://mp.weixin.qq.com/s/MkVh1lYUvpE5C2WZWmy0Zg


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM