具体的功能可以这样理解:
1.功能需求
1)创建根仓库(总得仓库,比如本机D盘)里文件可见。
2)本地仓库(C盘仓库)可关联根仓库(D盘仓库)并提交。
3)局域网其他机器可访问根仓库并可向根仓库提交。
2.准备环境
1)两台机器都安装了git。
2)两台机器可以ping通。
3.功能实现
1) 根仓库的搭建
找好要存放的根仓库目录,比如容量比较大的硬盘D,移动硬盘也可以(相当于一个移动仓库,我没有试过,原理上可行)。
在要做为仓库的目录(如D:\AllGitRepository)下执行以下命令创建仓库:
D:\AllGitRepository>git initInitialized empty Git repository in D:/AllGitRepository/.git/
这样,本地的根仓库就搭建好了。
//不创建裸仓库,因为看不到文件。
2).本地仓库(C盘仓库)可关联根仓库(D盘仓库)并提交
重点来了。
先在C盘创建一个测试目录gitTest,执行以下命令。
::创建文件。C:\Users\gitTest>type null > a.txtC:\Users\gitTest>dir C:\Users\gitTest 的目录2018/07/09 14:45 <DIR> .2018/07/09 14:45 <DIR> ..2018/07/09 14:45 <DIR> a.txt::创建本地仓库。C:\Users\gitTest>git initInitialized empty Git repository in C:/Users/gitTest/.git/C:\Users\gitTest>git add .::提交到本地仓库。C:\Users\gitTest>git commit -m "test"[master (root-commit) 41bf91e] test 1 file changed, 0 insertions(+), 0 deletions(-) create mode 100644 a.txt::关联根仓库(D盘根仓库)C:\Users\gitTest>git remote add rootRep D:\AllGitRepository\
在根仓库(D盘目录)下执行以下命令:
D:\AllGitRepository>git config --global receive.denyCurrentBranch ignore
修改根仓库.git/hooks/post-update.sample文件,在最下边添加以下代码:
unset GIT_DIRcd ..git checkout -f
将该文件后缀删除,变为post-update,post-update文件内容如下:
之后就可以在C盘的仓库中做提交了:
C:\Users\gitTest>git push -u rootRep masterCounting objects: 5, done.Delta compression using up to 4 threads.Compressing objects: 100% (4/4), done.Writing objects: 100% (5/5), 610 bytes | 0 bytes/s, done.Total 5 (delta 0), reused 0 (delta 0)To D:\AllGitRepository 41bf91e..03de5cf master -> masterBranch master set up to track remote branch master from rootRep.
前边只是示例,真实环境下我们已经有了本地的仓库,里边还有不少的代码,比如我有以下一个工程:
3).局域网其他机器访问根仓库并向根仓库提交。
其他机器访问根仓库,只需要将根仓库文件夹共享就可以(添加密码验证)。
将根仓库共享。
a.右键根仓库目录—>属性—>共享—>高级共享—->勾选共享此文件夹—->权限如下:
b.在另一台机器上右键计算机—>映射网络驱动器:
输入根仓库地址比如:
远程提交:
上述步骤将根仓库的地址映射为了X:\所以我们只需要将远程仓库关联到X:\目录下就可以了。其他步骤和本地一样。
这样实现了开头所要的功能。
谢谢阅读。
参考资料:
1) https://blog.csdn.net/lusyoe/article/details/52876728
2) https://www.cnblogs.com/tianyalu/p/5153256.html
联系客服