问题背景:
    最近在重新整理手中的一个项目,目前该项目分为PC项目,手机项目,某第三方接口项目,第三方接口服务项目和手机项目
    因为之前规划的原因,原来的四个项目是分两个解决方案来管理的
    PC解决方案:
#PC解决方案,2015年从Vss迁移到Git 一共三个项目
#F:\WWW\F.COM\WWW
Flight.sln
Flight.suo
Web #PC项目 Qr #第三方接口项目 2015年新增项目,也使用PC解决方案但用分支进行管理,维护单独的通用项目,目前已经将通用项目分离到单独的分支进行单独维护(仅添加要引用的Dll即可)
QunarTTS #第三方接口服务项目2015年新增项目,也使用PC解决方案但用分支进行管理,维护单独的通用项目,目前已经将通用项目分离到单独的分支进行单独维护(仅添加要引用的Dll即可) #所有通用项目,仅 PC&手机&第三方项目提供统一的支持
BLL
Model
Common
WebHelp
SqlServerDAL
DBUtility
Languages
FlightAPI #机票Api Mobile #手机项目,需要从另一解决方案合并过来

  

 
手机解决方案:
#手机解决方案,所有DLL都会引用PC通用项目的DLL
#因为当时考虑手机跟PC的View和大部分功能不一样,所以单独一个解决方案来做
#F:\WWW\F.COM\Mobile
WebApp
WebApp.csproj #手机项目
WebApp.sln #解决方案
WebApp.suo

  

 
因为最近客户的业务有所调整,所以涉及到以上四个全部的项目,在处理的时候出现了以下问题
  1. 因为 PC,第三方接口,接口服务都共同维护了通用项目,所以导致我频繁在这三个项目之前切换合并(保存通用项目文件一致) 已解决
  2. 手机解决方案同其他项目一样,都使用同一通用项目的Dll但不单独维护,为什么要独立一个解决方案,决定合并到PC解决方案以分支的方式管理
于是我就开始尝试对以上问题进行解决
  1. 将PC,第三方接口,接口服务等所有通用项目从三个分支里分离到单独的分支里统一管理
    其他项目如果要更改通用文件必须切换到分支然后生成再切换回来重新添加新的Dll即可(确保通用项目文件一致性)
  2. 将手机解决方案中的项目合并到PC解决方案里,然后以新的分支Mobile进行维护
问题1已经解决,当我在把手机解决方案的项目合并到PC解决方案里,遇到此问题:
GIT 如何合并另一个远程Git仓库的文件到本地仓库里某个指定子文件夹并不丢失远程提交记录?
 
我这样获取远程Git的信息"git pull remote-address"时,手机项目文件是在PC仓库的根目录"F:\WWW\F.COM\WWW" 而我希望手机项目文件是在该根目录下Mobile目录下的“F:\WWW\F.COM\WWW\Mobile”
经过我反复测试和使用其他命令fetch等都没有解决,于是把自己的问题发在了群里,在跟群友沟通了N个小时后也没有解决我的问题,不过某个群友说可以使用subtree子目录的方式试试
于是在网上找各种资料做各种测试,终于经过二天的时间完成解决问题
 
合并必须满足以下条件:
1.必须完整的合并远程仓库(手机项目)的所有文件和提交记录本地仓库(PC项目)
2.远程的所有文件必须是在本地指定的目录“F:\WWW\F.COM\WWW\Mobile”而不是在本地仓库的根目录
3.合并后只有一个git仓库(将远程提交合并到本地提交)“F:\WWW\F.COM\WWW\.git”
 
以下为真实测试的信息:
  1. 在本地新建Git仓库
  2. 在新仓库添加文件和更改,产生提交历史(也可以创建分支,Tag等)
  3. 在本地创建新分支并切换(栗子中直接在master操作的)
  4. 使用“git remote add -f demo2 f:\demo\d2”添加远程仓库 (demo2为远程仓库名, f:\demo\d2为远程仓库地址),将会获取远程提交历史,但没有远程文件
  5. 使用“git subtree add --prefix=d/2  f:\demo\d2 master --squash”引入外部仓库, --prefix=d/2 为在本地创建的子目录(子目录如果存在需要删除),后面是远程地址和分支名, 将会pull远程文件到本地目录如f:\w\d\2
  6. 使用“git merge -s subtree demo2/master”合并远程分支到当前分支,demo2/master 为 远程仓库/远程分支名
  7. 使用“git remote remove demo2”删除远程仓库分支,并删除合并自远程仓库的所有分支和Tag(不删除会出现 "demo2/master"这样的分支和Tag)
  8. 在本地进行操作,提交commit .....
 
 
使用“git remote remove demo2”删除远程仓库分支
 
 
感谢群里的朋友和网上的资料!
 
参考:

使用 git-subtree 以子目录形式引入外部项目    Git submodule VS Git Subtree    Git Subtree命令剖析    使用 git subtree 來分拆子目錄成獨立的新 repo

 

