Git 创建一个完全没有提交历史的 master 分支

需求

本地有master、dev、test 等各个分支,远程公司代码库有 master 分支,现在不想让同事看到自己以前的提交记录,需要洗白远程的 master 分支,让别人不知道自己的提交记录或者得到的是删除了重要文件后的版本。

使用孤儿分支(Orphan Branch)

它会创建一个没有任何历史的全新分支,然后将 dev 分支的内容放进去,使其看起来就像是项目的第一次提交。

步骤如下:

  1. 确保 dev 分支最新:

    确保 dev 分支包含了你想要保留的最终代码状态。

    bash 复制代码
    git checkout dev
    git pull origin dev
  2. 创建全新的孤儿分支:

    使用 checkout --orphan 命令创建一个名为 new_master 的新分支。这个分支是"孤儿",意味着它不继承任何提交历史。

    bash 复制代码
    git checkout --orphan new_master

    执行后,你会发现分支虽然切换了,但工作区的文件还在,并且所有文件都处于"待添加"状态。

  3. 添加并提交所有文件:

    将所有文件添加到暂存区,并创建一个新的提交。这将是这个全新分支的第一个 ,也是唯一一个提交。

    bash 复制代码
    # 添加所有文件
    git add -A
    
    # 创建提交
    git commit -m "Initial commit"
  4. 删除旧的 master 分支:

    为了避免混淆,可以先删除本地的旧 master 分支。

    bash 复制代码
    git branch -D master
  5. 重命名新分支:

    将当前的新分支 new_master 重命名为 master

    bash 复制代码
    git branch -m master
  6. 强制推送到远程仓库:

    最后,将这个全新的、只有一次提交的 master 分支强制推送到远程,覆盖掉旧的 master 分支。

    bash 复制代码
    git push -f origin master

强调

请仅在个人项目或你完全确定后果并已通知所有协作者的情况下执行此操作。对于大多数项目来说,保留完整的提交历史远比拥有一个"干净"的历史重要得多。

相关推荐
weixin_3776348423 分钟前
【Git使用】PyCharm中的Git使用
ide·git·pycharm
爱吃泡芙的小白白2 小时前
vscode、anaconda、git、python配置安装(自用)
ide·git·vscode·python·anaconda·学习记录
ALex_zry8 小时前
Git大型仓库推送失败问题解决方案:大文件传输优化指南
git
草莓熊Lotso8 小时前
Git 分支管理:从基础操作到协作流程(本地篇)
大数据·服务器·开发语言·c++·人工智能·git·sql
w***Q35012 小时前
Git工作流自动化
运维·git·自动化
舒一笑17 小时前
GitPulse:让代码的故事自己讲述
git·程序员·intellij idea
5***o50018 小时前
Git在代码中的GitHub
git·github
还是会想她18 小时前
git 常见命令
git
1***y17820 小时前
Git在发布流程中的自动化标签
运维·git·自动化
逻辑棱镜1 天前
Git 分支管理与提交信息规范 (v1.0)
git·github·团队开发·代码规范·敏捷流程