已经会用Git了?不会这十招怎么行

已经会用Git了?不会这十招怎么行

之前我们发了一些教程让你熟悉Git基础在团队合作环境中使用Git.我们讨论的这些Git命令足够让一个开发者在Git的世界里生存下去。在这篇教程里,我们试着探索如何高效地管理你的时间以及如何充分利用Git提供的特性。

注意:这里介绍的命令中有的包含方括号(例如:git add -p [file_name])。在这些例子中,你应该用你自己的数字、标识符等替代方括号里的内容,并且去掉方括号。

1. Git自动补全

如果你在命令行环境中运行Git命令,每次都手动地逐个输入命令是一件很无聊的事。为此,你可以花几分钟时间配置一下Git命令的自动补全功能。

在*nix系统运行下列命令下载自动补全脚本:


  1. cd ~
  2. curl https://raw.github.com/git/git/master/contrib/completion/git-completion.bash -o ~/.git-completion.bash

然后,添加下面的行到你的~/.bash_profile文件:


  1. if [ -f ~/.git-completion.bash ]; then
  2. . ~/.git-completion.bash
  3. fi

尽管我之前已经提到过,但我还是想再强调一下:如果你想使用完整的Git特性,你绝bi应该切换到命令行环境。

2. 在Git中忽略文件

你是不是对出现在你Git库里面的编译生成文件(比如.pyc)感到很无语?或者你是不是很厌恶不小心将他们添加到了Git?直接看这里,这里有一个方法可以让你告诉Git忽略所有这些文件和目录。只需要创建一个名字为.gitignore的文件,里面列出你不想要Git跟踪的文件和目录。可以用感叹号(!)列出例外情况。


  1. *.pyc
  2. *.exe
  3. my_db_config/
  4.  
  5. !main.pyc

3. 谁动了我的代码?

当事情出了乱子时立马责怪别人这是人类的天性。如果你的服务器程序不能正常工作了,要找出罪魁祸首是非常简单的--只需要执行git blame。这个命令告诉你文件里的每一行的作者是谁,最后改动那一行的提交,以及提交的时间戳。


  1. git blame [file_name]

git blame demonstration

在下面的截图里,你可以看到在一个更大的库里这个命令的输出是什么样的:

git blame on the ATutor repository

4. 查看库的历史

在之前的教程里,我们已经看过了如何使用git log命令。不管怎样,有3个选项你应该知道。

  • --oneline - 压缩每次的提交信息,只保留一个缩减的Hash值和说明文字,然后把这些都展示在一行里。
  • --graph - 这个选项将在左边画出一个文字界面的提交历史图。如果你只有一个分支,用这个选项查看历史时是没什么意义的。
  • --all - 显示所有分支历史。

这是这3个选项合起来使用的效果:

Use of git log with all, graph and oneline

5. 不要丢失对某个提交的跟踪

假设你提交了一些不需要的东西,然后你进行了hard重置回到之前的状态。后来,你发现在这个过程中你丢失了其他一些重要的信息,你想要把这些信息找回来,或者至少可以查看一下这些信息。这就需要git reflog帮忙。

简单的git log只能告诉你最近的提交,这个提交的父提交,父提交的父提交,等等。但是git reflog是一个HEAD指向的提交的列表。记住,这个列表依赖于你自己的本地操作环境,它不是库的一部分,也不包含在push或者merge中。

如果执行git log命令,可以看到提交历史,这是我的库的一部分:

Project history

但是,git reflog命令显示了一个被我用hard重置丢掉的提交(b1b0ee9-HEAD@{4}).

Git reflog

6. 暂存文件的一部分更改以便进行一次提交

通常依据特性来提交是一个好的实践方法,意思是说,每一个提交都只添加一个特性或者修复一个bug。想一下如果你一次修复了两个bug或者添加了两个特性但是都还没有逐个提交该怎么办。这种场景下,你可以将他们一起提交。但是有一个更好的办法:单独暂存这些文件,然后分开提交。

让我们假设你对一个文件做了多个更改,然后想让这些更改分开提交。这时,我们用带-p的添加命令。


  1. git add -p [file_name]

我们来试试这种用法。我添加了3个新行到file_name,但是我只想让第1行和第3行出现在我的提交里。让我们看看git diff的输出是什么样的。

Changes in repo

然后,我们看看带-p选项的add命令会发生什么。

Running add with -p

看起来Git认为所有的更改都是同一个目的的一部分,所以把他们分组到同一个块里。这时,你可以:

  • 输入 y 暂存块
  • 输入 n 不暂存块
  • 输入 e 手动编辑块
  • 输入 d 退出或者跳转到下一个文件
  • 输入 s 分割块

