一、Git工作流程
1、一般工作流程如下:
– 克隆 Git 资源作为工作目录。
– 在克隆的资源上添加或修改文件。
– 如果其他人修改了,你可以更新资源。
– 在提交前查看修改。
– 提交修改。
– 在修改完成后,如果发现错误,可以撤回提交并再次修改并提交。
2、Git 的工作流程示意图:
二、Git基本概念
– 工作区:就是你在电脑里能看到的目录。
– 暂存区:英文叫stage, 或index。一般存放在”git目录”下的index文件(.git/index)中,所以我们把暂存区有时也叫作索引(index)。
– 版本库:工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。
1、工作区、版本库中的暂存区和版本库之间的关系的示意图:
– 图中左侧为工作区,右侧为版本库。在版本库中标记为 “index” 的区域是暂存区(stage, index),标记为 “master” 的是 master 分支所代表的目录树。
– 图中我们可以看出此时 “HEAD” 实际是指向 master 分支的一个”游标”。所以图示的命令中出现 HEAD 的地方可以用 master 来替换。
– 图中的 objects 标识的区域为 Git 的对象库,实际位于 “.git/objects” 目录下,里面包含了创建的各种对象及内容。
– 当对工作区修改(或新增)的文件执行 “git add” 命令时,暂存区的目录树被更新,同时工作区修改(或新增)的文件内容被写入到对象库中的一个新的对象中,而该对象的ID被记录在暂存区的文件索引中。
– 当执行提交操作(git commit)时,暂存区的目录树写到版本库(对象库)中,master 分支会做相应的更新。即 master 指向的目录树就是提交时暂存区的目录树。
– 当执行 “git reset HEAD” 命令时,暂存区的目录树会被重写,被 master 分支指向的目录树所替换,但是工作区不受影响。
– 当执行 “git rm –cached ” 命令时,会直接从暂存区删除文件,工作区则不做出改变。
– 当执行 “git checkout .” 或者 “git checkout — ” 命令时,会用暂存区全部或指定的文件替换工作区的文件。这个操作很危险,会清除工作区中未添加到暂存区的改动。
– 当执行 “git checkout HEAD .” 或者 “git checkout HEAD ” 命令时,会用 HEAD 指向的 master 分支中的全部或者部分文件替换暂存区和以及工作区中的文件。这个命令也是极具危险性的,因为不但会清除工作区中未提交的改动,也会清除暂存区中未提交的改动。
三、Git 客户端安装使用
1、 Git 安装配置
[root@master ~]# yum -y install curl-devel expat-devel gettext-devel openssl-devel zlib-devel [root@master ~]# yum -y install git git-all git-core [root@master ~]# git --version git version 2.18.4
2、Git 配置
Git 提供了一个叫做 git config 的工具,专门用来配置或读取相应的工作环境变量。
这些环境变量,决定了 Git 在各个环节的具体工作方式和行为。这些变量可以存放在以下三个不同的地方:
– `/etc/gitconfig` 文件:系统中对所有用户都普遍适用的配置。若使用 `git config` 时用 `–system` 选项,读写的就是这个文件。
– `~/.gitconfig` 文件:用户目录下的配置文件只适用于该用户。若使用 `git config` 时用 `–global` 选项,读写的就是这个文件。
– 当前项目的 Git 目录中的配置文件(也就是工作目录中的 `.git/config` 文件):这里的配置仅仅针对当前项目有效。每一个级别的配置都会覆盖上层的相同配置,所以 `.git/config` 里的配置会覆盖 `/etc/gitconfig` 中的同名变量。
3、Git 用户信息
配置个人的用户名称和电子邮件地址: [root@master ~]# git config --global user.name "qfedu" [root@master ~]# git config --global user.email test@qq.com
如果用了 **–global** 选项,那么更改的配置文件就是位于你用户主目录下的那个,以后你所有的项目都会默认使用这里配置的用户信息。
如果要在某个特定的项目中使用其他名字或者电邮,只要去掉 –global 选项重新配置即可,新的设定保存在当前项目的 .git/config 文件里。
4、文本编辑器
设置Git默认使用的文本编辑器, 一般可能会是 Vi 或者 Vim。如果你有其他偏好,比如 Emacs 的话,可以重新设置
[root@master ~]# git config --global core.editor emacs
5、差异分析工具
还有一个比较常用的是,在解决合并冲突时使用哪种差异分析工具。比如要改用 vimdiff 的话:
[root@master ~]# git config –global merge.tool vimdiff
Git 可以理解 kdiff3,tkdiff,meld,xxdiff,emerge,vimdiff,gvimdiff,ecmerge,和 opendiff 等合并工具的输出信息。当然,你也可以指定使用自己开发的工具
6、查看配置信息
要检查已有的配置信息,可以使用 git config --list 命令: [root@master ~]# git config --list http.postbuffer=2M user.name=runoob user.email=test@runoob.com
有时候会看到重复的变量名,那就说明它们来自不同的配置文件(比如 /etc/gitconfig 和 ~/.gitconfig),不过最终 Git 实际采用的是最后一个。
这些配置我们也可以在 **~/.gitconfig** 或 **/etc/gitconfig** 看到,如下所示:
[root@master ~]# vim ~/.gitconfig 显示内容如下所示: [http] postBuffer = 2M [user] name = git email = test@master.com 也可以直接查阅某个环境变量的设定,只要把特定的名字跟在后面即可,像这样: [root@master ~]# git config user.name git
暂无评论内容