git从0到不会

143 阅读4分钟

git

本文以平时工作经历+pro git 书籍内容进行阐述,算是做个学习笔记。

版本控制系统

  • 本地版本控制系统

    Mac OS X 系统上通过 rcs 命令进行保存并且管理文件补丁,补丁记录着对应文件修订前后的变化

  • 集中化版本控制系统

    类似于 CVS,Subversion,Perforce 之类的,主要核心在于有一个核心服务器负责管理所有文件的修订版本。

  • 分布式版本控制系统

    Git、Mercurial、Bazaar 之类的,客户端不只提取最新的文件版本,而且把 repository 全部克隆下来

**总结 :simle: **

种类优点缺点特点
本地版本简单,单机部署不适合多人操作使用补丁形式记录文件信息
集中化容易管理,易于掌握其他人进度但若服务器宕机,则服务中止,且易于丢数据,无法协同工作记录各个文件的差异
分布式即便服务器故障,也可以轻松 commit 或者回滚历史,操作方便,只要操作完后再 push 到 repository 即可,且即便服务器挂了,也可以上传本地项目镜像庞大把变化的文件做一次快照,不变的则指向上一个快照的,类似于文件系统

git 知识【只针对 git 进行讲解】

状态

  • committed 已提交

    数据已存放在本地数据库中

  • modified 已修改

    修改但未保存

  • staged 已暂存

    把已修改的文件放在下次提交时要保存的清单中

  • untracked 未跟踪

    不想要加入 git 的,创建.gitingnore 文件,按照正则匹配模式设置一下即可

使用【安装略】

git config --global user.name "tyrantqiao"
git config --global user.email "tyrantqiao@email.com"

若不用 global 则设定保存在当前项目的.git/config 下

  • 查看提交情况

git log -p -2 --stat --pretty

  • 按照文件名的形式查看

git log git show --name-status hash_id

  • 修改最后一次更改情况

git commit --amend

git 存储数据

例如有 test.log 文件,执行git add test.log将 test.log 添加到暂存区中,这时会对文件进行校验和(SHA-1 哈希字符字串)然后将当前版本的文件快照保存到 git 仓库中【快照以 blob 的形式存储下来】其后将校验和加入暂存区域。

当执行git commit时,git 先计算每一个子目录的检验和,再将目录存为树对象,之后 git 创建提交对象,加上那些作者信息等等,包含指向树对象【根目录】的指针,这样就可以到时再回滚回来。

对象也就有: blob【test.log】 tree【根目录加子目录】 tree【根目录】

分支

  • master 默认分支
  • head git 系统的当前分支
  • 合并分支问题:
    • fastforward master->hotfix 合并时,直接将两个指针指向 hotfix 的快照即可,而当操作完成后,即可以删除掉无用的分支例如 hotfix
    • 分岔分支的合并:自动合并,且若有冲突时,需要解决,或者可以加上 force 的命令
  • 分支模式种类
    • 长期分支: 拥有多个开放的分支,各个分支负责特定的任务,对于大型项目时这种易于管理,像可以分为基础,前端,后端,bug 分支等等。
    • 特性分支【topic】:一个短期的,用来实现单一特性与其相关工作的分支,可以理解为一个任务的多种实现,然后在其中抉择较好的任务进行选择。

冲突解决以及什么是 merge

  • 冲突

    简单来说就是线上 git 仓库与本地 git 仓库在一些代码上有冲突的地方【都有改动】,而 git 无法得知哪种是正确的,所以 git 会爆出需要解决冲突

常见情况:

  1. v1->v2->v3-> 【有问题的 v4】,然后主环境回退到 v3,开发人员对 v4 进行修复 bug,建立了 v4->hotfix,完成修复后,merge master 指针和 hotfix,再后面将分支合并回来。
  2. 或者像提交前忘记拉代码,git 自动做了 merge 操作,因为开发上不涉及到冲突操作,所以常发生 merge 操作

那么冲突呢?

  1. 添加时勿将别人的代码添加进去,像格式化等都会导致文件的变化。
  2. 公共代码的修改,大家的版本不一致导致冲突

解决方案:

  1. 备份本地代码,删除掉 git 仓库内代码,拉取最新的代码,并添加上自己的内容上去。
  2. 使用 git 工具,快速将线上的代码依次合并上本地代码内来解决冲突,IDEA 等可以实现
  3. 线上的不要了,那就将本地的代码直接 push 上去