如何用Git单独针对一个仓库实现子目录提交修改

大家好啊,周五到了,这周马上结束咯,今天小编给大家说一下git单独针对一个仓库实现子目录提交修改。目前我们线上代码都是git 仓库托管的,开发和前端都需要对仓库中的js目录中的文件进行修改,为了避免冲突,想到了把仓库中的子目录分离开来,让前端工程师可以提交到git 仓库。以前是通过ftp进行更新,会有很多问题。更改了这种方式会提高工作效率.raksmart服务器。

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.在本地创建一个目录,用于提交代码

mkdir test

2.初始化仓库

git init

3.拉取远程仓库的objects信息

4.开启sparse clone

git config core.sparsecheckout tr

ue

5.设置需要pull的目录 *表示所有

echo "develop" >>.git/info/sparse-checkout

echo "web/assets/*" >>.git/info/sparse-checkout

6.拉取远程仓库

git pull origin master

7.查看

8.本地测试提交

OK,今天到这里就结束啦,大家下周见咯~

  • 发表于:
  • 原文链接http://kuaibao.qq.com/s/20180302A0QP2H00?refer=cp_1026
  • 腾讯「云+社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 yunjia_community@tencent.com 删除。

扫码关注云+社区

领取腾讯云代金券