当前位置: 首页 > news >正文

清除 git 所有历史提交记录,使其为新库

清除 git 所有历史提交记录,使其为新库

    • 需求
    • 方案

需求

基于以前的仓库重新开发,这样可保留以前的配置等文件,但是需要删除全部的历史记录、tag、分支等。

方案

  1. 创建新的分支

    使用 --orphan 选项,可创建1个干净的分支(无任何的提交历史,但是当前分支的内容一应俱全)。但严格意义上说,这样创建的分支还不是一个真正的分支,因为 HEAD 指向的引用中没有 commit 值,只有在进行一次提交后,它才算得上真正的分支。

    git checkout --orphan new_branch
    
  2. 添加所有文件

    git add .
    
  3. 提交代码

    git commit -m '新仓库'
    
  4. 删除原来的主分支 master

    一般仓库默认的主分支为 master 分支,如果原来的主分支不是 master, 用实际的主分支名代替。

    git branch -D master
    
  5. 把当前分支重命名为 master

    git branch -m master
    
  6. 最后把代码推送到远程仓库

    有些仓库有 master 分支保护,不允许强制 push,需要在远程仓库项目里暂时把项目保护关掉才能推送。
    推送前需要使用 git remote -v 查看关联的远程仓库的信息(主要是远程库的别名)。虽然远程库的别名默认是 origin ,但你可能设置过其他的别名(而非 origin)。

    git push -f origin master
    
  7. 测试仓库是否可用

    git pull
    

    如果别人不能拉取代码,可以使用

    git pull -r
    
  8. 测试提交历史是否清除

    # 1.查看提交日志
    git log --pretty=oneline# 2.查看分支信息
    # 列出所有本地分支
    git branch
    # 列出所有远程分支
    git branch -r
    # 列出所有本地分支和远程分支
    git branch -a# 3.查看 tag 信息
    # 查看本地标签
    git tag
    # 查看远程标签
    git ls-remote --tags
    

若在第 6、7 步遇到类似下面的问题:
在这里插入图片描述
可以通过 git branch --set-upstream-to=origin/master master 命令解决

http://www.lryc.cn/news/5661.html

相关文章:

  • pyTorch下载和cuda下载以及学习笔记
  • 【学习总结】IMU预积分推导
  • 天猫商城自动化python脚本(仅供初学者学习使用)
  • 代码随想录第十一天(459)
  • 线程及线程池学习
  • SpringBoot整合(四)整合Ehcache、Redis、Memcached、jetcache、j2cache缓存
  • 想要的古风女生头像让你快速get
  • 传统企业数字化转型,到底难在哪里?
  • Python:青蛙跳杯子(BFS)
  • 6.10 谱分解
  • MySQL入门篇-MySQL 行转列小结
  • 项目管理常见的十大难题及其症状
  • 技术方案模板
  • MySQL中对于单表和多表的操作
  • MFI认证
  • Vue中mixins的使用
  • 【PyQt】PyQt学习(一)框架介绍+环境搭建
  • 浅谈前端设计模式:策略模式和状态模式的异同点
  • 线性杂双功能PEG试剂OPSS-PEG-Acid,OPSS-PEG-COOH,巯基吡啶聚乙二醇羧基
  • 开发微服务电商项目演示(四)
  • 【C语言学习笔记】:静态库
  • 社科院与杜兰大学中外合作办学金融管理硕士——30+的年龄在职读研有必要吗?
  • 2.13作业【设备树解析,按自己理解】
  • 《NFL星计划》:巴尔的摩乌鸦·橄榄1号位
  • Allegro如何设置自动保存和自动保存的时间操作指导
  • Kotlin实现简单音乐播放器
  • ShardingSphere-Proxy 数据库协议交互解读
  • 基于ubuntu20.4的wine的MDK5软件的安装
  • Jmeter之直连数据库框架搭建简介
  • 备战蓝桥杯【高精度乘法和高精度除法】