Git 版本管理
应用情景1:添加文件(单个、多个、目录)到Git版本库,提交一个版本快照。
应用情景2:穿越历史回到过去,版本回退,从当前版本回退到之前提交过的某个版本上。
应用情景3:穿越历史过头了,版本回退多了,目的时间是2000年,结果硬是穿到了1900年,没办法,又得从1900年穿越到"未来"的2000年。
情景1:
假设有一个目录 work ,里面三个文件:file1、file2、file3:
git add work/file1 # 添加单个文件到版本库
git add work/file1 work/file2 work/file3 # 添加多个文件到版本库
git add work/ # 添加整个目录到版本库
git add . # 添加所有文件到版本库(.gitignore忽略的文件除外)
git commit -m "add file1 file2 file3" # 提交版本快照
情景2:
假设从项目开发到现在,一共提交了3个版本快照到Git版本库(3次有效的 git commit),分别是
git commit -m "first commit"
git commit -m "second commit"
git commit -m "third commit"
当前我们便是在最新版本(也就是最后一次提交的版本 "third commit")上进行开发,假设突然发现 "third commit" 版本存在重大问题,需要回退到"之前某个版本"上重新开发:
# 第一步:找到之前提交的某个版本的 commit id
git log # 查看历史提交记录,里面有 commit id 信息
git log --pretty=oneline # 简化版的历史提交记录 # commit id类似于 "5c6c438396bd9db4f24d299fc68f3150ec81b2f8" 这样的字符串 # 根据 commit id 回退到指定版本
git reset --hard
git reset --hard 5c6c438396bd9db4f24d299fc68f3150ec81b2f8 # 没必要写全,写前几位即可,但是要保证Git能够根据你提供的信息找到唯一的 commit id
回退版本的另外一种方法:Git中有一个特殊的指针HEAD,永远指向当前版本,所以,可以用HEAD表示上一个版本HEAD^,上上个版本HEAD^^,向上几个版本就在HEAD后面加写几个^,当然,写太多的^不现实,所以向上100个版本可简写为HEAD~100,其它可依此类推。
git reset --hard HEAD^ # 回退到上个版本
git reset --hard HEAD^^ # 回退到上上个版本
git reset --hard HEAD~ # 回退到100个版本之前
当前版本(third commit)回退到某个版本 (first commit)后,当前版本就是 first commit。查看历史提交记录,只会有 first commit 及之前的提交记录,就仿佛是 second commit 版本和 third commit 版本是一种幻觉,从来就没有提交过一样。
情景3:
在情景2中,回退到了 first commit 版本上后发现回退多了,此时想要再回到 "未来 second commit 版本" 或是 "未来 third commit 版本"
# 版本可以自由回退穿越,但是所有的git操作都会被git按顺序记录下来,必然有某个命令可以查看历史操作。
git reflog # 查看历史操作记录,从中可以找到所有真实提交过的 commit id # 假设 second commit 版本 id 是 6w59a45,third commit 版本 id 是 8m334k2
git reset --hard 6w59a45 # 从 first commit 版本穿越到"未来" second commit 版本
git reset --hard 8m334k2 # 从 first commit 版本穿越到"未来" third commit 版本
总结:所有提交过的版本都会被Git如实的记录下来并分配独一无二的 commit id,在版本间来回穿越的关键就是想方设法找到目的版本的 commit id。
Git 版本管理的更多相关文章
- Git 版本管理的简单理解
来源:百度知道 现在使用Git版本管理代码的项目非常多.但是Git本身是一条复杂的系统.我从几个简单的点来说明Git的基本功能.希望能帮助初学者快速入门. 工具/原料 Git code dot j ...
- GIT版本管理工具
原文:http://blog.csdn.net/ithomer/article/details/7527877 Git 是一个分布式版本控制工具,它的作者 Linus Torvalds 是这样给我们介 ...
- git学习——<四>git版本管理
一.git版本管理的优势 都说git比svn强大,强大在哪呢? 首先,从部署上说:svn.cvs都是集中式的,一台服务器上部署服务,所有客户端编写的代码都要提交到该服务器上.git是分布式的,所有人都 ...
- Git——版本管理工具(一)
Git 是一个分布式版本控制工具,它的作者 Linus Torvalds 是这样给我们介绍 Git —— The stupid content tracker(傻瓜式的内容跟踪器) 1. Git 背 ...
- Git 版本管理工具(一)
转自:http://blog.csdn.net/ithomer/article/details/7527877 Git 是一个分布式版本控制工具,它的作者 Linus Torvalds 是这样给我们介 ...
- GIT版本管理工具教程
目录 GIT版本管理工具教程 一 Git初始化 二 简单指令使用 基本操作 简单总结 三 Git进阶 Git三大区域 Git回滚 Git分支 Git工作流 四 Github代码管理仓库 第一步:注册G ...
- [工具] Git版本管理(知识总结)
对以下文档进行了简要总结,方面复习: [工具] Git版本管理(一)(基本操作) [工具] Git版本管理(二)(分支) [工具] Git版本管理(三)(工作流) [工具] Git版本管理(四)(贡献 ...
- [工具] Git版本管理(四)(贡献开源代码、git配置、git免密、gitignore)
一.开源项目贡献代码 1.fork项目代码 例如,我们想向tornado框架贡献代码,首先搜索tornado. 然后,将tornado的代码fork到我们的仓库中. 2.clone到本地进行开发 克隆 ...
- 开启我的python之路,第一节,git版本管理工具
git版本管理工具 一.git功能与结构 1.Git是分布式管理系统,服务端和客户端都有版本控制功能,都能进行代码的提交,合并 2.git分为工作区,暂存区,本地仓库和远程仓库 二.git安装与查看 ...
- git版本管理策略及相关技巧(A)
公司几乎所有的项目都是使用 git 仓库来管理代码,以前对 git 只有些肤浅的了解,每次提交代码或者上线的时候总是会提心吊胆,生怕出现一些未知的问题.经过三个月的踩坑和填坑, git 操作颇显成熟. ...
随机推荐
- 在主方法中定义一个大小为10*10的二维字符型数组,数组名为y,正反对角线上存的是‘*’,其余 位置存的是‘#’;输出这个数组中的所有元素。
//在主方法中定义一个大小为10*10的二维字符型数组,数组名为y,正反对角线上存的是‘*’,其余 位置存的是‘#’:输出这个数组中的所有元素. char [][]y=new char [10][10 ...
- 使用Reveal查看任意App的技巧
转:http://www.jianshu.com/p/4dc8f94ca27c 前言 Reveal(http://revealapp.com)是一个很强大的iOS View Hierarchy工具,与 ...
- Cocos2dx.3x入门三部曲-软件环境配置(一)
一.环境: Win7 32位 二.必备软件: l Java JDK 下载地址:http://www.oracle.com/technetwork/java/javase/downloads/inde ...
- AngularJs应用页面切换优化方案(转)
目录[-] 前言 场景 使用resolve来提前请求数据 为页面加入切换动画 总结 葡萄城的一款尚在研发中的产品,对外名称暂定为X项目.其中使用了已经上市的wijmo中SpreadJS产品,另外,在研 ...
- madown标签说明
1.删除线的用法 ~~这是删除线~~
- web项目中加入struts2、spring的支持,并整合两者
Web项目中加入struts2 的支持 在lib下加入strut2的jar包 2. 在web.xml中添加配置 <filter> <filter-name>struts2< ...
- MapReduce的一点理解
对于MapReduce编程,大概率的流程用过的人或多或少都清楚,但是归结到细节上,就有的地方不清楚了,下面根据自己的疑问,加上从网上各处,找到的被人的描述,最自己的疑问做出回答. 1. MapRedu ...
- Oracle 数据同步系列--触发器
现在随着项目集成的越来越深入,异构的数据多起来,数据同步的场景也用的多起来,我甚至在考虑是否忽悠用户上Oracle GoldenGate了,这样就可以不用考虑采用哪种同步方案了. 简单的介绍一下我们数 ...
- 国内 Composer 镜像收集
本文转载自: https://www.insp.top/article/composer-mirror-image 常见的: { "repositories": [ {" ...
- 多线程锁--怎么理解Condition
在java.util.concurrent包中,有两个很特殊的工具类,Condition和ReentrantLock,使用过的人都知道,ReentrantLock(重入锁)是jdk的concurren ...