目录
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