Git(版本控制:前端git使用全流程)

news/2024/12/14 17:12:20/

1.版本控制(简单理解:就是软件对每次操作之后提交的记录)

  • 文件版本

  • 版本控制软件

  • 版本控制的好处

  • 版本控制的分类

  • 本地版本控制系统

  • 集中化版本控制系统

  • 分布式版本控制系统

2. Git基础概念与工作流程 

  •  什么是Git?

开源的分布式版本控制系统,快速高效处理从很小到很大的项目版本管理

  •  Git特性:直接记录快照,而非差异比较

SVN基本差异版本控制,存储的是一组基本文件和每个文件随时间逐步积累的差异

  • 好处:节省磁盘空间
  • 缺点:
    • 耗时、效率低
    • 每次切换版本的时候,都需要在基本的文件基础上,应用每个差异,从而生成目标版本对应的文件

Git快照是在原有文件版本基础上重新生成一份新的文件,类似于备份,为了效率,如果文件没有修改,Git不在重新存储该文件,而是保留一个链接指向之前存储的文件

  • 缺点:占用磁盘空间较大
  • 优点:版本切换时候非常块,因为每个版本都是完整的文件快照,切换版本时候直接回复目标版本的快照即可

  • Git 管理拥有三个区域

    • 工作区

    • 暂存区

    • Git仓库

  •  Git的三种状态:注意存在暂存区

  • 工作区的文件被修改了,但是还没放在暂存区,就是已修改的状态
  • 但是文件已经修改放在暂存区,就属于已暂存状态
  • 如果Git仓库中保存着特定版本的文件,就属于已提交状态
  • Git工作流程

  • 工作中修改文件
  • 将想要下次提交的更改进行暂存
  • 提交更新,找到暂存区的文件,将快照永久性存储Git仓库

3.Git基础(并操作用户初始化操作:声明自己的git版本控制)

  • 安装:

Git (git-scm.com)https://git-scm.com/

安装之后会存在的右键点击效果

  •  Git安装之后首先配置用户信息

    • 定义当前计算机的用户名和email密码(注意只需要声明一次就可以长期使用)
git config --global user.name "名字"
git config --gloabl user.email "email地址"

  •  Git全局配置文件

    • 配置用户信息之后就会存在本地文件夹:.gitconfig

  • 检查配置信息:除了上面的全局配置存在的地方,可以使用命令进行查看

# 查看所有全局配置
git config --list --gloabal
# 查看指定的全局配置
git config user.name
git config user.email

  •  查看帮助信息:可以对配置好的信息进行查看配置(可略)

#想要打开git config命令的帮助手册(网页版本)
git help config
#简单语法
git config -h

 4. Git基础操作

获取Git仓库的两种方式:(先得有仓库才能完善后面操作):本地创建库,从远程克隆库

  • 将尚未进行版本控制的本地目录转换为Git仓库
  • 从其他服务器克隆一个存在的Git仓库

 在现有(已经创建好的总文件夹下:例如一个工程文件)目录下进行初始仓库

  • 打开Git Bush
  • 执行git init :当前工程文件夹转为Git仓库

  • 之后会存在一个git仓库文件夹:这是隐藏文件,需要将隐藏文件夹显示打开

 工作区的四种状态

  • 分为两大类:未被管理和已被管理(需要先被管理追踪才能继续操作)
  • 未被管理:指的是新建的文件没有被git发现
  • 已被管理:新创建的文件已经被git已经追踪/发现
  • 注意:最终要实现的目的就是未修改状态

  •  检查文件的状态操作:git ststus(这个方法是查看所有操作状态)

精简方式查看文件状态

git status -s  (一般使用此方法:与下面方法相同)

git status --short

以下是会出现的结果(后面就是操作的文件):

  • ? ?   :  表示文件未被跟踪

  • M  :   表示文件被修改

  • A  :    表示文件有新增文件

  • D :     表示从git仓库中删除了哪个文件

跟踪文件:git add 文件名.文件后缀名

  •  提交更新 git commit -m “提交信息”

  • 暂存区中有一个文件等待被提交到Git仓库
  • 将追踪文件提交到暂存区之后进行再进行查看

  对已经提交的文件进行修改 

  • 注意修改之后的文件没有防止缓存区会出现红色:modified

  • 修改index.html文件
  • 运行git status
  • 运行git status -s

 

暂存已修改的文件:git add 文件名.文件后缀名

 

工作区中的index.html文件已经被修改,如果要暂存这次修改,再次使用git add命令,这个命令是多功能命令,主要三个功效:

  • 可以使用其开始跟踪新文件

  • 把已经跟踪的文件,并且修改的文件放到暂存区

  • 把有冲突的文件标为已经解决状态

再次提交已经暂存的文件:git commit -m “提交信息”

即可将在那存取中记录index.html快照(原有版本生成的新的文件),提交到Git仓库中进行保存 

