git的基本教程

来源:互联网 发布:ppt 展示数据 特效 编辑:程序博客网 时间:2024/05/23 01:43

项目开发的时候,往往不是一个人都能搞得定所有的代码,而是需要一个团队,大家的协作.此时,一个好的代码管理工具就显得尤为的重要.git 和svn同样都是代码管理工具,他们的区别在哪里?优缺点又在哪里呢?

  1. svn是集中式的版本控制工具
    集中式的版本控制系统,版本库是集中存放在中央服务器的,所以我们需要先从中央服务器取得最新版本,开发完毕,又要把自己代码提交到服务器.集中式版本控制系统最大的毛病就是必须联网才能工作,如果在局域网内还好,带宽够大,速度够快,可如果在互联网上,遇到网速慢的话,那一天基本上不用做多少工作了…

  2. git是分布式的版本管理工具
    而分布式版本控制根本没有”中央服务器”,每个人的电脑上都是一个完整的版本库,这样工作的时候就不需要联网了,和集中式版本控制系统相比,分布式版本控制系统的安全性要高很多,因为每个人的电脑里都有一个完整的版本库,这样,如果你的代码出了问题,可以直接拉取同事的代码,但是集中式的版本控制工具就不同了,如果中央服务器出了问题,那么所有的人都不用干活了.

git管理工具的优点

  1. 离线,速度更快
  2. 比SVN 更小(git比较节省空间。举例来说,一个Django项目如果使用现行的源代码控制系统(source control systems)来实现版本控制的话,git克隆(clone)是最小的。)
  3. 快照,而不是变更集(跟其他的VCS工具不同,git是基于快照的。不再是考虑将提交点存储成补丁文件,而是在你提交项目的时候对项目做一个简单的快照。)
  4. 分支和合并(git最显著的一个特点就是它的分枝模型了,因为它改变了开发者工作的基本模式)

git的安装:
下载地址: 
http://www.kernel.org/pub/software/scm/git/
安装过程:

$ tar xzvf git-1.6.5$ cd git-1.6.5$ ./config --prefix=/usr/local$ make
$ sudo make install
$ git --version

如果需要命令帮助的话,可以键入’-help’就会显示出
操作手册。你也可以键入’git help command’实现同样的目的。

$ git log --help$ git help log

第一步创建版本库
什么是版本库呢?版本库又名仓库,英文名repository,你可以简单理解成一个目录,这个目录里面的所有文件都可以被Git管理起来,每个文件的修改、删除,Git都能跟踪,以便任何时刻都可以追踪历史,或者在将来某个时刻可以“还原”。
所以,创建一个版本库非常简单,首先,选择一个合适的地方,创建一个空目录:

$ mkdir learngit$ cd learngit$ pwd/Users/michael/learngit

第二步,通过git init命令把这个目录变成Git可以管理的仓库:

$ git initInitialized empty Git repository in /Users/michael/learngit/.git/

瞬间Git就把仓库建好了,而且告诉你是一个空的仓库(empty Git repository),细心的读者可以发现当前目录下多了一个.git的目录,这个目录是Git来跟踪管理版本库的,没事千万不要手动修改这个目录里面的文件,不然改乱了,就把Git仓库给破坏了。

使用Windows的童鞋要特别注意:
千万不要使用Windows自带的记事本编辑任何文本文件。原因是Microsoft开发记事本的团队使用了一个非常弱智的行为来保存UTF-8编码的文件,他们自作聪明地在每个文件开头添加了0xefbbbf(十六进制)的字符,你会遇到很多不可思议的问题,比如,网页第一行可能会显示一个“?”,明明正确的程序一编译就报语法错误,等等,都是由记事本的弱智行为带来的。建议你下载Notepad++代替记事本,不但功能强大,而且免费!记得把Notepad++的默认编码设置为UTF-8 without BOM即可.

现在我们编写一个readme.txt文件,内容如下:

Git is a version control system.Git is free software.

(ps 一定要放到learngit目录下(子目录也行),因为这是一个Git仓库,放到其他地方Git再厉害也找不到这个文件。)

第一步,用命令git add告诉Git,把文件添加到仓库:

$ git add readme.txt

执行上面的命令,没有任何显示,这就对了,Unix的哲学是“没有消息就是好消息”,说明添加成功。

第二步,用命令git commit告诉Git,把文件提交到仓库:

$ git commit -m "wrote a readme file"[master (root-commit) cb926e7] wrote a readme file 1 file changed, 2 insertions(+) create mode 100644 readme.txt

git的基本命令:

  • git pull :从其他的版本库将代码更新到本地
  • git add: 是将当前更改或者新增的文件加入到Git的索引中,加入到Git的索引中就表示了记入了版本历史,这也是提交之前所需要执行的一步
  • git rm:从当前的工作空间和索引中删除文件
  • git commit:提交当前工作空间中和索引中删除文件
  • git push: 提交当前工作空间的修改内容,类似于SVN的commit命令
  • git push:将本地的代码更新到远程版本库中
  • git log:查看历史日志
  • git revert:还原一个版本的修改,必须提供一个具体的git版本号
  • git branch:对分支的增,删,查等操作
  • git checkout:Git的checkout有两个作用,其一是在不同的branch之间进行切换
  • git rebase:用下面两幅图解释会比较清楚一些,rebase命令执行后,实际上是将分支点从C移到了G,这样分支也就具有了从C到G的功能
    这里写图片描述

  • git reset:将当前的工作目录完全回滚到指定的版本号,假设如下图,我们有A-G五次提交的版本,其中C 的版本号是 bbaf6fb5060b4875b18ff9ff637ce118256d6f20,我们执行了’git reset bbaf6fb5060b4875b18ff9ff637ce118256d6f20’那么结果就只剩下了A-C三个提交的版本
    这里写图片描述

    • git config:利用这个命令可以新增、更改Git的各种设置

    注意:另附上一篇有用的教程,手把手教会你git的使用(http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000)

0 0