版本控制(七)--git使用

新建git仓库

有两种取得 Git 项目仓库的方法。第一种是在现存的目录下,通过导入所有文件来创建新的 Git 仓库。第二种是从已有的 Git 仓库克隆出一个新的镜像仓库来。

在工作目录中初始化新仓库

要对现有的某个项目开始用 Git 管理,只需到此项目所在的目录,执行:
$ git init
初始化后,在当前目录下会出现一个名为 .git 的目录,所有 Git 需要的数据和资源都存放在这个目录中。不过目前,仅仅是按照既有的结构框架初始化好了里边所有的文件和目录,但我们还没有开始跟踪管理项目中的任何一个文件。(在第九章我们会详细说明刚才创建的.git 目录中究竟有哪些文件,以及都起些什么作用。)
如果当前目录下有几个文件想要纳入版本控制,需要先用 git add 命令告诉 Git 开始对这些文件进行跟踪,然后提交:
$ git add .c $ git add README $ git commit -m ‘initial project version*

从现有仓库克隆

如果想对某个开源项目出一份力,可以先把该项目的 Git 仓库复制一份出来,这就需要用到 git clone 命令。如果你熟悉其他的 VCS 比如 Subversion,你可能已经注意到这里使用的是 clone 而不是 checkout。这是个非常重要的差别,Git 收取的是项目历史的所有数据(每一个文件的每一个版本),服务器上有的数据克隆之后本地也都有了。实际上,即便服务器的磁盘发生故障,用任何一个克隆出来 的客户端都可以重建服务器上的仓库,回到当初克隆时的状态(虽然可能会丢失某些服务器端的挂钩设置,但所有版本的数据仍旧还在)。

克隆仓库的命令格式为 git clone [url]。比如,要克隆 Ruby 语言的 Git 代码仓库 Grit,可以用下面的命令:
$ git clone git://github.com/schacon/grit.git
这会在当前目录下创建一个名为“grit”的目录,其中包含一个 .git 的目录,用于保存下载下来的所有版本记录,然后从中取出最新版本的文件拷贝。如果进入这个新建的grit 目录,你会看到项目中的所有文件已经在里边了,准备好后续的开发和使用。如果希望在克隆的时候,自己定义要新建的项目目录名称,可以在上面的命令末尾指定新的名字:
$ git clone git://github.com/schacon/grit.git mygrit
唯一的差别就是,现在新建的目录成了 mygrit,其他的都和上边的一样。

Git 支持许多数据传输协议。之前的例子使用的是 git:// 协议,不过你也可以用 http(s):// 或者user@server:/path.git 表示的 SSH 传输协议。我们会在第四章详细介绍所有这些协议在服务器端该如何配置使用,以及各种方式之间的利弊。

git status文件状态

git status 命令。
该命令输出信息包括:

  1. 所在分支
  2. 已经commits,可以push的;
  3. Changes to be committed:(已经暂存,用commit命令);
  4. Changes not staged for commit:(用add命令,变为staged)
  5. Unmerged paths:冲突的文件(用add命令,变为staged)
  6. Untracked files:未追踪的文件(用add命令,变为staged)
    eg:
On branch master
Your branch is ahead of 'origin/master' by 5 commits.
  (use "git push" to publish your local commits)
Changes to be committed:
  (use "git reset HEAD <file>..." to unstage)
    ......
Changes not staged for commit:
  (use "git add <file>..." to update what will be committed)
  (use "git checkout -- <file>..." to discard changes in working directory)
    ......
Unmerged paths:
  (use "git add/rm <file>..." as appropriate to mark resolution)
Untracked files:
  (use "git add <file>..." to include in what will be committed)
  ......

git add

该命令用途:
1. 已经tracked的,做修改了,变为staged待提交;
2. 未tracked的,变为staged待提交;
3. 冲突的,变为staged待提交;
注意,有时候,一个文件X做修改了,使用了git add命令,该文件X出现在了staged区域;此后再次修改X的话,用status命令查看,X文件出现了两次!一次算未暂存,一次算已暂存,这怎么可能呢?好吧,实际上 Git 只不过暂存了你运行 git add 命令时的版本,如果现在提交,那么提交的是添加注释前的版本,而非当前工作目录中的版本。所以,运行了git add 之后又作了修订的文件,需要重新运行 git add 把最新版本重新暂存起来。

.gitignore

