建站服务器
项目组有个需求:目前我们线上代码都是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.git4.开启sparse clone
gitconfigcore.sparsecheckouttrue
5.设置需要pull的目录 *表示所有
echodevelop>>.git/info/sparse-checkoutechoweb/assets/*>>.git/info/sparse-checkout6.拉取远程仓库
gitpulloriginmaster7.查看
llassets/total4drwxr-xr-x1administrator1971210七月1010:51css/drwxr-xr-x1administrator1971210七月1010:51img/drwxr-xr-x1administrator1971210七月1010:51js/drwxr-xr-x1administrator1971210七月1010:51lib/8.本地测试提交
touchtest.txtechothisisatestgitadd.gitcommit-mtestgitpushoriginmastercountingobjects: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.git037b8ec..317b2a2master->master参考文档:http://www.wfuyu.com/technology/25144.html
哪个云平台服务器便宜重磅会议有亿联“云 端” 信息传递更清楚ftp服务器云盘区别购买了腾讯云服务器后怎么用钉钉发布春雷计划 亿元补贴助力100区县数字化要在从新空间开不出来啊-市场咨询阿贝云服务器怎么用小白必看技术:懒猫聊动态网页和静态网页的特点