建站服务器
项目组有个需求:目前我们线上代码都是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
当前文章:git单独针对一个仓库实现子目录提交修改
URL分享:https://www.cdcxhl.com/article48/cgidhp.html
成都网站建设公司_创新互联,为您提供面包屑导航、小程序开发、品牌网站设计、域名注册、网站设计公司、品牌网站制作
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联