// assume there're some initial files you want to push to the bare repo you just created,
// which are placed under example directory
# cd example
# git init
# git add *
# git commit -m "My initial commit message"
# git remote add origin git@example.com:example.git
# git push -u origin master
项目团队里面的每个人都可以clone这个库,然后完成本地修改之后,往这个库中push自己的代码。
# git clone git@example.com:example.git
# cd example
在本文中我将:
使用“普通库”代指用"git init"命令创建的GIT库;
使用“裸库”代指用"git init --bare"命令创建的GIT库;
当你创建一个普通库时,在工作目录下,除了.git目录之外,你还可以看到库中所包含的所有源文件。你拥有了一个可以进行浏览和修改(add, commit, delete等)的本地库。
当你创建一个裸库时,在工作目录下,只有一个.git目录,而没有类似于本地库那样的文件结构可供你直接进行浏览和修改。但是你仍旧可以用git show命令来进行浏览,举个例子(参数为某个commit的SHA1值):
一般来说,一个裸库往往被创建用于作为大家一起工作的共享库,每一个人都可以往里面push自己的本地修改。一个惯用的命名方式是在库名后加上.git,举个例子:
这样你便拥有了一个叫做example的共享库。在你自己的本地机器上,你可以用git remote add命令做初始化check-in:
项目团队里面的每个人都可以clone这个库,然后完成本地修改之后,往这个库中push自己的代码。
参考:
普通库与裸库的区别:http://stackoverflow.com/questions/78611...
该如何使用一个裸库:http://stackoverflow.com/questions/76324...
什么是GIT裸库:http://www.saintsjd.com/2011/01/what-is-...
如何设置一个远程共享库并进行团队协作:http://thelucid.com/2008/12/02/git-setti...
git remote add与git clone的区别:http://stackoverflow.com/questions/48555...
用“git init –bare”初始化的版本库(bare repository)仅包含”.git”目录(记录版本历史),不含项目源文件拷贝。如果你进入版本目录,你会发现仅有”.git”目录,没有其他文件。版本库仅包含记录着版本历史的文件。
上面的人都说的太复杂了,3句话就可以说明白:
1.git init 创建本地仓库(在工程目录下创建)
2.git init --bare 创建远端仓库(在服务器或者工程目录以外路径都可以创建的备份仓库)
工程commit到1中,push到2中;
bare repo没有work tree
有本书是《git权威指南》可以看看,真的不错
`--bare
创建一个裸存储库。如果没有设置GIT_DIR环境,则设置为当前工作目录。`
http://blog.csdn.net/feizfang3/article/details/8065506
从使用方面看:
git init 用于本地代码库,跟文件夹下包括所有的源代码,git版本控制相关的文件在.git目录下;
git init --bare 意思是建一个裸库,执行命令后,跟目录下只包括git版本控制相关的文件等,相对于上面.git文件夹下的所有文件。跟目录是不包括项目源代码的。
一般来讲,作为远端备份或公共版本库时,应该使用git init --bare。