在我们这个例子中,我们想把这个块分割成更小的部分,然后选择其中一些忽略另外一些。

Adding all hunks

如你所见,我们已经逐个添加了第1和第3行,忽略了第2行。你可以看到库的状态并且进行一次提交。

Repository after selectively adding a file

7. 合并多个提交

为了进行核查或者发起一个合并请求(这经常发生在开源项目里),对代码进行了修改提交。但在最后代码被接受之前,你也许会需要修改你的代码。于是你修改代码,但是下一次核查的时候又一次需要进行修改。不知不觉中,你就已经有了好几个提交。理论上你应该用rebase命令把他们合并起来。


  1. git rebase -i HEAD~[number_of_commits]

如果你想合并最后的两次提交,你应该运行下面的命令。


  1. git rebase -i HEAD~2

一旦你运行这个命令,你将进入一个交互式界面,它将询问你想要合并哪些提交。你pick(拣选)最近的提交然后squash(合并)旧的提交。

Git squash interactive

接着你应该提供一个对新提交的说明。这个过程会重写你的提交历史。

Adding a commit message

8. 储藏没有提交的更改

假设你正在修复一个bug或者添加一个特性,突然你被要求展示一下你的工作成果。你现在的工作还没有完成,不够进行一次提交。这时,git stash命令可以用来急救一下。Stash命令跟踪你所有的更改,然后把他们储藏起来以便以后使用。命令如下-


  1. git stash

可以多次储藏更改,查看储藏列表,你可以运行下面的命令:


  1. git stash list

Stash list

如果你想取消储藏,覆盖当前的更改,你可以通过下面的命令使用储藏:


  1. git stash apply

在最后的这个截图里,你可以看到每个储藏都有一个标识符,是一个唯一的数字(尽管在这里我们只有一个储藏)。如果你想使用某个储藏,你在apply命令后面加上这个唯一的标识符:


  1. git stash apply stash@{2}

After un-stashing changes

9. 检查丢失的提交

尽管reflog是一种检查丢失提交的方法,大型的库里却不太实用。这个时候,应该用fsck(文件系统检查)命令。


  1. git fsck --lost-found

Git fsck results

这里你可以看到一个丢失的提交。你可以通过git show [commit_hash] 查看提交的更改或者通过运行git merge [commit_hash]命令进行恢复。

git fsck跟reflog命令相比有一个优点。假设你删除了一个远程分支,然后clone了这个库。用fsck命令你可以找到并且恢复这个删除的远程分支。

10. 最佳选择

之前我已经存记下了那些最优雅的Git命令。但是目前为止,cherry-pick命令是我最喜欢的Git命令,因为它直白的名字和实用的功能!

最简单的情况下,cherry-pick从另一个分支里选出单独的一个提交,然后合并到当前分支。如果你正并行工作在两个或者更多的分支上,你也许会发现一个存在于所有分支上的bug。如果你解决了一个分支上的这个bug,你可以拣选这个对应的提交应用到其他分支上,而不会弄乱其他文件或者提交。

让我们来考虑一个可以使用这个命令的场景。我有两个分支,我想拣选b20fd14: Cleaned junk这个提交到另一个分支上。

Before cherry pick

我切换到想要应用这个拣选出来的提交的分支,然后运行下面的命令:


  1. git cherry-pick [commit_hash]

After cherry pick

尽管这次我们很干净的用了cherry-pick命令,但你应该知道这个命令经常会引起冲突,所以请小心使用。

总结

到了这里,我们结束了这个能使你Git能力提升一个级别的列表。Git是最好的版本控制器,它能完成你能想象到的任何事情。所以,经常试着用Git挑战你自己。一不小心你就会学到很多新东西。

原文发布时间:2014-07-25

本文来自云栖合作伙伴“linux中国”

时间: 2024-09-17 02:29:20

已经会用Git了?不会这十招怎么行的相关文章

CentOS下Git的服务器版安装和使用

Git分布式版本控制系统: Git的使用体验,早已习惯了svn [集中式] 代码管理的吾,第一次接触分布式的git的时候,感觉很难使用,煎熬了一段时间,整个项目组,也是花费了很大的代价,就是出现代码被覆盖很多次,代码都不敢提交了! 记得在中国民航的时候,由于服务器硬件搬家过程中损坏,导致整个系统和代码全部丢失,不是很重要所以没有去做数据恢复,svn就挂了. 记得在金葵花的时候,由于svn服务器端口被抢占,导致没有启动,早上经理不在,没权限,所有,大家闲置了一早上. 使用了一段时间的git,使用过

