fetch git pull 切换_Git&GitHub(三)

本文详细介绍了Git的基本原理,包括哈希算法在数据完整性中的作用,Git如何保存版本以及其独特的文件管理机制。此外,还探讨了Git的分支管理,如创建和切换分支,以及如何与GitHub进行交互,如克隆、推送和拉取操作。最后,讨论了团队协作中的冲突解决和SSH登录配置。
摘要由CSDN通过智能技术生成

Git 基本原理

哈希

4bcee2cfbd159c74ba1d61c44c07999e.png


哈希是一个系列的加密算法,各个不同的哈希算法虽然加密强度不同,但是有以下几个共同点:

  1. 不管输入数据的数据量有多大,输入同一个哈希算法,得到的加密结果长度固定
  2. 哈希算法确定,输入数据确定,输出数据能够保证不变
  3. 哈希算法确定,输入数据有变化,输出数据一定有变化,而且通常变化很大
  4. 哈希算法不可逆

Git 底层采用的是 SHA-1 算法。
哈希算法可以被用来验证文件。原理如下图所示:

af5d6c7485327d9bb7d5b18f80e2d3fc.png


Git 就是靠这种机制来从根本上保证数据完整性的。


Git 保存版本的机制

集中式版本控制工具的文件管理机制

以文件变更列表的方式存储信息。这类系统将它们保存的信息看作是一组基本文件和每个文件随时间逐步累积的差异。

29fb2bc63a633985eb7ecf005a4e84be.png

Git 的文件管理机制

Git 把数据看作是小型文件系统的一组快照。每次提交更新时 Git 都会对当前的全部文件制作一个快照并保存这个快照的索引。为了高效,如果文件没有修改,Git 不再重新存储该文件,而是只保留一个链接指向之前存储的文件。所以 Git 的工作方式可以称之为快照流。

86e7e951b327bc3407c4b54c037fcef1.png

Git 文件管理机制细节

  • Git 的“提交对象”
  • 提交对象及其父对象形成的链条

Git 分支管理机制

分支的创建

5f3d485c24958768046cd8f710178a9c.png

分支的切换

9f388d7f4127964cace5da28127d5cbb.png

当再切换的时候,就把head指向master的这个分支就好了:

76aada6d7c7c6582bf9dfa324ae69a50.png

GitHub

GitHub 首页就是注册页面

创建本地库

创建远程库

33201ac95f0f88d68710161638874c14.png

bd49d13119e4ad2aaa21bdcbf14a46d2.png

刚创建好,这里会有一些操作的提示:

bcba1b2cc41cd225574a53e1ffd477ee.png

创建远程库地址别名

b7cad8172af5fd030ed0626f739b05e5.png

git remote -v 查看当前所有远程地址别名
git remote add [别名] [远程地址]

fetch表示取回,push表示的就是推送:

1a5b1a890d4562ca94516dad597c3cf2.png

推送

git push [别名] [分支名]

411b46b20231f7b4a52c6e8016d2540c.png

b9714cca9a5db8e216c64438ef4d2153.png

我们再到GitHub上就可以看到我们推送过来的文件了:

42b66b912a39863a56c1868cd4918921.png

克隆

  • 命令:git clone [远程地址]
  • 效果完整的把远程库下载到本地创建远程地址的别名初始化本地库

团队成员邀请

5be4603e215088c536af5fb27bf69abc.png

在邀请组员后,被邀请的组员就可以通过邀请的访问链接来进行访问:

cd8e7612747124ed25eef8ad8c579ada.png

当访问邀请链接的时候,就会出现下面的这个界面:点击接受就可以了

91927f332ee30be7b41d72eff6c0209c.png

这个时候,被邀请的组员再往远程库里面推送就是可以成功了:

f1487944d25305ad09dafe929d4c503a.png

拉取

  • pull=fetch+merge
  • git fetch [远程库地址别名] [远程分支名]
  • git merge [远程库地址别名/远程分支名]
  • git pull [远程库地址别名] [远程分支名]
  • git fetch只是把远程库里面的文件下载到本地,把远程库的文件抓取下来,此时并没有修改本地工作区的文件,如果我们想查看下载了哪些文件,就可以切换远程的分支来进行查看文件
  • git merge这个命令就是把远程的分支合并到本地的master,当合并完了之后,本地就有了新的内容了

解决冲突

93bded66b2fc00a9a4a32fd75c16e95a.png
  • 要点如果不是基于 GitHub 远程库的最新版所做的修改,不能推送,必须先拉取。拉取下来后如果进入冲突状态,则按照“分支冲突解决”操作解决即可。
  • 类比债权人:老王债务人:小刘老王说:10 天后归还。小刘接受,双方达成一致。老王媳妇说:5 天后归还。小刘不能接受。老王媳妇需要找老王确认后再执行。

跨团队协作

  • Fork

这个图表示正在执行fork的这个操作:

891c98f2fc6a20351e16e94d189e6068.png

1387cc1e799b40626a785a59ff605c02.png
  • 克隆下来,本地修改,然后推送到远程
  • Pull Request

16fbeb308907868b59a58ecc2b42f6aa.png

0a871907b4382f7a7857e1bd20ddcfda.png

现在轮到原团队的人来进行操作

6bf6f9deb3cde06e2a59c0dc54f72c53.png

  • 对话
    可以进行交流

  • 审核代码

  • 合并代码

4870f49a3dc95c8f8864fabffd114732.png
  • 将远程库修改拉取到本地

SSH 登录

  • 进入当前用户的家目录
    $ cd ~
  • 删除.ssh 目录
    $ rm -rvf .ssh
  • 运行命令生成.ssh 密钥目录
    $ ssh-keygen -t rsa -C nzyh12358@126.com
    [注意:这里-C 这个参数是大写的 C]
  • 进入.ssh 目录查看文件列表
    $ cd .ssh
    $ ls -lF
  • 查看 id_rsa.pub 文件内容

把生成的key复制到GitHub里面的SSH and GPG keys里面:

946dd749df8ae18e32b3a816c483cf5b.png

此时就是已经可以了:

1fc8601958e237617894cebc5079ab5c.png
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值