Git常用命令备忘

不用git简直就是反人类啊。
不过没有能力一下子把所有的命令都记住,先把常用的几个列下,具体的后面用到了再查。

示意图

git-map

  • remote
  • repository
  • index
  • workspace

-图中的remote是远程仓库,而repository、index和workspace都是在你本地。
remote还可以分为trunk repository和your own github repository。
如果你觉得别人的工程很好,想在此基础上嫁接自己的开发,那么fork一下,就会到你自己的github工程列表中。这些remote都是有独立的地址的,比如git自己的代码,提供一个唯一的地址供大家fork:

https://github.com/git/git.git   

-图中的repository是本地仓库,如果这个本地仓库刚刚被初始化,还是空的,那么我们需要clone一下远程仓库。
如果这个本地仓库是以前就创建好的,我们开发代码之前,应该取得(fetch)远程仓库remote的更新。

-图中的workspace是工作区,就是具体的代码文件。
-图中的index是暂存区,代码某个版本开发好后,需要add进index,就是告诉仓库,我修改了哪些文件,将会提交哪些文件。
此时使用commit命令来提交文件。
最后,把修改从本地仓库repository推送(push)到远程仓库(remote)。

1.git clone

重要的事情在前面说,clone之前需要init!

$ cd proj-dir
$ git init

clone命令会在本地主机生成一个目录,与远程主机的版本库同名。
如果要指定不同的目录名,可以将目录名作为git clone命令的第二个参数。

$ git clone <版本库的网址>
$ git clone <版本库的网址> <本地目录名>

比如,克隆jQuery的版本库。

$ git clone https://github.com/jquery/jquery.git

clone支持HTTP(s)、SSH、Git、FTP等协议。

2.git remote

git remote命令列出所有远程主机。
克隆版本库的时候,所使用的远程主机自动被Git命名为origin。

$ git remote
origin

使用-v选项,可以参看远程主机的网址。

$ git remote -v
origin  git@github.com:jquery/jquery.git (fetch)
origin  git@github.com:jquery/jquery.git (push)

如果想用其他的主机名,需要用git clone命令的-o选项指定。

$ git clone -o jQuery https://github.com/jquery/jquery.git
$ git remote
jQuery

3.git fetch

如果远程仓库的代码有更新,我们需要将这些更新取到本地。
通常建议在修改本地代码前做这件事。

$ git fetch <远程主机名>
$ git fetch <远程主机名> <分支名>

如果不指定分支名,则取回所有分支的更新。
如果指定分支名,则仅取回指定分支的更新。

那么,我怎么知道取哪个分支?
git branch命令的-r选项,可以用来查看远程分支,-a选项查看所有分支。

$ git branch -r
origin/master

$ git branch -a
* master
remotes/origin/master

上面的命令表示,本地主机的当前分支是master,远程分支是origin/master。

fetch只能从远程仓库取得代码,还没有合并到本地的代码中去。需要使用git merge命令或者git rebase命令,在本地分支上合并远程分支。

$ git merge origin/master
# 或者
$ git rebase origin/master

可是可是,如果我不想合并到现在的分支上怎么办呢。可以使用git checkout命令创建一个新的分支。

$ git checkout -b newBrach origin/master

上面命令表示,在origin/master的基础上,创建一个新分支。

4.git pull

取回远程主机某个分支的更新,并且与本地的指定分支合并。
同最开始的图上看,是不是相当于fetch+checkout?

$ git pull <远程主机名> <远程分支名>:<本地分支名>
$ git pull origin next:master

表示取回origin主机的next分支,与本地的master分支合并。
如果远程分支是与当前分支合并,则冒号后面的部分可以省略。

$ git pull origin next

也就是先做git fetch,再做git merge。

$ git fetch origin
$ git merge origin/next

5.git add

把修改信息添加到index暂存区。
添加所有文件:

$ git add -A

添加指定文件到暂存区:

$ git add <文件1> <文件2>

也可以指定文件夹:

$ git add <文件夹>

删除文件,并且将删除信息也添加到暂存区:

$ git rm <文件1> <文件2>

重命名,并且将重命名信息也添加到暂存区:

$ git mv <原文件名> <新文件名>

6.git commit

把暂存区的修改,提交到仓库:

$ git commit -m "信息"

原则上是,每一个原子修改,都作一次提交。

7.git push

将本地分支的更新,推送到远程主机。

$ git push <远程主机名> <本地分支名>:<远程分支名>   

通常本地分支名和远程分支名都同名,可以省略远程分支名。

$ git push origin master

表示将本地的master分支推送到origin主机的master分支。

其他

显示暂存区和工作区的差异:

$ git diff    

显示有变更的文件:

$ git status

参考

1.阮一峰 Git远程操作详解
2.阮一峰 常用 Git 命令清单
3.廖雪峰 Git教程
4.Git官方文档
5.Git常用命令一览
git-cmd