我们在初次使用Git时,我们一般是作为使用者从第三方(github、oschina、gitcafe(已被coding收购)、阿里云code……)仓库拉取或提交代码的,我们并不用深究他是怎样建立的,我们首先要学会的是如何去使用,那么现在我们就从第一条指令开始学习Git的使用。
git clone:第一条git命令,获取仓库
$ git clone <版本库的网址>
执行如上命令会直接在本地建立一个与目标地址相同的git仓库,由于git使用的是分布式版本控制,因此任何人获取的仓库都是完整的。如果你觉得使用原有的仓库名不能让你满意,我们还可以使用git clone的第二个参数,这会让你建立一个以该参数为目录名的git仓库。
$ git clone <版本库的网址> <本地目录名>
git clone 可以后接网址,并且支持多种协议,无论是HTTP(s),还是SSH、Git、本地文件协议等,都可以在git上使用,如:
$ git clone http[s]://example.com/path/to/repo.git/ $ git clone ssh://example.com/path/to/repo.git/ $ git clone git://example.com/path/to/repo.git/ $ git clone /opt/git/project.git $ git clone file:///opt/git/project.git $ git clone ftp[s]://example.com/path/to/repo.git/ $ git clone rsync://example.com/path/to/repo.git/
这里还有另一种ssh协议的使用方法,我们公司平时使用的就是这种
$ git clone [user@]example.com:path/to/repo.git/
另外,如果访问一个Git URL需要用法名和密码,可以在Git URL前加上用户名,并在它们之间加上@符合以表示分割,然后执行git clone命令,git会提示你输入密码。
示例
git clone usrname@http://www.example.com/git.git
这样将以作为usrname用户名访问http://www.example.com/git.git,然后按回车键执行git clone命令,git会提示你输入密码。
另外,我们可以通过-b <name>来指定要克隆的分支名,比如:
$ git clone -b master2 ../server
表示克隆名为master2的这个分支,如果省略-b <name>表示克隆master分支。类似的参数还有好多,具体请自行阅读官方文档。
git clone [--template=<template_directory>] [-l] [-s] [--no-hardlinks] [-q] [-n] [--bare] [--mirror] [-o <name>] [-b <name>] [-u <upload-pack>] [--reference <repository>] [--separate-git-dir <git dir>] [--depth <depth>] [--[no-]single-branch] [--recursive|--recurse-submodules] [--] <repository> [<directory>]
git add :添加文件到缓存区
$ git add <文件名> 或者 $ git add *
添加指定文件到缓存区,或者将所有的修改提交到文件缓存区。
git conmit:提交更改
$ git commit -m 'Implemented my_strlen function' 或 $ git conmit
使用git conmit命令提交更改前,请确保仓库中所有的修改均已缓存。
如果直接使用git conmit提交,会弹出文本编辑器,需要在文本编辑器中填写提交信息,如果使用 -m 选项,可以不调用文本编辑器,直接在后方直接将提交信息写入并完成提交。
git pull:从远程获取最新版本并merge(合并)到本地
git pull拉取命令,无论是提交后推送前必须的步骤,还是远程仓库更新后对应的更新本地命令,都会用到此命令。它的作用是,取回远程主机某个分支的更新,再与本地的指定分支合并。它的完整格式稍稍有点复杂。
常用命令,直接从远程获取最新版本并与当前分支自动合并,该段落最后部分有详解
$ git pull
↑上一条命令的完全版↓:
$ git pull <远程主机名> <远程分支名>:<本地分支名>
比如,取回origin主机的next分支,与本地的master分支合并,需要写成下面这样。
$ git pull origin next:master
如果远程分支是与当前分支合并,则冒号后面的部分可以省略。
$ git pull origin next
上面命令表示,取回origin/next分支,再与当前分支合并。实质上,这等同于先做git fetch,再做git merge。
$ git fetch origin //这条命令的含义是从远程获取最新的版本但是并不做任何处理 $ git merge origin/next //此命令为合并新版本与当前的origin/next分支
在某些场合,Git会自动在本地分支与远程分支之间,建立一种追踪关系(tracking)。比如,在git clone的时候,所有本地分支默认与远程主机的同名分支,建立追踪关系,也就是说,本地的master分支自动”追踪”origin/master分支。
Git也允许手动建立追踪关系。
git branch --set-upstream master origin/next
上面命令指定master分支追踪origin/next分支。
如果当前分支与远程分支存在追踪关系,git pull就可以省略远程分支名。
$ git pull origin
git push:将本地版本推送到远程仓库
请先解决合并冲突再提交,提交会改变远程仓库的内容,请谨慎处理,确认无误再提交。
git push命令用于将本地分支的更新,推送到远程主机。它的格式与git pull命令相仿,但是目标相反。
一般情况我们可以直接使用这条命令不加任何参数,但我们需要知道他的完整格式。
$ git push <远程主机名> <本地分支名>:<远程分支名>
注意,分支推送顺序的写法是<来源地>:<目的地>,所以git pull是<远程分支>:<本地分支>,而git push是<本地分支>:<远程分支>。
如果省略远程分支名,则表示将本地分支推送与之存在”追踪关系”的远程分支(通常两者同名),如果该远程分支不存在,则会被新建。
$ git push origin master
上面命令表示,将本地的master分支推送到origin主机的master分支。如果后者不存在,则会被新建。
如果省略本地分支名,则表示删除指定的远程分支,因为这等同于推送一个空的本地分支到远程分支。
$ git push origin :master # 等同于 $ git push origin --delete master
上面命令表示删除origin主机的master分支。
如果当前分支与远程分支之间存在追踪关系,则本地分支和远程分支都可以省略。
$ git push origin
上面命令表示,将当前分支推送到origin主机的对应分支。
如果当前分支只有一个追踪分支,那么主机名都可以省略。
$ git push
如果当前分支与多个主机存在追踪关系,则可以使用-u选项指定一个默认主机,这样后面就可以不加任何参数使用git push。
$ git push -u origin master
上面命令将本地的master分支推送到origin主机,同时指定origin为默认主机,后面就可以不加任何参数使用git push了。
不带任何参数的git push,默认只推送当前分支,这叫做simple方式。此外,还有一种matching方式,会推送所有有对应的远程分支的本地分支。Git 2.0版本之前,默认采用matching方法,现在改为默认采用simple方式。如果要修改这个设置,可以采用git config命令。
$ git config --global push.default matching # 或者 $ git config --global push.default simple
还有一种情况,就是不管是否存在对应的远程分支,将本地的所有分支都推送到远程主机,这时需要使用–all选项。
$ git push --all origin
上面命令表示,将所有本地分支都推送到origin主机。
如果远程主机的版本比本地版本更新,推送时Git会报错,要求先在本地做git pull合并差异,然后再推送到远程主机。这时,如果你一定要推送,可以使用–force选项。←但我希望你永远不会使用这个选项,请安正常流程办事。
近期评论