扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
建站服务器
项目组有个需求:目前我们线上代码都是git 仓库托管的,开发和前端都需要对仓库中的js目录中的文件进行修改,为了避免冲突,想到了把仓库中的子目录分离开来,让前端工程师可以提交到git 仓库。以前是通过ftp进行更新,会有很多问题。更改了这种方式会提高工作效率
让客户满意是我们工作的目标,不断超越客户的期望值来自于我们对这个行业的热爱。我们立志把好的技术通过有效、简单的方式提供给客户,将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,公司提供的服务项目有:空间域名、雅安服务器托管、营销软件、网站建设、盘锦网站维护、网站推广。git和svn对比:
svn是基于文件方式的集中存储,Git却是基于元数据方式散布式存储文件信息的,它会在每次Clone的时候将所有信息都取回到本地,即相当于在你的机器上生成1个克隆版的版本库,既然本地有了完全的版本库,肯定就有所有权限了,所以也就没办法针对子目录的进行权限控制了。
实现:
git从1.7.0开始支持sparse clone,sparse clone也只是1个变通的方法:先拿到全部repository的object等元数据信息,然后在本地加1个叫.git/info/sparse-checkout的文件(即黑名单、白名单,支持正则,参见下文具体操作命令)来控制pull那些目录和文件(类似.gitignore文件,都是本地的概念),变通的实现git只clone仓库中指定子目录和文件
步骤:
1.在本地创建一个目录,用于提交代码
mkdirtest
2.初始化仓库
gitinit
3.拉取远程仓库的objects信息
gitremoteadd-forigingit@code.aliyun.com:test/test.git
4.开启sparse clone
gitconfigcore.sparsecheckouttr
ue
5.设置需要pull的目录 *表示所有
echodevelop>>.git/info/sparse-checkout echoweb/assets/*>>.git/info/sparse-checkout
6.拉取远程仓库
gitpulloriginmaster
7.查看
llassets/ total4 drwxr-xr-x1Administrator1971210七月1010:51css/ drwxr-xr-x1Administrator1971210七月1010:51img/ drwxr-xr-x1Administrator1971210七月1010:51js/ drwxr-xr-x1Administrator1971210七月1010:51lib/
8.本地测试提交
touchtest.txt echothisisatest gitadd. gitcommit-mtest gitpushoriginmaster Countingobjects:4,done. Deltacompressionusingupto4threads. Compressingobjects:100%(3/3),done. Writingobjects:100%(4/4),331bytes|0bytes/s,done. Total4(delta2),reused0(delta0) Tocode.aliyun.com:test8/test.git 037b8ec..317b2a2master->master
参考文档:http://www.wfuyu.com/technology/25144.html
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流