IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发工具 -> Git的学习与总结 -> 正文阅读

[开发工具]Git的学习与总结

git介绍

集中式版本控制系统

集中式版本控制系统,版本库是集中存放在中央服务器的,而干活的时候,用的都是自己的电脑,所以要先从中央服务器取得最新的版本,然后开始干活,干完活了,再把自己的活推送给中央服务器。

集中式版本控制系统最大的毛病就是必须联网才能工作,如果在局域网内还好,带宽够大,速度够快,可如果在互联网上,遇到网速慢的话,那就GG了.
在这里插入图片描述
分布式版本控制系统

分布式版本控制系统根本没有“中央服务器”,每个人的电脑上都是一个完整的版本库,这样,你工作的时候,就不需要联网了,因为版本库就在你自己的电脑上。

既然每个人电脑上都有一个完整的版本库,那多个人如何协作呢?

分布式版本控制系统通常也有一台充当“中央服务器”的电脑,但这个服务器的作用仅仅是用来方便“交换”大家的修改,没有它大家也一样干活,只是交换修改不方便而已。
在这里插入图片描述
创建本地版本库

版本库又名仓库,英文名repository,你可以简单理解成一个目录,这个目录里面的所有文件都可以被Git管理起来,每个文件的修改、删除,Git都能跟踪,以便任何时刻都可以追踪历史,或者在将来某个时刻可以“还原”。

  • 工作区

    • 用户自己创建的目录 -> 存放源代码
    • 本地的版本库也需要放到工作区中
    • 每个工作区中都可以创建一个版本库
    • 只有工作区的新文件才需要添加到暂存区
  • 版本库

    • 就是一个目录: 名字-> .git
    • 管理用于提交的代码
  • 暂存区

    • 首先创建新文件 -> 在工作区 (和版本库没有关系)

    • 将新文件添加到本地仓库中 -> 新文件被保存在了暂存区 (还是没有进行版本管理)

    • 将暂存区数据提交到版本库 -> 这时候就可以进行版本管理了

    • 暂存区也是一个目录: stage/index

    • 提交代码的流程

      • 要在工作区中创建新文件
      • 将工作区中的新文件添加到暂存区
        • 文件只需要往暂存区添加一次
      • 将暂存区数据提交到版本仓库
        • 版本仓库中有很多节点, 依次记录着我们提交的各个版本

在这里插入图片描述
操作步骤:

创建版本库

  • 在工作区中鼠标右键
    - [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Gho6dUZY-1647572076602)(assets/1566526442145.png)]
    在这里插入图片描述

添加新文件

  • 在工作区右键菜单
  • 在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

提交文件

  • 鼠标右键

  • 在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

  • 修改工作区文件

    • 修改完文件之后直接提交, 不需要再次添加到暂存区
  • 修改完之后 的数据需要提交到本地的版本仓库中

  • 还原修改

    • 还原之后数据就不能再恢复了
      在这里插入图片描述

查看修改历史

  • 比较当前查看的版本和上一个版本的区别
  • 可以导出某一个需要的版本, 在当前版本上鼠标右键:
    在这里插入图片描述

差异比较
在这里插入图片描述

删除文件

  • 可以手动删除 -> delete 键
  • 通过菜单项删除
    在这里插入图片描述
  • 注意事项:删除操作之后必须要提交
    可以从历史节点里导出已删除的历史版本信息

设置文件忽略
先选中要忽略的文件, 在这些文件上鼠标右键
在这里插入图片描述
将设置忽略的动作提交到版本库

添加远程仓库

远程仓库作用:
- 备份本地仓库的代码
- 多人协同开发, 使用远程仓库合并代码
远程仓库来源:
- 公司自己搭建
- 使用现有的远程仓库
– Github: https://github.com/
– 码云: https://gitee.com/

创建仓库
在这里插入图片描述
在这里插入图片描述
本地仓库同步到远程仓库

在工作区鼠标右键Git同步
在这里插入图片描述
克隆远程仓库到本地

进入到远程仓库中, 找到仓库的地址
在这里插入图片描述
第一次需要将远程仓库内容下载到本地的时候, 才需要克隆

ssh设置

在本地生成一个密钥对

  • 在本地任意目录下, 鼠标右键
    在这里插入图片描述
$ ssh-keygen -t rsa

在这里插入图片描述
本地设置ssh秘钥 -> 私钥
在这里插入图片描述
这就是公钥私钥:
在这里插入图片描述
在这里插入图片描述
远程仓库设置公钥

  • 进入当前用户的设置界面
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    使用ssh地址遇到的问题
    在这里插入图片描述
    解决方案: 需要修改tortoisegit 使用的 ssh工具
    需要在 tortoisegit 设置窗口中进行修改

默认的路径
在这里插入图片描述
修改后的路径
在这里插入图片描述
分支管理

在版本仓库中有一个默认的分支:master, 当前仓库中有文件之后, 默认分支就被创建了
如果不创建分支, 分支默认只有一个 : master

创建分支
在这里插入图片描述
在这里插入图片描述
合并分支

两个分支进行合并(master, new分支), 最终要合并到那个分支(master), 就先切换到那个分支(master), 切换完成之后, 在选择把哪个分支(new分支)合并到当前分支(master)

在这里插入图片描述
在这里插入图片描述
解决冲突
在这里插入图片描述
在这里插入图片描述
冲突文件的格式
在这里插入图片描述
手动修改文件内容, 修改完成之后, 解决冲突
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
推送文件

有一个远程的仓库-> github, 这不是一个空的仓库, 需要将本地的版本库提交到远程仓库

直接推送 -> 失败
在这里插入图片描述
失败的原因:

  • 远程仓库不是空的
    • 有一个默认分支, master
  • 本地仓库, 不是空的
    • 有一个默认分支, master
  • 远程仓库和本地仓库默认分支名字相同, 但是这两个分支没有任何关系
    • 没有关系的分支进行合并 -> 失败

解决方案

  1. 将远程仓库拉取到本地(pull)
    • 拉取: 直接将远程仓库分支中的信息和本地分支进行合并
    • 获取: 将远程仓库分支复制到本地的另外一个分支中, 不会合并
      • 分支名字: fetch_head
  2. 将两个分支进行强行合并
  3. 将本地分支数据推送动到远程仓库

通过进行获取操作, 得到新分支FETCH_HEAD
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-pM37PzqU-1647587688051)(assets/1566550553280.png)]
合并分支: 得到的新分支FETCH_HEAD分支合并到本地master分支
在这里插入图片描述
在这里插入图片描述
将本地仓库推动到远程仓库
在这里插入图片描述
远程仓库分支和本地仓库分支有关系的情况, 该如何操作?

本地:

  • 修改代码提交到本地仓库
  • 提交到远程仓库
    • 不能直接提交
    • 在推送之前应该将远程仓库代码拉取到本地
      • 进程代码合并
        • 有可能冲突 -> 手动解决冲突
    • 将新的代码推动到远程仓库
  开发工具 最新文章
Postman接口测试之Mock快速入门
ASCII码空格替换查表_最全ASCII码对照表0-2
如何使用 ssh 建立 socks 代理
Typora配合PicGo阿里云图床配置
SoapUI、Jmeter、Postman三种接口测试工具的
github用相对路径显示图片_GitHub 中 readm
Windows编译g2o及其g2o viewer
解决jupyter notebook无法连接/ jupyter连接
Git恢复到之前版本
VScode常用快捷键
上一篇文章           查看所有文章
加:2022-03-22 20:48:22  更:2022-03-22 20:49:43 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/2 0:25:55-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码