系统 ubuntu 14.04
1、git 的安装 在 ubuntu 上 使用 apt-get install git-core 命令就可以了
2、git 的基本配置:
git config -- global user.name xxx 配置用户名
git config -- global user.email xxx 配置邮箱
git config -- global color.ui uto 配置颜色
git config -- global diff.tool meld 差异分析工具
git config -- global merge.tool meld 差异分析工具
git config -- global difftool.prompt false 是否每次都要提示
git config -- global (只针对当前用户,配置文件在 ~/gitconfig)
git config --list 查询配置信息
git config --list 查询结果如下
crg@crg-pc:~$ git config --list
user.name=xxxxxxxxx
user.email=xxxxxxxx
color.ui=auto
diff.tool=meld
merge.tool=meld
difftool.prompt=false
使用vim 打开 ~/gitconfig 配置文件,信息如下:
~/gitconfig
[user]
name = rgchen
email = rgchen@neolink.com.cn
[color]
ui = auto
[diff]
tool=meld
[merge]
tool=meld
[difftool]
prompt=false
3、初始化仓库
git init 初始化一个仓库
git clone clone 一个仓库
git 下文件系统的状态
追踪、修改、暂存、提交
4、忽略某些文件
一般我们总会有些文件无需纳入 Git 的管理,也不希望它们总出现在未跟踪文件列表。通常都是些自动生
成的文件,像是日志或者编译过程中创建的等等。我们可以创建一个名为 .gitignore 的文件,列出要忽略的
文件模式,来看一个简单的例子:
$ cat .gitignore
*.[oa]
*~
第一行告诉 Git 忽略所有以 .o 或 .a 结尾的文件。一般这类对象文件和存档文件都是编译过程中出现
的,我们用不着跟踪它们的版本。第二行告诉 Git 忽略所有以波浪符( ~ )结尾的文件,许多文本编辑软件
(比如 Emacs)都用这样的文件名保存副本。此外,你可能还需要忽略 log,tmp 或者 pid 目录,以及自动
生成的文档等等。要养成一开始就设置好 .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
5、删除文件
git rm xxx 本地删除后暂存 本地文件也会被删除
git rm -f xxx 强制删除 本地文件也会被删除
git rm --cached xxx 只删除 跟踪清单中删除 不删除本地文件
git rm ./\*.c 递归删除 该目录下所有的 .c结尾的文件 git rm ./ *.c 只会删除当前目录下的 *.c 而不会递归。
6、git mv 重命名操作
git mv xx_from xx_to
相当于 以下三条命令:
mv xx_from xx_to
git rm xx_from
git add xx_to
7、显示提交的 log
git log --pretty=oneline 单行显示
git log --pretty=format:"%h %s" --graph 格式化输出
git log --pretty=format:"%h - %an, %ar : %s" 格式化输出
8、撤销操作
git commit --amend
修改最后一次提交
------------------------------------------------------------------------------------
git reset HEAD <file>
对于已经
git add 暂存的文件 撤销暂存
------------------------------------------------------------------------------------
git checkout -- XXX
抛弃对文件 xxx 的修改
9、查看当前的远程库
git remote
git remote -v(—verbose 的简写) 显示远程仓库的详细信息