zoukankan      html  css  js  c++  java
  • git拆分仓库

    1.git filter-branch拆分当前分支

    • 修改仓库目录,改成拆分后的结构
    • 创建一个当前分支的拷贝分支
    • git filter-branch -f --tag-name-filter cat --prune-empty --subdirectory-filter publish HEAD 运行命令,把publish目录下的内容和历史记录拆分到当前目录,删除所有其他的文件和历史记录,HEAD是当前分支
    • 创建新的远程仓库
    • 设置当前的remote为新创建的仓库 git remote set-url origin git@192.168.1.1:test.git
    • 把当前分支推送到远程的master git push -u origin test:master
    • 切换到原来的分支
    • 设置回来原来的远程仓库
    • 删除测试分支

    2.git filter-branch拆分仓库所有分支

    参考 https://printempw.github.io/splitting-a-subfolder-out-into-a-new-git-repository/

    git filter-branch --tag-name-filter cat --prune-empty --subdirectory-filter <name-of-folder> -- --all

    这条命令同样会过滤所有历史提交,只保留所有对指定子目录有影响的提交,并将该子目录设为该仓库的根目录。
    这里说明各下个参数的作用:
        --tag-name-filter 该参数控制我们要如何处理旧的 tag,cat 即表示原样输出;
        --prune-empty 删除空的(对子目录没有影响的)提交;
        --subdirectory-filter 指定子目录路径;
        -- --all 该参数必须跟在 -- 后面,表示对所有分支进行操作。如果你只想保存当前分支,也可以不添加此参数

    3.git subtree拆分当前分支

    拆分仓库也可以使用subtree更方便

    git subtree split -P <name-of-folder> -b <name-of-new-branch>

    subtree是把一个分支拆分到另一个分支,这样的话操作起来更方便,不会改写原来分支的内容

    总结

    git filter-branch操作的时候会修改当前分支,也就是在当前分支的基础上做了一个切分,然后提交创建了一个修改。所以为了避免污染原来的分支,建议一个分支一个分支的操作,并且操作前,最好是切一个临时分支。

  • 相关阅读:
    asp.net的尖括号绑定字段总结
    在 ASP.NET 中实现不同角色的用户使用不同登录界面的方法
    同一个页面内根据分类查询
    利用修改AccessDataSource的sql语句来检索数据
    ADO.NET站内模糊搜索
    又是一个新阶段
    完成一个测试的小功能实践题
    苦心志,劳筋骨,饿体肤,乏其身,乱其所为
    毕业设计进入收尾阶段
    两种模糊过滤关键字的方法
  • 原文地址:https://www.cnblogs.com/studywithallofyou/p/11771730.html
Copyright © 2011-2022 走看看