背景
今天琢磨著利用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命令要怎么寫(xiě)呢?
想想我們平時(shí)是怎么做的呢?
$ cd /xxxx/xxx #進(jìn)到git項(xiàng)目目錄
$ git pull #拉取代碼
嗯,看起來(lái)很簡(jiǎn)單,那我們shell命令也這么寫(xiě)吧。
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è)變量呢?求大神指教。