项目管理工具git

git

  • 1. git介绍
    • 1.1. 版本控制系统
  • 2. 创建本地版本库
    • 2.1 概念
    • 2.2 操作步骤
  • 3. 修改文件
  • 4. 练习: 添加一个本地项目到仓库
  • 5. 添加远程仓库
    • 5.1 添加远程仓库
    • 5.2 本地仓库同步到远程仓库
    • 5.3 克隆远程仓库到本地
    • 5.4 SSH设置
  • 6. 分支管理
    • 6.1 创建分支
    • 6.2 切换分支
    • 6.3 合并分支
    • 6.4 解决冲突
  • 7. 推送文件
  • 8. 使用最多的场景

1. git介绍

1.1. 版本控制系统

  • 集中式版本控制系统

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

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

    在这里插入图片描述

  • 分布式版本控制系统

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

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

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

    在这里插入图片描述

2. 创建本地版本库

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

2.1 概念

  • 工作区:用户自己创建的目录 -> 存放源代码

    • 本地的版本库也需要放到工作区中
    • 每个工作区中都可以创建一个版本库
    • 只有工作区的新文件才需要添加到暂存区
  • 版本库

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

    • 首先创建新文件 -> 在工作区 (和版本库没有关系)
    • 将新文件添加到本地仓库中 -> 新文件被保存在了暂存区 (还是没有进行版本管理)
    • 将暂存区数据提交到版本库 -> 这时候就可以进行版本管理了
    • 暂存区也是一个目录: stage/index

    在这里插入图片描述

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

2.2 操作步骤

  • 创建版本库

    • 在工作区中鼠标右键

      在这里插入图片描述

在这里插入图片描述

  • 添加新文件

    • 在工作区右键菜单

      在这里插入图片描述

      在这里插入图片描述

    此时文件在暂存区中。

    在这里插入图片描述

  • 提交文件

    • 鼠标右键

      在这里插入图片描述

    在这里插入图片描述

3. 修改文件

  • 修改工作区文件

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

  • 还原修改

    • 还原之后数据就不能再恢复了

    在这里插入图片描述

  • 查看修改历史

    • 比较当前的版本和上一个版本的区别

    • 显示日志,查看提交的所有版本的记录

    • 在这里插入图片描述

    • 可以导出某一个需要的版本, 在当前版本上鼠标右键:

      在这里插入图片描述

  • 比较差异

    在这里插入图片描述

  • 删除文件

    • 可以手动删除 -> delete 键
  • 通过菜单项删除

在这里插入图片描述

  • 注意事项:删除操作之后必须要提交

4. 练习: 添加一个本地项目到仓库

  • 设置文件忽略

    先选中要忽略的文件, 在这些文件上鼠标右键

    在这里插入图片描述

    将设置忽略的动作提交到版本库

5. 添加远程仓库

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

5.1 添加远程仓库

在线代码托管平台

  • Github: https://github.com/
  • 码云: https://gitee.com/

创建仓库

  • 在这里插入图片描述

  • 在这里插入图片描述

  • 在这里插入图片描述

5.2 本地仓库同步到远程仓库

  • 在工作区鼠标右键

    在这里插入图片描述

5.3 克隆远程仓库到本地

  • 进入到远程仓库中, 找到仓库的地址

    在这里插入图片描述

  • 将远程地址复制一份

  • 在本地找一个目录, 进行如下操作

    在这里插入图片描述

  • 第一次需要将远程仓库内容下载到本地的时候, 才需要克隆

5.4 SSH设置

  • 在本地生成一个密钥对

    • 在本地任意目录下, 鼠标右键

    在这里插入图片描述

    $ ssh-keygen -t rsa
    

    在这里插入图片描述

    • 本地设置SSH秘钥 -> 私钥

      在这里插入图片描述

      在这里插入图片描述

  • 远程仓库设置公钥

    • 进入当前用户的设置界面

      在这里插入图片描述

      在这里插入图片描述

      在这里插入图片描述

    • 使用SSH地址遇到的问题

      在这里插入图片描述

      # 解决方案: 需要修改tortoisegit 使用的 ssh工具
      # 需要在 tortoisegit 设置窗口中进行修改
      
      • 默认的路径

        在这里插入图片描述

      • 修改后的路径

        在这里插入图片描述

6. 分支管理

分支就是科幻电影里面的平行宇宙,当你正在电脑前努力学习Git的时候,另一个你正在另一个平行宇宙里努力学习SVN。

