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

强调

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

相关推荐
stevenzqzq1 天前
git 常用操作
大数据·git
Curvatureflight1 天前
Git工作流最佳实践:从混乱到优雅
git
wu~9701 天前
GitHub永不遗忘,使用git push -f来覆盖的提交依旧保留
git·github
Vermouth_001 天前
git clone的时候提示access denied
git
qq_437657271 天前
清楚本地的git并重新登录
git
jiang_changsheng1 天前
工作流agent汇总分析 2
java·人工智能·git·python·机器学习·github·语音识别
顶点多余1 天前
版本控制器-git
linux·git
夔曦1 天前
Git工程日常下拉/上传完整流程(自用)
git
岱宗夫up1 天前
GitHub Desktop如何设置中文?这不是个简单问题
git·github
岱宗夫up1 天前
.env 文件是干啥的?为什么不能提交到 Git?
大数据·git·elasticsearch·搜索引擎·gitee·github·gitcode