项目组有个需求:目前我们线上代码都是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.在本地创建一个目录,用于提交代码
1
|
mkdir
test
|
2.初始化仓库
1
|
git init
|
3.拉取远程仓库的objects信息
1
|
git remote add -f origin git@code.aliyun.com:
test
/test
.git
|
4.开启sparse clone
1
|
git config core.sparsecheckout
tr
|
ue
5.设置需要pull的目录 *表示所有
1
2
|
echo
"develop"
>>.git
/info/sparse-checkout
echo
"web/assets/*"
>>.git
/info/sparse-checkout
|
6.拉取远程仓库
1
|
git pull origin master
|
7.查看
1
2
3
4
5
6
|
ll assets/
total 4
drwxr-xr-x 1 Administrator 197121 0 七月 10 10:51 css/
drwxr-xr-x 1 Administrator 197121 0 七月 10 10:51 img/
drwxr-xr-x 1 Administrator 197121 0 七月 10 10:51 js/
drwxr-xr-x 1 Administrator 197121 0 七月 10 10:51 lib/
|
8.本地测试提交
1
2
3
4
5
6
7
8
9
10
11
12
|
touch
test
.txt
echo
"this is a test"
git add .
git commit -m
"test"
git push origin master
Counting objects: 4,
done
.
Delta compression using up to 4 threads.
Compressing objects: 100% (3
/3
),
done
.
Writing objects: 100% (4
/4
), 331 bytes | 0 bytes
/s
,
done
.
Total 4 (delta 2), reused 0 (delta 0)
To code.aliyun.com:test8
/test
.git
037b8ec..317b2a2 master -> master
|
本文转自 shouhou2581314 51CTO博客,原文链接:http://blog.51cto.com/thedream/1945853,如需转载请自行联系原作者