如果两个平行宇宙互不干扰,那对现在的你也没啥影响。不过,在某个时间点,两个平行宇宙合并了,结果,你既学会了Git又学会了SVN!

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

​ - 如果不创建分支, 分支默认只有一个 : master

在这里插入图片描述

6.1 创建分支

在这里插入图片描述

在这里插入图片描述

6.2 切换分支

在这里插入图片描述

在这里插入图片描述

6.3 合并分支

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

在这里插入图片描述

在这里插入图片描述

6.4 解决冲突

在这里插入图片描述

在这里插入图片描述

  • 冲突文件的格式

    在这里插入图片描述

    手动修改文件内容, 修改完成之后, 解决冲突

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

7. 推送文件

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

直接推送 -> 失败

在这里插入图片描述

失败的原因:

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

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

在这里插入图片描述

  • 合并分支: 得到的新分支FETCH_HEAD分支合并到本地master分支

在这里插入图片描述

在这里插入图片描述

  • 将本地仓库推动到远程仓库

在这里插入图片描述

8. 使用最多的场景

远程仓库分支和本地仓库分支有关系的情况, 该如何操作?

  • 本地:
    • 修改代码提交到本地仓库
    • 提交到远程仓库
      • 不能直接提交
      • 在推送之前应该将远程仓库代码拉取到本地
        • 进程代码合并
          • 有可能冲突 -> 手动解决冲突
      • 将新的代码推动到远程仓库

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/2811991.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

实践航拍小目标检测,基于轻量级YOLOv8n开发构建无人机航拍场景下的小目标检测识别分析系统

关于无人机相关的场景在我们之前的博文也有一些比较早期的实践,感兴趣的话可以自行移步阅读即可: 《deepLabV3Plus实现无人机航拍目标分割识别系统》 《基于目标检测的无人机航拍场景下小目标检测实践》 《助力环保河道水质监测,基于yolov…

QT之项目经验(windows下的sqlite,c++开发)

目录 一、需要时间去磨练gui的调整和优化 1. 借鉴网上开源项目学习 2. gui的布局及调整是磨人的一件事情 3. gui的布局也是可以用组件复刻的 4. 耗时的设备树 二、多线程异步弹窗 三、定时任务动态变更设定 1.确定按钮触发 2.此处监听定时任务时间的改变 3.此处对改变做出具…

[算法沉淀记录]排序算法 —— 快速排序

排序算法 —— 快速排序介绍 基本概念 快速排序(Quicksort)是一种排序算法,最早由东尼霍尔提出。在平均状况下,排序 n 个项目要 Ο(n log n) 次比较。在最坏状况下则需要 Ο(n2) 次比较,但这种状况并不常见。事实上&…

linux centos7.9改dns和ip

vi /etc/sysconfig/network-scripts/ifcfg-ens32 :wq后 重启网络服务 systemctl restart network —————————————————————————— 篇外话题 软件下载 xshell可以从腾讯软件中心下载

Open CASCADE学习|GC_MakeArcOfCircle构造圆弧

目录 1、通过圆及圆的两个参数创建圆弧,参数为弧度角 2、通过圆及圆上的一点、圆的1个参数创建圆弧,参数为弧度角,Sense决定方向 3、通过圆及圆上的两个点创建圆弧,Sense决定方向 4、通过三点创建圆弧,最后一点应安…

react useRef用法

1&#xff0c;保存变量永远不丢失 import React, { useState,useRef } from react export default function App() { const [count,setcount] useState(0) var mycount useRef(0)//保存变量永远不丢失--useRef用的是闭包原理 return( <div> <button onClick{()>…

SpringBoot使用classfinal-maven-plugin插件加密Jar包

jar包加密 1、在启动类的pom.xml中加入classfinal-maven-plugin插件 <build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin><plugin><…

Qt QWidget 简约美观的加载动画 第五季 - 小方块风格

给大家分享两个小方块风格的加载动画 &#x1f60a; 第五季来啦 &#x1f60a; 效果如下: 一个三个文件,可以直接编译运行 //main.cpp #include "LoadingAnimWidget.h" #include <QApplication> #include <QGridLayout> int main(int argc, char *arg…

Python之词频统计(自然语言处理)

背景 词频统计是指对一段文本中每个单词出现的次数进行计数分析。这种分析有助于了解文本的重点词汇、主题或作者的写作风格。如果你有一个特定的文本或想要分析某些内容的词频&#xff0c;你可以提供文本&#xff0c;我可以为你进行简单的词频统计。 例如&#xff0c;如果你…

jeesite用字典项配置二级下拉选

