2014年03月22日 16:30:18 ljchlx 閱讀數 58304更多git
我的分類: gitspa
git init 和 git init –bare 的區別
使用命令"git init --bare"(bare漢語意思是:裸,裸的)初始化的版本庫(暫且稱爲bare repository)只會生成一類文件:用於記錄版本庫歷史記錄的.git目錄下面的文件;而不會包含實際項目源文件的拷貝;因此該版本庫不能稱爲工做目錄(working tree);若是你進入版本目錄,就會發現只有.git目錄下的文件,而沒有其它文件;就是說,這個版本庫裏面的文件都是.git目錄下面的文件,把本來在.git目錄裏面的文件放在版本庫的根目錄下面;換句話說,不使用--bare選項時,就會生成.git目錄以及其下的版本歷史記錄文件,這些版本歷史記錄文件就存放在.git目錄下;而使用--bare選項時,再也不生成.git目錄,而是隻生成.git目錄下面的版本歷史記錄文件,這些版本歷史記錄文件也再也不存放在.git目錄下面,而是直接存放在版本庫的根目錄下面
用"git init"初始化的版本庫用戶也能夠在該目錄下執行全部git方面的操做。但別的用戶在將更新push上來的時候容易出現衝突。
好比有用戶在該目錄(就稱爲遠端倉庫)下執行git操做,且有兩個分支(master 和 b1),當前在master分支下。另外一個用戶想把本身在本地倉庫(就稱爲本地倉庫)的master分支的更新提交到遠端倉庫的master分支,他就想固然的敲了
git push origin master:master
因而乎出現
由於遠端倉庫的用戶正在master的分支上操做,而你又要把更新提交到這個master分支上,固然就出錯了。
但若是是往遠端倉庫中空閒的分支上提交仍是能夠的,好比
git push origin master:b1 仍是能夠成功的
解決辦法就是使用」git init –bare」方法建立一個所謂的裸倉庫,之因此叫裸倉庫是由於這個倉庫只保存git歷史提交的版本信息,而不容許用戶在上面進行各類git操做,若是你硬要操做的話,只會獲得下面的錯誤(」This operation must be run in a work tree」)
這個就是最好把遠端倉庫初始化成bare倉庫的緣由。
轉自:http://blog.csdn.net/feizxiang3/article/details/8065506.net