git 介绍
Git 是一款免费、开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目,可以有效、高速的处理从很小到非常大的项目版本管理。Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。
git 架构
git 由三部分组成:
-
工作区:用户工作目录
-
暂存区 index:用户提交的工作文档暂存于此
-
对象库 object:用户执行 commit 操作之后的文件会进入对象库。对象库中的文件可以随时进行版本回滚。
git 工作原理:
首先执行 git 初始化,然后会在用户目录生成一个.git 目录,其中记录的是 index 区,object 区,hook 等各种信息。当用户在工作目录编辑文档之后可以执行 git add 把文档记录到 index 区域,然后再通过 git commit 操作把 index 区域的文件同步到 object 区域,并且可以指定一个注释信息作为版本注释信息。object 中的文件是以 sha 算法进行单向加密的 hash 值,以文件名和大小等信息为 hash 计算的依据。其中前两位为目录名,后面为文件名:
在 object 中有 HEAD 的概念,HEAD 是一个指针,永远指向当前最新的一个 commit 版本。git 实现版本的回滚就是利用 head 实现的。当需要回滚到以前的版本的时候 HEAD 会指向用户指定的版本。
git 原理图:
git 使用方法
提交文件
git add filename:用于把文件提交到 index 区域
git commit :用户提交 index 的文件到 object 区域
例子:git init develop #创建一个develop的工作区,其中有.git目录# cd develop cp /etc/passwd /. #拷贝/etc/passwd文件到当前工作区# git status #查看当前git状态,会提示有文件需要add进行提交或者执行git rm进行删除# git add . #提交当前工作区所有文件到index# git commit -m ‘v0.1’ #提交文件到object区域,并注释为v0.1#
此时进入.git 目录的 object 目录会看到已经多了一个文件,即刚提交的文件。
可以对文件进行多次修改,修改完成之后再次按照以上步骤提交,然后可以进行版本回滚
版本回滚:
git reset --hard :将 head 指向改定的提交,index 的快照内容也更改为指定提交,工作区文件变为指定版本
git reset --soft:head 指向给定的提交,index 和工作区不受影响
git reste --mixed:head 指向给定的提交,index 的快照也恢复到指定版本,但是工作区内容不变git log --graph --pretty=oneline #查看所有的历史提交版本# git reset --hard ***:恢复到指定的版本,***表示可以为commit值,也可以为tag或者文件名,也可以通过相对路径表示#
此时就可以恢复到以前的版本,但是有一个问题,如果想从以前版本再恢复到最新版本发现 git log 已经找不到最新的 commit 信息了,这是因为当前状态还没有 commit,不过也可以恢复,需要使用 git reflog 查看最新的 commit 信息,git reflog 会列出在 git 执行的所有操作。
git 相对路径表示法
HEAD^1:表示恢复到上一个提交版本
HEAD^2:表示恢复到上两个提交版本
HEAD~10:表示恢复到上 10 个版本git 多分支
git 可以指定多个分支同时工作,比如开发工作中 master 分支通常是用于稳定版本的发布,通常还会有 develop 开发分支。通常在 develop 分支进行开发工作,开发完成之后会把 develop 分支工作的内容合并到 master 分支中去。
git branch:列出当前的分支数目和当前使用的分支
git branch 分支名:创建新分支
git checkout 分支名:切换分支git 分支合并
git 分支有两种合并方式,一个为 merge,一种为 rebase。
merge 表示把指定分支合并到另一个分支,此时两个分支的内容会合二为一,不过如果分支过多会导致分支过复杂。
rebase 表示把指定分支无缝合并到另一分支,分支变化的内容会以 pack 文件的方式存在,pack 存放的是多个分支不同的内容。从下图可以看到 rebase 会更加明晰。
git 合并分支一般会自动完成,不过如果主分支和另一分支对一个文件同时进行了修改操作,则需要手动解决冲突再合并。合并之前需要两个分支都 commit 工作。#merge操作# git checkout master git merge develop #合并develop到master git add . #合并完成需要重新提交 git commit #rebase操作# git checkout master git rebase develop git add. git commit
分布式 git 版本控制系统
有多种方法可以实现此功能,比如可以采用 github 或者公司自建 gitlab 等。
常用命令:
git clone 分支名:克隆远程分支到本地
git remote:显示所有的远程分支
git push:推送当前修改的工作内容到远程分支
git pull:将远程分支内容取下来然后和本地进行合并
git fetch:取回远程服务器的更新
git 本地和远程服务器的传输可以通过多种方法 -
http 或 https 协议:可以进行远程下载,但是无法做到上传
-
ssh:可以进行远程下载上传
-
git 协议:由 git-daemon 程序提供,监听在 tcp 的 9418 端口;仅支持“读”操作,无任何认证功能;
gitlab 和 github 都支持 http 和 ssh 两种方式。
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于