1、配置字典项 2、html代码&#xff1a;修改下拉选项框 <div class"col-xs-6"><div class"form-group"><label class"control-label col-sm-4" title""><span class"required">*</span> ${…

备考北京高考数学:历年选择题真题练一练和解析(2014-2023)

还有三个多月的时间就要高考了&#xff0c;我们今天继续看北京市高考数学真题和解析。今天看5道选择题。独家制作的在线练习集&#xff0c;可以便捷地反复刷这些真题&#xff0c;吃透真题&#xff08;背后的知识点和解题技巧&#xff09;&#xff0c;让高考数学再上一个台阶。 …

OpenAI Sora 关键技术详解:揭秘时空碎片 (Spacetime Patches) 技术

编者按&#xff1a;近日&#xff0c;OpenAI发布其首个视频生成模型“Sora”&#xff0c;该模型生成的视频内容可以呈现出多个角色、特定动作以及复杂场景&#xff0c;为构建能够理解和模拟现实世界的人工智能模型奠定了基础。 本文解析的重点即是 Sora 背后的核心技术 Spacetim…

单片机51 定时器

一、基本概念 1.1简介 单片机的定时器是一种内部功能模块&#xff0c;用于产生计时、计数、延时等功能。定时器通常由一个或多个计数器和相关的控制逻辑组成。单片机的定时器可以运行在不同的工作模式下&#xff0c;以适应不同的计时和计数需求。 C51中的定时器和计数器是同…

Tomcat 下部署若依单体应用可观测最佳实践

实现目标 采集指标信息采集链路信息采集日志信息采集 RUM 信息会话重放 即用户访问前端的一系列过程的会话录制信息&#xff0c;包括点击某个按钮、操作界面、停留时间等&#xff0c;有助于客户真是意图、操作复现 版本信息 Tomcat (9.0.81)Springboot(2.6.2)JDK (>8)DDT…

请求包的大小会影响Redis每秒处理请求数量

文章目录 &#x1f50a;博主介绍&#x1f964;本文内容压测规划客户端长连接数量对性能的影响请求包大小的影响Pipleline模式对Redis的影响 &#x1f4e2;文章总结&#x1f4e5;博主目标 &#x1f50a;博主介绍 &#x1f31f;我是廖志伟&#xff0c;一名Java开发工程师、Java领…

第二章 Xshell5连接VM中虚拟系统Ubuntu1704

第二章 Xshell5连接VM中虚拟系统Ubuntu1704 第一章 Win10系统VM安装Ubuntu1704虚拟机 第三章 VMware虚拟机ubuntu显示屏幕太小&#xff0c;无法自适应解决办法 一、设置全新安装的Ubuntu的root密码 1.1、启动Ubuntu系统&#xff0c;在桌面右键打开终端 1.2、尝试登陆root用户…

【postgresql】数据表id自增与python sqlachemy结合实例

需求&#xff1a; postgresql实现一个建表语句&#xff0c;表名&#xff1a;student,字段id,name,age&#xff0c; 要求&#xff1a;每次添加一个数据id会自动增加1 在PostgreSQL中&#xff0c;您可以使用SERIAL或BIGSERIAL数据类型来自动生成主键ID。以下是一个创建名为stude…

TiDB之分布式数据库TiDB 操作管理规范【附可下载文档】

一、 目的 为了在软件生命周期内规范数据库相关的设计、开发、运维工作,便于不同团队之间的沟通及协调,制定此文档,以期在相关规范上达成共识和默契,提升相关环节的工作效率及系统的可维护性。同时好的规范,在执行的时候可以培养出好的习惯,好的习惯是软件质量的很好保证…

EMQX Enterprise 5.5 发布:新增 Elasticsearch 数据集成

EMQX Enterprise 5.5.0 版本已正式发布&#xff01; 在这个版本中&#xff0c;我们引入了一系列新的功能和改进&#xff0c;包括对 Elasticsearch 的集成、Apache IoTDB 和 OpenTSDB 数据集成优化、授权缓存支持排除主题等功能。此外&#xff0c;新版本还进行了多项改进以及 B…

Qt项目:网络1

文章目录 项目&#xff1a;网路项目1&#xff1a;主机信息查询1.1 QHostInfo类和QNetworkInterface类1.2 主机信息查询项目实现 项目2&#xff1a;基于HTTP的网络应用程序2.1 项目中用到的函数详解2.2 主要源码 项目&#xff1a;网路 项目1&#xff1a;主机信息查询 使用QHostI…