一般我们总会有些文件无需纳入 Git 的管理,也不希望它们总出现在未跟踪文件列表。通常都是些自动生成的文件,比如日志文件,或者编译过程中创建的临时文件等。我们可以创建一个名为 .gitignore 的文件,列出要忽略的文件模式(注:.gitignore文件跟.git目录在同一个根目录下)。
使用:

  1. 所有空行或者以注释符号 #开头的行都会被忽略(即不起作用)。
  2. 可以使用标准的 glob 模式匹配。

所谓的 glob 模式是指 shell 所使用的简化了的正则表达式。星号()匹配零个或多个任意字符;[abc] 匹配任何一个列在方括号中的字符(这个例子要么匹配一个 a,要么匹配一个 b,要么匹配一个 c);问号(?)只匹配一个任意字符;匹配模式最后跟反斜杠(/)说明要忽略的是目录;指定模式以外的文件或目录,可以在模式前加上惊叹号(!)取反。例子:

#此为注释
*.a  #忽略所有 .a 结尾的文件 
!lib.a  #但 lib.a 除外 
/TODO   #仅仅忽略项目根目录下的 TODO 文件,不包括subdir/TODO
build/  #忽略build/ 目录下的所有文件 
doc/*.txt #会忽略 doc/notes.txt 但不包括doc/server/arch.txt

git diff

  • 该命令不过是显示还没有暂存起来的改动,而不是这次工作和上次提交之间的差异。所以有时候你一下子暂存了所有更新过的文件后,运行git diff 后却什么也没有,就是这个原因;
  • 若要看已经暂存起来的文件和上次提交时的快照之间的差异,可以用 git diff –cached 命令

git commit

git commit。如果使用git commit -a,则,Git 就会自动把所有已经跟踪过的文件暂存起来一并提交,从而跳过 git add 步骤。-m 参数后面跟说明。

git rm

要从 Git 中移除某个文件,就必须要从已跟踪文件清单中移除(确切地说,是从暂存区域移除),然后提交。可以用 git rm 命令完成此项工作,并连带从工作目录中删除指定的文件,这样以后就不会出现在未跟踪文件清单中了。

如果只是简单地从工作目录中手工删除文件,运行 git status 时就会在 “Changed but not updated” 部分(也就是未暂存清单)看到。这个时候用git rm将文件从tracked中移除。之后提交,该文件就不再纳入版本管理了。如果删除之前修改过并且已经放到暂存区域的话,则必须要用强制删除选项 -f(译注:即 force 的首字母),以防误删除文件后丢失修改的内容。

另外一种情况是,我们想把文件从 Git 仓库中删除(亦即从暂存区域移除),但仍然希望保留在当前工作目录中。换句话说,仅是从跟踪清单中删除。比如一些大型日志文件或者一堆.a 编译文件,不小心纳入仓库后,要移除跟踪但不删除文件,以便稍后在 .gitignore 文件中补上,用 –cached 选项即可:git rm –cached file后面可以列出文件或者目录的名字,也可以使用 glob 模式。比方说:$ git rm log/*.log。

git mv

当你看到 Git 的 mv 命令时一定会困惑不已。要在 Git 中对文件改名,可以这么做:
$ git mv file_from file_to
它会恰如预期般正常工作。
其实,运行 git mv 就相当于运行了下面三条命令:
$ mv README.txt README $ git rm README.txt $ git add README

git log

会按提交时间列出所有的更新,最近的更新排在最上面。每次更新都有一个 SHA-1 校验和、作者的名字和电子邮件地址、提交时间,最后缩进一个段落显示提交说明。
-p 选项展开显示每次提交的内容差异,
-2 则仅显示最近的两次更新:
–stat,仅显示简要的增改行数统计(哪些文件作修改了,可以看到)

git撤销

  • $ git commit –amend:有时候我们提交完了才发现漏掉了几个文件没有加,或者提交信息写错了。想要撤消刚才的提交操作,可以使用 –amend 选项重新提交。
    1. 如果刚才提交完没有作任何改动,直接运行此命令的话,相当于有机会重新编辑提交说明,但将要提交的文件快照和之前的一样。
    2. e.g:$ git commit -m ‘initial commit’ $ git add forgotten_file $ git commit –amend
      上面的三条命令最终只是产生一个提交,第二个提交命令修正了第一个的提交内容。
  • git reset HEAD file:取消暂存;
  • git checkout file:取消修改;

仓库

git remote

git remote:它会列出每个远程库的简短名字。
1.在clone完某个项目后,至少可以看到一个名为 origin 的远程库,Git 默认使用这个名字来标识你所克隆的原始仓库;
2.-v 选项(–verbose ),显示对应的克隆地址;

git remote add

git remote add [shortname] [url]:给远程仓库添加一个简单名字,以便之后使用

git remote show

git remote show [remote-name] :查看某个远程仓库的详细信息。
1.会告诉远程仓库地址;
2.会告诉远程仓库分支情况;
3.会告诉git pull/push不带参数时远程仓库跟本地分支的绑定情况;

git fetch

$ git fetch <远程主机名>:将某个远程主机的更新,全部取回本地。
1.默认情况下,git fetch取回所有分支(branch)的更新。如果只想取回特定分支的更新,可以指定分支名。
2.$ git fetch <远程主机名> <分支名>:比如,取回origin主机的master分支。eg:$ git fetch origin master
所取回的更新,在本地主机上要用”远程主机名/分支名”的形式读取。比如origin主机的master,就要用origin/master读取。

$ git checkout -b newBrach origin/master
//在origin/master的基础上,创建一个新分支:
$ git merge origin/master
//表示在当前分支上,合并origin/master

说明:如果设置了某个分支用于跟踪某个远端仓库的分支,可以使用 git pull 命令自动抓取数据下来,然后将远端分支自动合并到本地仓库中当前分支。实际上,默认情况下git clone 命令本质上就是自动创建了本地的 master 分支用于跟踪远程仓库中的 master 分支(假设远程仓库确实有 master 分支)。所以一般我们运行git pull,目的都是要从原始克隆的远端仓库中抓取数据后,合并到工作目录中的当前分支。

git pull

git pull:取回远程主机某个分支的更新,再与本地的指定分支合并。
格式:$ git pull <远程主机名> <远程分支名>:<本地分支名>。

  1. 如果远程分支是与当前分支合并,则冒号后面的部分可以省略。
    $ git pull origin next
    相当:
    $ git fetch origin
    $ git merge origin/next
  2. 在某些场合,Git会自动在本地分支与远程分支之间,建立一种追踪关系(tracking)。比如:在git clone的时候,所有本地分支默认与远程主机的同名分支,建立追踪关系,也就是说,本地的master分支自动”追踪”origin/master分支。
    Git也允许手动建立追踪关系。
    git branch –set-upstream master origin/next //上面命令指定master分支追踪origin/next分支。
  3. 如果当前分支与远程分支存在追踪关系,git pull就可以省略远程分支名。
    $ git pull origin //上面命令表示,本地的当前分支自动与对应的origin主机”追踪分支”(remote-tracking branch)进行合并。
    如果当前分支只有一个追踪分支,连远程主机名都可以省略。

git push

git push命令用于将本地分支的更新,推送到远程主机。
格式:$ git push <远程主机名> <本地分支名>:<远程分支名>

  1. 分支推送顺序的写法是<来源地>:<目的地>,所以git pull是<远程分支>:<本地分支>,而git push是<本地分支>:<远程分支>。
  2. 如果省略远程分支名,则表示将本地分支推送与之存在”追踪关系”的远程分支(通常两者同名),如果该远程分支不存在,则会被新建。
    $ git push origin master
    上面命令表示,将本地的master分支推送到origin主机的master分支。如果后者不存在,则会被新建。
  3. 如果省略本地分支名,则表示删除指定的远程分支,因为这等同于推送一个空的本地分支到远程分支。
    $ git push origin :master == $ git push origin –delete master
    上面命令表示删除origin主机的master分支。
  4. 如果当前分支与远程分支之间存在追踪关系,则本地分支和远程分支都可以省略。
    $ git push origin
    上面命令表示,将当前分支推送到origin主机的对应分支。
  5. 如果当前分支只有一个追踪分支,那么主机名都可以省略
    $ git push
  6. 如果当前分支与多个主机存在追踪关系,则可以使用-u选项指定一个默认主机,这样后面就可以不加任何参数使用git push。
    $ git push -u origin master
    上面命令将本地的master分支推送到origin主机,同时指定origin为默认主机,后面就可以不加任何参数使用git push了。
  7. 不带任何参数的git push,默认只推送当前分支,这叫做simple方式。此外,还有一种matching方式,会推送所有有对应的远程分支的本地分支。Git 2.0版本之前,默认采用matching方法,现在改为默认采用simple方式。如果要修改这个设置,可以采用git config命令。
    $ git config –global push.default matching or $ git config –global push.default simple

标签

  1. 列出现有标签:git tag;
  2. 新建标签(含附注的):git tag -a 标签名 -m ‘message’;
  3. 分享标签(推送到远程):–tags参数:git push origin –tags
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值