GIT 如何合并另一个远程Git仓库的文件到本地仓库里某个指定子文件夹并不丢失远程提交记录?的更多相关文章

  1. 键盘录入一个文件夹路径,统计该文件夹(包含子文件夹)中每种类型的文件及个数,注意:用文件类型(后缀名,不包含.(点),如:"java","txt")作为key, 用个数作为value,放入到map集合中,遍历map集合

    package cn.it.zuoye5; import java.io.File;import java.util.HashMap;import java.util.Iterator;import ...

  2. 在存放源程序的文件夹中建立一个子文件夹 myPackage。例如,在“D:\java”文件夹之中创建一个与包同名的子文件夹 myPackage(D:\java\myPackage)。在 myPackage 包中创建一个YMD类,该类具有计算今年的年份、可以输出一个带有年月日的字符串的功能。设计程序SY31.java,给定某人姓名和出生日期,计算该人年龄,并输出该人姓名、年龄、出生日期。程序使用YM

    题目补充: 在存放源程序的文件夹中建立一个子文件夹 myPackage.例如,在“D:\java”文件夹之中创建一个与包同名的子文件夹 myPackage(D:\java\myPackage).在 m ...

  3. 创建局域网内远程git仓库,并将本地仓库push推到远程仓库中

    转载请注明出处 http://www.goteny.com/articles/2014/06/136.html http://www.cnblogs.com/zjjne/p/3778640.html ...

  4. git只合并某一个分支的某个commit

    第一种情况:只合并一个commit git checkout develop-hbb git cherry-pick 7c32be61 以上,7c32be61是develop上的一个fix bug的c ...

  5. git提交空文件夹和删除远程文件

    git提交空文件夹 在文件夹中创建 .gitkeep 文件,文件内容如下 # Ignore everything in this directory * # Except this file !.gi ...

  6. git强制合并另一个分支

    New分支和Old分支都修改了同样的部分,有冲突,但是想在Old分之上合并New分支的内容,并且以New分支为主,就是不自己手动解决冲突,碰到冲突,直接以New分支为主. 参考 https://git ...

  7. Git拉取远程仓库代码并更新本地仓库

    1.git pull:获取最新代码到本地,并自动合并到当前分支 //查询当前远程分支 $ git remote -v //直接拉取并合并最新代码 $ git pull origin master [示 ...

  8. Git 将子文件夹分离为一个新的库

    前面的需求 公司Android的项目上,想要将一些module抽取出来,作为一个可以被其它项目上使用的. 所以使用了git submodule的方案. 为了将代码库中的一个文件夹分离后,作为一个单独的 ...

  9. 通过创建临时表合并某一个库的hive小文件

    #!/bin/bash #需要指定hive中的库名 #set -x set -e DB=$1 if [ -z $1 ];then echo "Usage:$0 DbName" ex ...

随机推荐

  1. CentOS 7使用通过二进制包安装MySQL 5.7.18

    安装依赖 yum install -y libaio 下载 wget https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.18-linux- ...

  2. WebMvcConfigurerAdapter已经过时的问题解决

    spring 5开始已经废弃WebMvcConfigurerAdapter,替代的是WebMvcConfigurer接口. 参考: https://blog.csdn.net/lenkvin/arti ...

  3. Software UART, Timer, PWM, External Interrupt

    How can you add extra hardware UARTs to a 32bit TMS470 ARM7-based microcontroller at zero cost? Solu ...

  4. AES advanced encryption standard 3

    This optimized <../aesbench/> AES implementation conforms to FIPS-. aes.h #ifndef _AES_H #defi ...

  5. linux 内核升级2 转

    linux内核升级 一.Linux内核概览 Linux是一个一体化内核(monolithic kernel)系统. 设备驱动程序可以完全访问硬件. Linux内的设备驱动程序可以方便地以模块化(mod ...

  6. Revit API封装一个通用函数“过名称找元素”

    感觉这个函数不错.通过这种方式寻找元素经常需要用到. )         {  ];         }         // cannot find it.         return null; ...

  7. [Winform]默认以管理员身份运行程序

    摘要 在使用setupfactory打包之后,想让程序默认以管理员身份运行,因为涉及到创建文件删除文件的操作,如果权限比较低的话,会出现没有权限操作的bug. 解决办法 在项目中找到app.manif ...

  8. 查看内核页表kernel_page_tables (aarch32)

    作者 彭东林 pengdonglin137@163.com   平台 Linux-4.10.17 Qemu + vexpress-ca9     概述 通过配置内核,会在/sys/kernel/deb ...

  9. [转]浅论ViewController的加载 -- 解决 viewDidLoad 被提前加载的问题(pushViewController 前执行)

    一个ViewController,一般通过init或initWithNibName来加载.二者没有什么不同,init最终还是要调用initWithNibName方法(除非这个ViewControlle ...

  10. [Android实例] Handler+ExecutorService(线程池)+MessageQueue模式+缓存模式

    android线程池的理解,晚上在家无事 预习了一下android异步加载的例子,也学习到了一个很重要的东东 那就是线程池+缓存  下面看他们的理解. [size=1.8em]Handler+Runn ...