背景
今天琢磨著利用git來(lái)做服務(wù)器自動(dòng)部署。git倉(cāng)庫(kù)掛在coding.net
上,而coding.net
提供webhook
功能,可以在指定git事件(根據(jù)“自動(dòng)部署”這一用途,這里指的當(dāng)然主要是push
事件了)發(fā)生后庞瘸,發(fā)一個(gè)請(qǐng)求到指定URL來(lái)觸發(fā)更新。
問(wèn)題
由于我本人用的是php囊咏,所以自然是php接收到coding.net
的請(qǐng)求后恕洲,執(zhí)行一段shell命令來(lái)啟動(dòng)git拉取代碼。這一部分還是比較順利的梅割,問(wèn)題是霜第,啟動(dòng)git拉取代碼的shell命令要怎么寫呢?
想想我們平時(shí)是怎么做的呢户辞?
$ cd /xxxx/xxx #進(jìn)到git項(xiàng)目目錄
$ git pull #拉取代碼
嗯泌类,看起來(lái)很簡(jiǎn)單,那我們shell命令也這么寫吧。
fatal: Not a git repository (or any of the parent directories): .git
哎刃榨?弹砚!這是什么情況,我路徑都是對(duì)的啊枢希,怎么會(huì)找不到.git
目錄桌吃?
解決方案
在stackoverflow一番搜尋后,尋得問(wèn)題原因:git命令依賴于環(huán)境變量GIT_DIR
和GIT_WORK_TREE
苞轿,這兩個(gè)環(huán)境變量才是git真正的運(yùn)行上下文茅诱。而在shell命令里直接執(zhí)行cd
是不會(huì)跟著改變這兩個(gè)環(huán)境變量的,因此搬卒,就可能發(fā)生上述的錯(cuò)誤瑟俭。
知道原因就好辦了,我們也不需要使用cd
命令了契邀,直接用--git-dir
和--work-tree
來(lái)傳入這兩個(gè)參數(shù)即可:
$ git --git-dir='/xxx/xxx/.git' --work-tree='/xxx/xxx' pull # 注意這兩個(gè)參數(shù)是傳給git命令的摆寄,要放在'git'的后面
未完待續(xù)
我不解的是,為什么在控制臺(tái)里直接cd
就可以改變GIT_DIR
和GIT_WORK_TREE
這兩個(gè)變量呢坯门?求大神指教微饥。