项目管理工具git

news2024/10/1 17:29:27

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://www.coloradmin.cn/o/1472268.html

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

相关文章

基于yolov5的苹果检测(pytorch框架)【python源码+UI界面+功能源码详解】

功能演示: 基于yolov5的苹果检测系统,系统既能够实现图像检测,也可以进行视屏和摄像实时检测_哔哩哔哩_bilibili (一)简介 基于yolov5的苹果检测系统是在pytorch框架下实现的,这是一个完整的项目&#xf…

Go语言必知必会100问题-06 生产者端接口

生产者端接口 Go语言必知必会100问题-05 接口污染中介绍了程序中使用接口是有价值的。在编码的时候,接口应该放在哪里呢?这是Go开发人员经常有误解的一个问题,本文将深入分析该问题。 在深入探讨问题之前,先对提及的术语做一个定…

如何使用Inno Setup制作Unity构建程序的Windows安装程序

1. 准备 (1)准备好Unity构建的程序集合 必须包括: Data文件夹(xxx_Data) Mono文件夹(MonoBleedingEdge) 打包的应用程序文件(xxx.exe) Unity播放器dll文件&#xff…

mac flutter 配置

下载Flutter Sdk 直接访问官网无法下载,需要访问中国镜像下载 Flutter SDK 归档列表 - Flutter 中文文档 - Flutter 中文开发者网站 - Flutter Start building Flutter Android apps on macOS - Flutter 中文文档 - Flutter 中文开发者网站 - Flutter 下载后解压…

HCIA-Datacom实验指导手册:5.1 实验一:FTP SFTP TFTP 基础配置实验

HCIA-Datacom实验指导手册:5.1 实验一:FTP 基础配置实验 一、实验介绍:二、实验拓扑:三、实验目的:四、配置步骤:步骤 1 设备基础配置步骤 2 在 Router 上配置 FTP 和SFTP服务器功能及参数步骤 3 配置本地 …

大厂经验谈之OKR目标管理

前言 这是大厂经验谈系列第一篇文章,来看看互联网公司是如何制定和管理目标的。OKR是目前互联网公司经常采用的目标管理工具,最开始也是由国外著名公司推崇,比如Google、微软、亚马逊等,后面才逐步引入国内。既然是工具就有用得好和不好的地方,很多团队仍然把OKR当做KPI来…

【人工智能高频面试题--基本篇】

🚀 作者 :“码上有前” 🚀 文章简介 :人工智能高频面试题 🚀 欢迎小伙伴们 点赞👍、收藏⭐、留言💬 人工智能高频面试题--基本篇 1.深度学习和过往的神经网络训练方法有什么区别?列举…

2024年 前端JavaScript入门到精通 第四天 笔记

4.1 函数的基本使用以及封装练习 ★ 函数命名规范 4.2 函数的参数以及默认参数 函数的灵魂!!! 4.3 函数封装数组求和案例 4.4 函数返回值return 4.5 函数返回值细节以及上午总结 4.6 函数返回值案例-求最大值和最 4.7 函数复习以及断点进入函…

php脚本输出中文在浏览器中显示乱码

问题说明 这个问题一般出现在较低版本的php中,原因是php和浏览器的字符解析方式不对应 ,导致中文字符被错误解析成乱码 (注,此处的php版本任意切换是依赖于小皮面板(phpstudy)实现的,感兴趣可以…

132 Linux 系统编程9 ,IO操作,lseek 函数,truncate函数,查看文件的表示形式

一 lseek 函数 函数说明:此函数用于文件偏移 Linux中可使用系统函数lseek来修改文件偏移量(读写位置) 每个打开的文件都记录着当前读写位置,打开文件时读写位置是0,表示文件开头,通常读写多少个字节就会将读写位置往后移多少个字…

2024国际生物发酵展览会全面揭秘-西尼尔过程控制

参展企业检查 西尼尔(南京)过程控制有限公司成立于2007年,坐落于美丽的六朝古都南京,占地面积20000平方米,现有员工130人,其中70%为本科及以上学历,高级、中级专业技术人员占比30%以上。 公司为…

[NOIP2011 普及组] 数字反转

AC代码&#xff1a; #include<iostream>using namespace std;int main() {long long n;cin >> n;long long temp n;long long sum 0;while(temp ! 0){int c temp % 10;sum sum * 10 c;temp temp / 10;}printf("%lld",sum);return 0; }

BUUCTF第二十四、二十五题解题思路

目录 第二十四题CrackRTF 第二十五题[2019红帽杯]easyRE1 第二十四题CrackRTF 查壳 无壳&#xff0c;32位&#xff0c;用32位IDA打开&#xff0c;打开后的main函数很短&#xff0c;可以找到一句“jmz _main_0”——跳转到 _main_0&#xff0c;说明真正的主函数是_main_0&am…

Rem 自适应原理与应用

前言 移动端适配有很多方案&#xff0c;这篇文章将根据 rem 自适应的原理进行讲解&#xff0c;接下来跟着作者的思路一起来看看吧&#xff01; 原理 在搞清楚 rem 适配之前&#xff0c;我们先来了解一下什么是 rem&#xff1f; rem 是一种相对长度单位&#xff0c;它相对于根…

Mysql学习之事务日志undolog深入剖析

Undo log redo log 是事务持久性的保证&#xff0c;undo log是事务原子性的保证。在事务中更新数据的前置操作其实是要先写入一个undo log。 如何理解undo 日志&#xff1f; 事务需要保证原子性&#xff0c;也就是事务中的操作要么全部完成&#xff0c;要么什么也不做。但有时…

SQLServer 格式化数据的方法

格式化数据一般考虑使用FORMAT 或者CONVERT ​​​​​​​函数&#xff0c;FORMAT 函数是在 SQL Server 2012 中引入的&#xff0c;如果你使用的是较早版本的 SQL Server&#xff0c;则可能需要考虑使用其他方法&#xff0c;如 CONVERT 函数。 在 SQL Server 中&#xff0c;FO…

动态规划--状态转移

解码方法 1.题目 2.思路 1&#xff09;我们定义一个数组dp&#xff0c;其中dp[i]表示字符串s的前i个字符的解码方法总数。初始化时&#xff0c;dp[0]为1&#xff0c;因为空字符串有一种解码方式。dp[1]的值取决于第一个字符是否是0&#xff0c;如果不是0&#xff0c;则有一种…

Unity—MVC分层开发思想

每日一句&#xff1a;当你不努力的时候&#xff0c;天赋就会一点一点被收回 目录 MVC分层开发思想 MVC是什么 MVC的开发步骤 案例&#xff1a;点击按钮实现金币进行添加&#xff0c;并且把金币记录到JSON里 MVC模式实现 背包系统基础代码 背包项目实现步骤 MVC分层开发思…

第十三天-mysql交互

目录 1.安装MySQL connector 方式1&#xff1a;直接安装 方式2&#xff1a;下载 2.创建链接 3.游标Cursor 4.事务控制 5. 数据库连接池 1. 使用 6.循环执行SQL语句 不了解mysql的可以先了解mysql基础 1.安装MySQL connector 1. MySQL connector 是MySQL官方驱动模块…

VirtualBox+Vagrant安装linux

一、VirtualBox安装 VirtualBox官网&#xff1a;Oracle VM VirtualBox 这里采用VirtualBox--7.0.0 版本 二、Vagrant安装 Vagrant官网&#xff1a;Vagrant by HashiCorp Vagrant镜像仓库&#xff1a;Discover Vagrant Boxes - Vagrant Cloud 这里采用Vagrant--2.4.1版本 在…