Git回滚远程版本

"房子是租的 但生活不是" 1.故事的开始 远程master分支下代码被不小心提交了很多垃圾代码或项目删掉,想要回滚到以前的某一版本并删除commit log.怎么办?情景如图: 情景很简单.老板上传了个文件,我把他删掉了.有一种办法,把文件再push下,但是也不想他看到图中那comment(ps:这样我才不会被fire).实现上面场景的代码如下: vim A.txt git add . git commit -a -m "add A.txt" git push r

项目实践中--Git服务器的搭建与使用指南(转)

  一.前言 Git是一款免费.开源的分布式版本控制系统,用以有效.高速的处理从很小到非常大的项目版本管理.在平时的项目开发中,我们会使用到Git来进行版本控制. Git的功能特性: 从一般开发者的角度来看,git有以下功能: 1.从服务器上克隆数据库(包括代码和版本信息)到单机上. 2.在自己的机器上创建分支,修改代码. 3.在单机上自己创建的分支上提交代码. 4.在单机上合并分支. 5.新建一个分支,把服务器上最新版的代码fetch下来,然后跟自己的主分支合并. 6.生成补丁(patch),

Git & Github 一页简明笔记(转)main

由于小组工程需要使用git&github的版本控制来协作,但我对其使用并不熟悉,特此写篇一页的笔记放在手边,备随时查阅. 使用方法:常用命令供随时查阅,其余内容供新手了解.   0. 常用命令一览 # 配置仓库命令(项目名:play,项目发起者的名字:icedream61,URL=get@github.com:icedream61/play.git) git clone URL # 第一次克隆远程仓库,并关联:远程仓库 -> 本地仓库 git remote add origin URL #

详解Git图形界面的使用

图形界面 Git 的原生环境是终端. 在那里,你可以体验到最新的功能,也只有在那里,你才能尽情发挥 Git 的全部能力. 但是对于某些任务而言,纯文本并不是最佳的选择;有时候你确实需要一个可视化的展示方式,而且有些用户更习惯那种能点击的界面. 有一点请注意,不同的界面是为不同的工作流程设计的. 一些客户端的作者为了支持某种他认为高效的工作流程,经过精心挑选,只显示了 Git 功能的一个子集. 每种工具都有其特定的目的和意义,从这个角度来看,不能说某种工具比其它的"更好". 还有请注意,

[译] 保护我们的 Git Repos,立刻停止“狐步舞”

本文讲的是[译] 保护我们的 Git Repos,立刻停止"狐步舞", 原文地址:Protect our Git Repos, Stop Foxtrots Now! 原文作者:Sylvie Davies 译文出自:掘金翻译计划 本文永久链接:github.com/xitu/gold-m- 译者:LeviDing 校对者:薛定谔的猫,luisliuchao 狐步舞舞者 舞者们正准备跳狐步舞. 首先,什么是"狐步舞"式的合并? "狐步舞"式的合并是 

Git 系列(四):在 Git 中进行版本回退

在这篇文章中,你将学到如何查看项目中的历史版本,如何进行版本回退,以及如何创建 Git 分支以便你可以大胆尝试而不会出现问题. 在你的 Git 项目的历史中,你的位置就像是摇滚专辑中的一个片段,由一个被称为 HEAD 的 标记来确定(如磁带录音机或录音播放器的播放头).要在你的 Git 时间线上前后移动 HEAD ,需要使用 git checkout 命令. git checkout 命令的使用方式有两种.最常见的用途是从一个以前的提交中恢复文件,你也可以整个倒回磁带,切换到另一个分支. 恢复一

写好 Git Commit 信息的 7 个建议

介绍: 为什么好的提交信息如此重要 当你随意浏览任一 git 仓库的日志,你很可能会发现其中的提交信息或多或少有点乱.举个例子,瞧一瞧我早先提交到 Spring 上的这些宝贝: $ git log --oneline -5 --author cbeams --before "Fri Mar 26 2009" e5f4b49 Re-adding ConfigurationPostProcessorTests after its brief removal in r814. @Ignore

Git使用笔记

1.第一次使用github 1)github注册账号,网址:https://github.com/ 使用邮箱注册账号 先不要创建版本库   2)安装git Linux请参考网上教程,这里演示windows操作. 实际命令行操作基本是一样的.  msysgit 是Windows版的Git,从http://msysgit.github.io/下载,然后按默认选项安装即可. 官方下载比较慢,可以使用第三方下载点:msysgit_1.9.4.0_XiaZaiBa.zip 安装完成后,在开始菜单里找到"G