项目管理工具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://www.rhkb.cn/news/264918.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

5.2 Ajax 数据爬取实战

目录 1. 实战内容 2、Ajax 分析 3、爬取内容 4、存入MySQL 数据库 4.1 创建相关表 4.2 数据插入表中 5、总代码与结果 1. 实战内容 爬取Scrape | Movie的所有电影详情页的电影名、类别、时长、上映地及时间、简介、评分,并将这些内容存入MySQL数据库中。 2、…

8.qt5使用opencv的库函数打开图片

1.配置opencv动态库的环境变量 2.在创建的qt工程中加入如下opencv代码,具体代码如下: 使用opencv库函数显示图片

c语言经典测试题4

1.题1 #include <stdio.h>//没有break的话&#xff0c;输入什么都会往下一直执行下去&#xff0c;而且default在最后就会全都执行 int main() {char c;int v0 0, v1 0, v2 0;do{switch (c getchar())// 输入ADescriptor{casea:caseA:casee:caseE:casei:caseI:caseo:…

数据结构2月21日

双向链表: func函数&#xff1a; #include <stdio.h> #include <stdlib.h> …

Springboot中如何记录好日志

Springboot中如何记录日志 日志体系整体介绍 日志一直在系统中占据这十分重要的地位&#xff0c;他是我们在系统发生故障时用来排查问题的利器&#xff0c;也是我们做操作审计的重要依据。那么如何记录好日志呢&#xff1f;选择什么框架来记录日志&#xff0c;是不是日志打越…

LeetCode142. 环形链表 II刷题详解

今天力扣刷到了一个特别有意思的题目&#xff0c;于是就写了下面的题解来加深以下理解。 142. 环形链表 II - 力扣&#xff08;LeetCode&#xff09; 这个可以分为两大步去写&#xff0c;首先要判断链表是否有环&#xff0c;然后如果有环就去找到环的入口&#xff0c;没有环返…

Vue源码系列讲解——生命周期篇【七】(模板编译阶段)

目录 1. 前言 2. 模板编译阶段分析 2.1 两种$mount方法对比 2.2 完整版的vm.$mount方法分析 3. 总结 1. 前言 前几篇文章中我们介绍了生命周期的初始化阶段&#xff0c;我们知道&#xff0c;在初始化阶段各项工作做完之后调用了vm.$mount方法&#xff0c;该方法的调用标志…

Vue + Echarts页面内存占用高问题解决

Vue Echarts页面内存占用高问题解决 1.问题描述 目前使用的是Vue2 Echarts4.x的组合&#xff0c;页面如下所示。 就是一个类似于神策的数据看板页面&#xff0c;左侧是一个导航栏&#xff0c;右侧看板页面中包含很多个报表图片&#xff0c;其中报表页面中对Echarts图表进…

Excel的中高级用法

单元格格式&#xff0c;根据数值的正负分配不同的颜色和↑ ↓ 根据数值正负分配颜色 2-7 [蓝色]#,##0;[红色]-#,##0 分配颜色的基础上&#xff0c;根据正负加↑和↓ 2↑-7↓ 其实就是在上面颜色的代码基础上加个 向上的符号↑&#xff0c;或向下的符号↓ [蓝色]#,##0↑;[红色…

Python算法题集_图论(课程表)

Python算法题集_课程表 题207&#xff1a;课程表1. 示例说明2. 题目解析- 题意分解- 优化思路- 测量工具 3. 代码展开1) 标准求解【循环递归全算】2) 改进版一【循环递归缓存】3) 改进版二【循环递归缓存反向计算】4) 改进版三【迭代剥离计数器检测】 4. 最优算法5. 相关资源 本…

蓝桥杯算法赛 第 6 场 小白入门赛 解题报告 | 珂学家 | 简单场 + 元宵节日快乐

前言 整体评价 因为适逢元宵节&#xff0c;所以这场以娱乐为主。 A. 元宵节快乐 题型: 签到 节日快乐&#xff0c;出题人也说出来自己的心愿, 祝大家AK快乐! import java.util.Scanner;public class Main {public static void main(String[] args) {System.out.println(&qu…

现代化数据架构升级:毫末智行自动驾驶如何应对年增20PB的数据规模挑战?

毫末智行是一家致力于自动驾驶的人工智能技术公司&#xff0c;其前身是长城汽车智能驾驶前瞻分部&#xff0c;以零事故、零拥堵、自由出行和高效物流为目标&#xff0c;助力合作伙伴重塑和全面升级整个社会的出行及物流方式。 在自动驾驶领域中&#xff0c;是什么原因让毫末智行…

Unity3D 使用 Proto

一. 下载与安装 这里下载Google Protobuff下载 1. 源码用来编译CSharp 相关配置 2. win64 用于编译 proto 文件 二. 编译 1. 使用VS 打开 2. 点击最上面菜单栏 工具>NuGet 包管理器>管理解决方案的NuGet 管理包 版本一定要选择咱们一开始下载的对应版本否则不兼容&am…

linux中的权限

Linux 的权限 在了解Linux的权限之前&#xff0c;我们需要知道Linux的构成&#xff0c;Linux分为三个部分&#xff0c;内核、外部程序、以及用户。 内核&#xff1a; 内核一般是指Linux的操作系统&#xff0c;用来执行用户发送的指令 或者 拒绝执行用户发布指令时而发出的报…

Elasticsearch 创建index库 timeout

问题概述 使用 python 客户端 代码进行创建&#xff0c;【之前成功创建&#xff0c;但是现在出现报错&#xff0c;报错代码es_connection.client.indices.create】 def create_vector_index(dataset_index_name,vector_query_field,query_field):es_connection get_collentio…

高并发Server的基石:reactor反应堆模式

业务开发同学只关心业务处理流程。但是我们开发的程序都是运行服务端server上&#xff0c;服务端server接收到IO请求后&#xff0c;是如何处理请求并最终进入业务流程的呢&#xff1f;这里不得不提到reactor反应堆模型。reactor反应堆模型来源于大师Doug Lea在 《Sacalable io …

python Matplotlib Tkinter-->导出pdf报表

环境 python:python-3.12.0-amd64 包: matplotlib 3.8.2 reportlab 4.0.9 import matplotlib.pyplot as plt from matplotlib.backends.backend_tkagg import FigureCanvasTkAgg, NavigationToolbar2Tk import tkinter as tk import tkinter.messagebox as messagebox impor…

11-pytorch-使用自己的数据集测试

b站小土堆pytorch教程学习笔记 import torch import torchvision from PIL import Image from torch import nnimg_path ../imgs/dog.png imageImage.open(img_path) print(image) # imageimage.convert(RGB)transformtorchvision.transforms.Compose([torchvision.transforms.…

设计模式(六)代理模式

相关文章设计模式系列 1.代理模式简介 代理模式介绍 代理模式也叫委托模式&#xff0c;是结构型设计模式的一种。在现实生活中我们用到类似代理模式的场景有很多&#xff0c;比如代购、代理上网、打官司等。 定义 为其他对象提供一种代理以控制这个对象的访问。 代理模式…

Nginx——安装和反向代理

Nginx安装与应用 1.1 Nginx介绍 Nginx 是一个高性能的HTTP和反向代理服务器,特点是占有内存少&#xff0c;并发能力强 Nginx可以作为静态页面的web服务器&#xff0c;同时还支持CGI协议的动态语言&#xff0c;比如perl、php等。但是不支持java。Java程序只能通过与tomcat配合…