跟svn一样用于版本控制,但git在多方面优于svn,具体可以参见http://www.aqee.net/5-fundamental-differences-between-git-svn/
svn管理的项目也可以同时用git管理,方式见:http://progit.org/book/ch8-1.html
下面先说下git常用功能命令,也方便自己查找
一、取得项目的 Git 仓库
有两种取得 Git 项目仓库的方法。第一种是在现存的目录下,通过导入所有文件来创建新的 Git 仓库。第二种是从已有的 Git 仓库克隆出一个新的镜像仓库来。
1、在工作目录中初始化新仓库
要对现有的某个项目开始用 Git 管理,只需到此项目所在的目录,执行:
git init
初始化后,在当前目录下会出现一个名为 .git 的目录,所有 Git需要的数据和资源都存放在这个目录中。
2、从现有仓库克隆
如果想对某个开源项目出一份力,可以先把该项目的 Git 仓库复制一份出来,这就需要用到 git clone 命令。命令格式为 git clone [url]。比如,要克隆 Ruby 语言的 Git 代码仓库 Grit,可以用下面的命令:
git clone git://github.com/schacon/grit.git
这会在当前目录下创建一个名为“grit”的目录,其中包含一个 .git 的目录,用于保存下载下来的所有版本记录,然后从中取出最新版本的文件拷贝。
以上命令
git clone git://github.com/schacon/grit.git mygrit
同样能达到效果,只是重命名了目录名而已
二、记录每次更新到仓库
1、检查当前文件状态
git status
2、跟踪新文件、暂存已修改文件
使用命令git add fileName(支持正则)开始跟踪一个新文件。实际上只是add file into staged area,并没有提交文件
3、忽略某些文件
一般我们总会有些文件无需纳入 Git的管理,也不希望它们总出现在未跟踪文件列表。通常都是些自动生成的文件,比如日志文件,或者编译过程中创建的临时文件等。我们可以创建一个名为 .gitignore的文件,列出要忽略的文件模式。来看一个实际的例子:
$ cat .gitignore
*.[oa]
*~
第一行告诉 Git 忽略所有以 .o 或 .a 结尾的文件。第二行告诉 Git 忽略所有以波浪符(~)结尾的文件。要养成一开始就设置好.gitignore文件的习惯,以免将来误提交这类无用的文件。
文件.gitignore 的格式规范如下:
所有空行或者以注释符号 # 开头的行都会被 Git 忽略。
可以使用标准的 glob 模式匹配。 * 匹配模式最后跟反斜杠(/)说明要忽略的是目录。 * 要忽略指定模式以外的文件或目录,可以在模式前加上惊叹号(!)取反。
所谓的 glob 模式是指 shell 所使用的简化了的正则表达式。星号(*)匹配零个或多个任意字符;[abc] 匹配任何一个列在方括号中的字符(这个例子要么匹配一个 a,要么匹配一个 b,要么匹配一个 c);问号(?)只匹配一个任意字符;如果在方括号中使用短划线分隔两个字符,表示所有在这两个字符范围内的都可以匹配(比如 [0-9] 表示匹配所有 0 到 9 的数字)。
我们再看一个 .gitignore 文件的例子:
# 此为注释 – 将被 Git 忽略
*.a # 忽略所有 .a 结尾的文件
!lib.a # 但 lib.a 除外
/TODO # 仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO
build/ # 忽略 build/ 目录下的所有文件
doc/*.txt # 会忽略 doc/notes.txt 但不包括 doc/server/arch.txt
更多规则:http://hi.baidu.com/orangejackylee/blog/item/dd1bc005afd66995e950cd3b.html
4、查看已暂存和未暂存的更新
实际上 git status 的显示比较简单,仅仅是列出了修改过的文件,如果要查看具体修改了什么地方,可以用 git diff 命令。
git diff 查看尚未暂存的文件更新了哪些部分
git diff --cached看已经暂存起来的文件和上次提交时的快照之间的差异
5、提交更新
每次准备提交前,先用git status看下,是不是都已暂存起来了,然后再运行提交命令git commit提交更新
git commit提交会提示输入本次提交说明
git commit -m "commentMark"直接附带提交说明