Git回滚远程版本
2016-04-08 22:49
344 查看
摘要: 原创出处:www.bysocket.com 泥瓦匠BYSocket 希望转载,保留摘要,谢谢!
“房子是租的 但生活不是”
情景很简单。老板上传了个文件,我把他删掉了。有一种办法,把文件再push下,但是也不想他看到图中那comment(ps:这样我才不会被fire)。实现上面场景的代码如下:
————–分割线 ————–
一头雾水的小白怎么办?怎么办?怎么办?
push到远程的提交默认是不能修改的,但是一定要修改不是不行:
》》工作区:就是我们操作的目录
》》暂存区:操作目录的快照
》》本地版本库:Git的精髓,人人都是中央仓库。也就是Git分布式的好处,自然对比SVN这种集中式
》》远程版本库:Github这种中央仓库,可以达到共享。
常用的操作也如图所示,不言而喻了。
详解如下:
第1行:git log 查看提交历史,然后找到要回滚的版本。历史如下,
我们想要回滚到的版本就是:72bd6304c3c6e1cb7034114db1dd1b8376a6283a
第2行:git reset –soft 72bd6304c3c6e1cb7034114db1dd1b8376a6283a
撤销到某个版本之前,之前的修改退回到暂存区(不懂看漂亮的图哦~)。soft 和 hard参数的区别就是,hard修改记录都没了,soft则会保留修改记录。
第3行:暂存为了安全起见。
第4行:git push -f
将本地master push 到远程版本库中, -f 强制覆盖。
git push -f 强制push覆盖
微 博:BYSocket 豆 瓣:BYSocket FaceBook:BYSocket Twitter :BYSocket
“房子是租的 但生活不是”
1.故事的开始
远程master分支下代码被不小心提交了很多垃圾代码或项目删掉,想要回滚到以前的某一版本并删除commit log。怎么办?情景如图:情景很简单。老板上传了个文件,我把他删掉了。有一种办法,把文件再push下,但是也不想他看到图中那comment(ps:这样我才不会被fire)。实现上面场景的代码如下:
vim A.txt
git add .
git commit -a -m "add A.txt"
git push
rm A.txt
git commit -a -m "我删除了老板的东西"
git push
————–分割线 ————–
一头雾水的小白怎么办?怎么办?怎么办?
push到远程的提交默认是不能修改的,但是一定要修改不是不行:
git push -f
2.解决之道
2.1工作区,暂存区,本地版本库 & 远程版本库
No pic say 个 78。。。》》工作区:就是我们操作的目录
》》暂存区:操作目录的快照
》》本地版本库:Git的精髓,人人都是中央仓库。也就是Git分布式的好处,自然对比SVN这种集中式
》》远程版本库:Github这种中央仓库,可以达到共享。
常用的操作也如图所示,不言而喻了。
2.2 实战解决
Talk is cheap,Show me the code or money~ 代码如下:git log
git reset --soft ${commit-id}
git stash
git push -f
详解如下:
第1行:git log 查看提交历史,然后找到要回滚的版本。历史如下,
commit 84686b426c3a8a3d569ae56b6788278c10b27e5b
Author: JeffLi1993 <qiangqiangli1993@gmail.com>
Date: Fri Apr 8 19:11:32 2016 +0800
我删除了老板的东西
commit 72bd6304c3c6e1cb7034114db1dd1b8376a6283a
Author: JeffLi1993 <qiangqiangli1993@gmail.com>
Date: Fri Apr 8 19:05:23 2016 +0800
add A.txt
我们想要回滚到的版本就是:72bd6304c3c6e1cb7034114db1dd1b8376a6283a
第2行:git reset –soft 72bd6304c3c6e1cb7034114db1dd1b8376a6283a
撤销到某个版本之前,之前的修改退回到暂存区(不懂看漂亮的图哦~)。soft 和 hard参数的区别就是,hard修改记录都没了,soft则会保留修改记录。
第3行:暂存为了安全起见。
第4行:git push -f
将本地master push 到远程版本库中, -f 强制覆盖。
3. 小结
git reset 回滚到某个版本之前git push -f 强制push覆盖
微 博:BYSocket 豆 瓣:BYSocket FaceBook:BYSocket Twitter :BYSocket
相关文章推荐
- Codeforces Round #149 (Div. 2) E. XOR on Segment (线段树成段更新+二进制)
- STL配置器(四)----内存池技术
- hdu1796(容斥原理)
- 该网站的安全证书吊销信息不可用
- 无比奇怪的问题,Runtime报错,程序仍可运行(有可能是线程崩溃,但主程序不崩溃,线程崩溃可能是因为锁使用不当引起的)
- URAL 1991 The battle near the swamp 水题
- andorid 多线程handler用法
- MyBatis (7)——Mybatis缓存
- poj3069 贪心
- cocos2d-x 2.x 场景切换、事件处理
- Source Insight通过快捷按键添加多种代码注释
- stm32的定时器
- Switch case
- 结队编程之"做汉堡"
- web框架--bottle
- str和repr的区别
- 对软件工程需求分析及创新项目等实际问题给提出建议或意见
- Frameworks.Entity.Core 5 EntityValidation
- 代码复审核查表
- data process for large scale datasets