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

强调

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

相关推荐
AIMath~2 小时前
如何将一个新的文件夹使用git 工具提交到github新仓库中
git·github
满天星83035772 小时前
【Git】原理及使用(二) (版本回退)
linux·git
愿天垂怜3 小时前
【C++脚手架】ffmpeg 库的介绍与使用
linux·服务器·开发语言·c++·ide·git·ffmpeg
月夜的风吹雨3 小时前
Linux 基础开发工具详解:从 yum 到 gdb 实战指南
linux·git·ubuntu·centos·vim
好运yoo3 小时前
git cherry-pick
git
不是光头 强4 小时前
Obsidian Git 插件安装与配置完全指南
git
.千余4 小时前
【C++】C++核心语法:函数重载与缺省参数原理与避坑
c语言·开发语言·c++·经验分享·笔记·git·学习
meowrain5 小时前
Git HTTPS Token 凭据配置指南
git·网络协议·https
Ws_16 小时前
Git + Gerrit 第二课:diff、暂存区与撤销修改
git
snowjlz17 小时前
鸿蒙版SVN来了!!!
git·svn·版本控制