git other-误删恢复等
修改未push的最后一次commit
如在commit后发现漏添加的文件或者commit message需要修改,则可以依次执行:
git add FILE_UN_STAGED # 将未提交的文件添加至缓存区
git commit --amend # 弹出文本编辑器,按需修改提交信息
删除错误的提交 commit
git reset --hard <commit_id>
git push origin HEAD --force
删除已经提交的 ignore 文件
有时候我们想忽略某些文件的提交,在.gitignore文件中声明后并不能直接生效,因为该文件已经被track:
git rm --cached file 再commit,如果不加--cached则在本地工作区也会被删掉.
回退文件版本
git 回退某些文件到之前提交的版本
git checkout COMMIT_ID -- FILE_LISTS
如回退到导数第二次提交COMMIT_ID可以写作HEAD~1
恢复误删文件
从之前的版本中检出这个文件,然后重新添加到版本库中,再作为一个新的提交来挽救:
git checkout HEAD^ -- a.txt
其中HEAD^ 代表上一次提交,
-- a.txt 表示将上一次提交里的a.txt文件检出到工作区,这样a.txt就回来了。
接着:
git add a.txt && git commit -m "recover a.txt" && git push
合并两个仓库
示例:将repo2合并到repo1
cd repo1
git remote add other ../repo2 # 这里repo2地址可以是本地目录也可以是网络地址,设置别名为other
git fetch other # 从repo2仓库中抓取数据到本仓库
git checkout -b repo2 other/master # 将repo2仓库的master分支作为新分支checkout到本地,新分支名设定为repo2
此时当前的分支的remote地址是原repo2的,可以在这个分支上向repo2继续提交代码,
如果想将当前分支提交到repo1的新远程分支,使用git push -u origin <新远程分支的名字>
git checkout master
git merge repo2 # 将新分支合并到master
如果不需要原repo2的remote的话,执行git remote remove repo2,执行git remote可以查看到remote列表,或者查看.git/config中的文件内容。
在合并时有可能两个分支对同一个文件都做了修改,这时需要解决冲突,对文本文件来说很简单,根据需要对冲突的位置进行处理就可以。对于二进制文件,需要用到如下命令。
git checkout --theirs BINARY_FILES // 保留需要合并进来的分支的修改
git checkout --ours BINARY_FILES // 保留自己的修改
git add BINARY_FILES
若是文件有冲突、或要建立子目录,建议在repo1中先解决,再进行合并操作。
存储/从文件系统检索
一些项目(例如 Git 项目自身)直接在 Git 文件系统中存储额外的文件而不必是检入文件。
让我们开始在 Git 中存储一个任意文件:
$ echo "Foo" | git hash-object -w --stdin
51fc03a9bb365fae74fd2bf66517b30bf48020cb
此时,该文件对象已在数据库中,但是如果你不设置(一些东西)指向那个文件对象,它将被作为垃圾而回收。最简单的方法是标记它:
$ git tag myfile 51fc03a9bb365fae74fd2bf66517b30bf48020cb
既然在这里我们已经标记了 myfile。当我们需要获取该文件时,我们可以这样做:
$ git cat-file blob myfile
程序员可能经常用到的工具文件(密码、GPG 密钥、等等),不需要每次都检出到磁盘上(特别是在生产环境下),这种方法非常有效。
代理
- 设置代理
git config –global http.proxy http://127.0.0.1:8080
git config –global https.proxy http://127.0.0.1:8080
git config --global http.proxy socks5://127.0.0.1:8443
git config --global https.proxy socks5://127.0.0.1:8443 - 取消代理
git config --global --unset http.proxy
git config --global --unset https.proxy
不加global只适用于当前仓库。
git clone 加速完成
git clone --depth 1 <repository>
depth可以控制clone的历史记录层级,显然clone最新的提交占用空间最小,这对于大型工程的clone会体现出时间的缩短。
git fetch也一样。
git设置postBuffer: git config --global http.postBuffer 524288000
能加上传大文件,且有时候能加速clone速度(从十几k到300kb/s)
git other-误删恢复等的更多相关文章
- git stash 暂存恢复和文件误删恢复
git commit提交文件,服务器返回本地文件有修改. 1.git stash :暂存本地代码 2.git pull origin develop : 获取远程分支代码 3.git stash po ...
- git 签出(恢复)指定文件
在项目开发中,偶尔会因为误删文件或其他原因需要从git仓库中恢复某些文件.此篇文章将介绍如何通过git从历史提交记录.分支记录恢复指定文件. 1. git checkout 说明:使用git chec ...
- 团队项目管理:Github项目误删恢复记录
参考: 准备更换git托管,如何迁移原git仓库 Github项目误删恢复记录 今天正常上线打卡,发现组织的线上Github仓库被误删了..本来是一场悲剧,所幸在本地的垃圾箱中翻出了还没有删除的本地仓 ...
- linux 下文件误删恢复
linux 下文件误删恢复 0x01 事件背景 某天晚上写代码的时候,本来想删除当前目录下一个叫xxx的文件夹 rm -rdf ./xxx/*, 结果光顾着和人说话,一不留神手贱把命令敲成了rm -r ...
- GIT仓库如何恢复到前一次提交
GIT仓库如何恢复到前一次提交 通过使用Git版本恢复命令reset,可以回退版本.reset命令有3种方式: git reset –mixed:此为默认方式,不带任何参数的git reset,即 ...
- Linux MBR扇区误删恢复
目录 1. 引导记录误删恢复 1.1 备份引导记录 1.2 误删引导记录 1.3 恢复引导记录 2. 分区表误删恢复 2.1 备份分区表 2.2 误删分区表 2.3 恢复分区表 如果MBR分区表没了, ...
- Git 将代码恢复到一个历史的版本
Git 将代码恢复到一个历史的版本 要把代码回到某个历史版本 比如 test有两种方法 暴力的方式 如果你的仓库是自己在用(不影响别人),那么你可以使用 git reset --hard <ta ...
- Git提交与恢复
Git提交与恢复 提交修改 git add --all # 提交所有修改文件 git add file file # 提交部分修改文件 $ git status On branch master Yo ...
- git中误删提交(commit)后,怎么恢复
“xml文件存储数据”提交被我误操作,即使用reset --hard删除了,然后又进行了三次提交,发现删除的提交有用,需要找回来, 于是找了好久,找到好方法: 1.进入工程下的.git文件下,git ...
随机推荐
- controlfile作为RMAN的repository时,对 keep time 的测试
4月2日,首先查看系统状况: SQL> show parameter control NAME TYPE VALUE ...
- [ZJOI2018]保镖
[ZJOI2018]保镖 Tags:题解 题意 链接 初始在平面上有一些点,九条可怜随机出现在一个矩形内的任意一点.若九条可怜出现在\(O\)点,则平面上所有的点都从\(P_i\)移动到\(P'_i\ ...
- 让vim成为VS的编辑器
编辑代码是还是感觉vim的比较方便--于是让vim成为VS的编辑器. 发现,安装了VsVim之后,也不失VS的便捷性,相当不错呢-- 对了我用的是VS2012---- 1.菜单栏->工具-> ...
- 【php增删改查实例】 第三节 - mysql 建表
这一节,来给数据库中添加一些测试数据. 登陆mysql: 找到%xampp%\mysql\bin 目录, 在此处打开命令窗口,用root用户登陆mysql 用户表建表sql: CREATE TABLE ...
- TMS320VC5509的DAC输出TLV5620
1. TLV5620的SPI数据是11位的 但是看图3和图4,感觉用2个字节应该也可以的,不知道行不行,可以试一试吧 2. 不过可惜的是5509A的SPI没有11位的,有点麻烦,只能先试试用两个字节行 ...
- 【分享】Java学习之路:不走弯路,就是捷径
1.如何学习程序设计? JAVA是一种平台,也是一种程序设计语言,如何学好程序设计不仅仅适用于JAVA,对C++等其他程序设计语言也一样管用.有编程高手认为,JAVA也好C也好没什么分别,拿来就用.为 ...
- tornado学习笔记
一.UIMOTHODS: 1.在项目目录创建uimothods.py文件(名称可以任意)内容: def test2(self): return ('hello uimothods') 2.tornad ...
- Flume的简单理解
由于没具体研究过画图,以前在公司每天都用Excel,所以很多图画都是画在了Excel上再剪切的,看着可能不太舒服. 先来看一下数据走向: 这样我们就大致了解了flume是干嘛的,在什么位置了. Flu ...
- Kubernetes并发控制与数据一致性的实现原理
在大型分布式系统中,定会存在大量并发写入的场景.在这种场景下如何进行更好的并发控制,即在多个任务同时存取数据时保证数据的一致性,成为分布式系统必须解决的问题.悲观并发控制和乐观并发控制是并发控制中采用 ...
- PHP 设计模式六大原则
http://www.cnblogs.com/yujon/p/5536118.html 设计模式六大原则(1):单一职责原则 不要存在多于一个导致类变更的原因.通俗的说,即一个类只负责一项职责 设计模 ...