撤销对文件的修改  git checkout -- 修改的文件名.后缀名

  • 操作结果:所有修改丢失,并且无法恢复,危险性比较高
  • 本质就是用git仓库中文件覆盖工作区中指定文件

 

向暂存区中一次性添加多个文件:  git add.

  • 开发中经常使用这个命令,将新增和修改过后的文件加入到暂存区

 这里修改了html文件并且新增了js文件和css文件

基础操作总结:

  • 初始化仓库: git init

  • 查看文件状态:  git status -s

  • 一次性将文件放到暂存区:   git add .

  • 将暂存区提交到git仓库命令:  git commit -a -m "提交信息"

 

取消暂存的文件:

  • git reset HEAD      要移除的文件名称 :移除指定文件

  • git reset HEAD .    移除所有文件

 跳过使用暂存区域:git commit - a -m"描述信息"

Git标准的工作流程是:工作区 -> 暂存区 ->Git仓库

简化后的工作流程:工作区--> Git仓库

 从Git仓库中移除文件

  • 从git仓库和工作区同时移除对应文件:    git rm -f index.js

  • 只从git仓库中移除:     git rm --cached index.css

 git忽略文件   .gitnore配置文件

  • #开头的是注释
  • /开头的是防止递归
  • 结尾/的是目录
  • !开头的标识取反
  • 使用glob模式进行文件和文件夹的匹配(指简化了的正则表达式

 glob模式

 

  • 星号*匹配零个或者多个字符
  • [abc] 匹配任何一列在方括号中的字符(此方案匹配一个a或匹配一个b或匹配一个c)
  • 问号?只匹配一个任意字符
  • 在方括号中使用短划线分割两个字符,标识所有在这两个字符范围内都可以匹配(比如[0-9]标识匹配所有的0-9的数字)
  • 两个星号**匹配任意中间的目录(比如a/**/a可匹配a/z、a/b/z或者a/b/c/z)
#忽略 所有.a文件
*.a#但是跟踪 lib.a,即使前面忽略了.a文件
!lib.a#只忽略目录下的TOOD文件,但是不忽略subdir/TODO
/TODO#忽略任何目录下名为build文件
build/#忽略doc/notes.txt但是不忽略doc/server/arch.txt
doc/*.txt#忽略doc/ 目录机器所有子目录下的.pdf文件
doc/**/*.pdf

例子: 创建gitnor文件之后通过文本编辑器设置忽略的文件

 

查看提交历史: git log

包含作者、邮箱、时间、提示信息

q可以退出当前查看

 版本切换

  回到第一个版本:使用单独的版本号

 回到之前的版本

 5. 了解Git开源

什么是开源

 

什么是开源协议 :

开源并不意味完全 没有限制,为了限制使用者的使用范围和保护作者的权力,每个开源项目都应该遵守开源许可协议

 五种开源许可协议

  开源托管平台:

  • GitHub:全球最好开源托管平台

  • GitLab:企业用户较多

  • Gitee:码云(国产GitHub)

GitHub访问方式:

  • Https:零配置,之前每次访问都需要输入账户密码(现在需要了) 

     

  • SSH:额外配置(配置之后不用重复输入账号密码)

 基于Https将git本地库上传到远程库(首次)

 

 

修改本地文件再上传 (可以直接使用命令进行上传)

这里已经不是第一次上传

 

 基于SSH key将git本地库上传到远程

1. 生成SSH key 

ssh-keygen -t rsa -b 4096 -C "email"

连续三次回车,可以在c:\user\用户文件夹\.ssh目录中生成id_rsa和id_rsa.pub两个文件

 

 

2. 配置SSH key

  • 打开id_rsa.pub文件并全部复制

  • 登录github:头像->Setting-> SSH and GPG Keys -> New SSH key
  • 将文件中内容粘贴到Key对应文本框
  • title文本框填写一个名称,标识key从何而来

 

3. 检测SSH key是否配置成功 

gitbush中测试: ssh -T git@github.com

输入yes:

 

4.  将本地库上传到GitHub

在当前git仓库目录中将文件上

 

 

 

远程仓库的使用

将远程仓库克隆到本地:git clone 远程仓库地址

 

 

 6. 分支

1. 什么是分支?

相当于平行宇宙

当前平行宇宙一个学git一个学SVN

在某个时间点,两个平行宇宙合并了,结果你即会了Git也学会了SVN

 

2. 分支在实际开发中的作用

在进行多人协作的时候,为了防止互相干扰,提高协同开发,每个开发者都基于分支进行项目开发

 

 3. master(main)主分支

初始化git本地仓库时候,git默认就创建了main主分支

主分支:用来保存和记录整个项目已经完成的功能代码(删除和合并都是在主分支进行操作)

不允许直接在master主分支上修改代码,因为这样的风险太高,容易导致这个项目崩溃

 4. 功能分支

功能分支:专门用来开发新功能的分支(功能实现完成之后会合并到主分支,)

5.  查看分支列表

git branch

  • 分支前面的*标识所处的分支

 

6. 创建新的分支

git branch 新分支名字

 

 

 

 7. 切换分支

git checkout 切换的分支名(注意类似于撤销对文件的修改)

 

 8. 分支的快速创建和切换

git checkout -b 分支名称

 

 

 

9. 合并分支 

 

  • 切换到当前主分支

 git checkout main

  • 运行命令将分支合并到主分支

 git merge 分支名

 

 

可以查看文件的内存占比判断是否已经进行了切换

 

10. 删除分支 

git branch -d 分支名称

 

 

11. 分支冲突合并

两个不同分支对同一个文件进行不同的修改,git无法干净的的合并 

此时需要打开这些包含冲突的文件手动解决冲突

 

 打开vscode当前修改的的文件会存在git操作之后的选择:

  • 选择哪一次更改(直接选择上方到的操作按钮)

 解决完合并冲突之后再次进行上传

 12. 本地分支推送到远程仓库

git push -u origin 远程仓库名 (本地分支名:远程分支名)

  • 如果想要本地分支名字和远程库分支名一样,就只需要一个本地分支名

分支名不同

git push -u origin payment:pay

分支名相同

git push -u origin payment

第一次推送分支需要带-u参数,此后可以使用git.push推送代码到远程分支

 

13. 查看远程仓库中所有分支列表

 git remot show 远程仓库名

 

14. 远程分支操作

14-1 远程跟踪分支 

目的:从远程库将远程分支下载到本地仓库中

#从远程仓库中把对应的远程分支下载到本地仓库,保持本地分支和远程分支名称相同
git checkout 远程分支的名称#实例:pay就是远程库名字
git checkout pay#从远程仓库中,把对应的远程分支下载到本地仓库,并把下载的本地分支进行重命名
git checkout -b 本地分支名称 远程仓库名称/远程分支名称#实例
git checkout -b payment origin/pay

 

 14-2 拉取远程分支最新代码

git pull

14-3 删除远程仓库分支

 git push origin --delete 远程分支名称

  •  远程删除没有本地删除:本地删除方式

 

  • 强制删除

 


http://www.ppmy.cn/news/49354.html

相关文章

八股文之面向对象和面向过程的区别

面向对象(Object-Oriented)和面向过程(Procedural)是两种不同的编程思想。 面向过程是以任务为中心,将程序分解成一系列步骤,在每个步骤中定义一个函数来完成特定的任务。它主要关注程序执行的过程和如何组…

day16 信号灯

信号灯概念和有名信号灯 目录 信号灯概念和有名信号灯 有名信号灯 无名信号灯 信号灯P操作 信号灯V操作 system V信号灯的 信号灯/信号量(semaphore) 信号量代表某一类资源,其值表示系统中该资源的数量; 信号量是一个受保…

瑞吉外卖项目——前后端分离

前后端分离开发 介绍 前后端分离开发,就是在项目开发过程中,对于前端代码的开发由专门的前端开发人员负责,后端代码则由后端开发人员负责,这样可以做到分工明确、各司其职,提高开发效率,前后端代码并行开…

LSM Tree

LSM Tree即Log Structured Merge Tree,如下是一些阅读材料。 Rocksdb Leveled CompactionLSM Tree/MemTable/SSTable基本原理REMIX:Efficient Range Query for LSM-trees深入解析什么是LSM-TreeLSM-Tree介绍浅析LSM-tree(WiscKey, Bourbon, Rum)LSM树详解简述LSM-T…

第五章 Linux实际操作——用户管理

第五章 Linux实际操作——用户管理 5.1 基本介绍5.2 添加用户5.3 指定、修改密码5.4 删除用户5.5 查询用户信息指令5.6 切换用户5.7 查看当前用户、登录用户5.8 用户组5.9 用户和组相关文件8.9.1/etc/passwd 文件8.9.2/etc/shadow文件8.9.3/etc/group文件 5.1 基本介绍 Linux系…

客快物流大数据项目(一百一十五):熔断器 Spring Cloud Hystrix

文章目录 熔断器 Spring Cloud Hystrix 一、​​​​​​​Hystrix 简介 二、什么是雪崩效应

vue+springboot上传大文件

前言 众所周知,上传大文件是一件很麻烦的事情,假如一条路走到黑,直接一次性把文件上传上去,对于小文件是可以这样做,但是对于大文件可能会出现网络问题,请求响应时长等等导致文件上传失败,那么…

Redis删除键命令: 入门用del,老手用unlink,有何区别?

在Redis中,删除键是一项常见操作。Redis提供了两种删除键的方式:del和unlink。这两种方式看似类似,但实际上它们之间存在着不同之处。在本文中,我们将深入探讨这两种删除键的区别以及它们在实际应用中的使用。 一、del命令 del…