Git基础知识
创始人
2025-05-31 01:38:15

Git基础知识

  • 前言
  • 一、Git基本概念
    • 1、分布式版本控制系统--Git
    • 2、Git配置命令
    • 3、Git原理
    • 4、Git常用指令
    • 5、git配置文本编辑器
  • 二、Git如何进行版本管理
    • 1、objects
    • 2、比较差异
    • 3、恢复与回退
    • 4、Revert反做
    • 5、分支
      • a.分支操作
      • b.rebase 变基分支操作原理
      • c.rebase和merge的区别
  • 三、Git同步远程仓库
  • 四、.gitignore
  • 五、SSH公钥验证
  • 六、图形化界面推荐
  • 总结

前言

记录git基础知识,包括基础命令及其背后的原理。

一、Git基本概念

  1. 版本控制系统
    版本控制系统(Version Control System):是一种记录一个或若干文件内容变化,以便将来查阅特定版本修订情况的系统。版本控制系统不仅可以应用于软件源代码的文本文件,而且可以对任何类型的文件进行版本控制。
    常见的版本控制系统有:cvs、svn、git
  2. 为什么要有版本控制系统?
    在开发过程中,经常需要对一个文件进行修改甚至删除,但是我们又希望能够保存这个文件的历史记录,如果通过备份,那么管理起来会非常的复杂。
    在多人开发时,如果需要多人合作开发一个页面,那么修改以及合并也会非常的棘手。容易出现冲突。

1、分布式版本控制系统–Git

分布式主要区别于集中式,集中式就是一台服务器多个用户端,所有用户链接到服务器,像一颗树一样;而分布式是多台服务器,去掉集中式的中心化,多台服务器相互链接,像图一样,特点如下。

  1. 需要一台服务器作为代码仓库
  2. 每个用户电脑都是一个服务器(代码仓库),并且和代码仓库是镜像的,用户修改和获取代码都是提交到自己的服务器当中。
  3. 不需要网络就可以进行工作,当连接网络时,用户可以选择将自己的服务器与代码仓库进行同步。

缺点,对大文件提交不友好(大文件的修改提交用git-lfs)+命令多学习成本大。

Git发展过程,bitKeeper(非开源软件)->Git->GitHub(存开源项目) / Gitlab(开源,便于定制化搭建,公司) / Gerrit(Google针对Android开发的,多仓库编译场景)

2、Git配置命令

git config 设置仓库的一些信息,配置信息有三个作用域,
–global,常用,当前用户有效;–local,当前仓库有效;–system,当前系统有效。

  1. 先配置用户名,git config --global user.name “Bob”;git config --global user.email xx@simple.com
  2. 查看配置信息,git config list
  3. 查看帮助文档,git config --help;–help是通用的,即git --help

3、Git原理

在这里插入图片描述
在这里插入图片描述
三种文件状态,
untracked:文件只在工作区;
modified:工作区和暂存区不一样;
staged:已提交到暂存区;

4、Git常用指令

  1. 创建本地仓库,git init,–initial-branch 初始化的分支;–bare创建一个裸仓库,只有.git目录,不允许添加工作文件,用于服务端仓库;–template可以通过模板来创建预先构建好的git目标。
  2. 查看工作区状态,git status
  3. 添加文件到缓存区,git add <修改的文件>,可以通过"."来代替所有修改文件。
  4. 提交修改,git commit -m “提交描述”
  5. 关联远端仓库,git remote add origin url
  6. 修改远端仓库url,git remote set-url origin url
  7. 和远端仓库同步,git push -u origin master(选择自己需要同步的分支branch)
  8. 拉取代码同步本地仓库,git pull / git fetch
  9. 克隆仓库,git clone url
  10. git命令别名配置,git config --global alias.cin “commit --amend --no-edit”
  11. instead of 配置,url替换,git config --global url.url1:.insteadOf url2
  12. 从fetch/push不同仓库,而不是配置两个origin,git remote add origin url;git remote set-url --add --push origin url
  13. ssh-keygen -t ed25519 -C “your_email@example.com”,密钥默认存在~/.ssh/id_ed25519.pub
    注:目前的Key有4种类型,dsa/rsa/ecdsa/ed25519,默认rsa,但是由于一些安全问题,不推荐dsa/rsa,Windows在ssh层面直接拒绝dsa/rsa命令,存在拉不下代码的情况。
    在这里插入图片描述
    注:
    git commit --amend可以修改commit信息,但是会生成新的commitid,就会导致原来的commitid是悬空的,所以可以gc掉,但有reflog日志记录,不能真正删掉,所以git reflog expire --expire=now --all;再git gc --prune=now(默认两周前)来删除刚才产生的悬空objects,而且会对文件进行压缩。

5、git配置文本编辑器

  1. 设置编辑器
    git config --global core.editor “‘D:\工具软件\NotePad\notepad.6.9.2\notepad++.exe’ -multiInst -notabbar - nosession -noPlugin”
    注:
    后面的参数为notepad对应的支持的命令。
    Ø -multiInst 允许多个 Notepad++ 同时运行
    Ø -notabbar 隐藏工具栏
    Ø -nosession 在 Notepad++ 启动后不加载之前保持的会话
    Ø -noPlugin 不加载任何插件

  2. 设置commit的的全局提交模板,git config --global commit.template “D:\git_template.txt”

二、Git如何进行版本管理

1、objects

每一次commit都会生成一个commitid文件,该文件里面有parentid,这样就形成了版本链条。该文件里面有目录树treeid的文件名,这里就能寻找到当前版本的目录树,而目录树中有每个文件blobid,这样就找到了具体文件。
可以理解为这三个object就能进行版本控制。

2、比较差异

  1. 查看提交历史,git log;git log --online
  2. 比较修改,git diff ,查看工作区和暂存区file的差别;git diff -cached,比较上一次提交和当前暂存区文件的改动。
  3. git diff ,比较两次commit的差异,id是commitid。
  4. HEAD表示当前版本,HEAD~表示上一个版本,HEAD~~表示上上个版本,HEAD~n表示上n个版本。

3、恢复与回退

git reset
原理:git reset的作用是修改HEAD的位置,即将HEAD指向的位置改为为之前存在的某个版本。
在这里插入图片描述

  1. 将缓存区的文件拉回来,git reset – file
  2. git reset --soft HEAD~1,使用当前的指令,工作区和暂存区的代码不会受到影响,但是本地仓库的代码会回滚到YY对应的commitid上。
    在这里插入图片描述
  3. git reset --mixed HEAD~1,使用当前的命令,工作区代码不会受到影响,但是暂存区、本地仓库区的代码已经回滚到了YY对应的commit-id上。
    在这里插入图片描述
  4. git reset --hard HEAD~1,使用当前的命令,工作区、暂存区、本地仓库都会回滚到对应commit-id上,
    在这里插入图片描述

4、Revert反做

git revert是用于“反做`某一个版本,以达到撤销该版本的修改的目的。比如,我们commit了三个版本(版本一、版本二、版本三),突然发现版本二不行(如:bug),想要撤销版本二,但又不想影响撒销版本三的提交,就可以用gitrevert命令来反做版本二,生成新的版本四,这个版本四里会保留版本三的东西,但撤销了版本二的东西。
在这里插入图片描述
git revert -n commitid

5、分支

  • master分支
    主分支,创建项目时即创建的分支,用于部署生产环境的分支,是所有分支的主干,与当前线上代码保持统一。
    由主开发人员、研发组leader管控、不允许其他开发在该分支上直接开发。
  • tag标签
    每次从master发布生产环境后,需要用tag标记一个版本,再master分支上的每个tag都对应历史的一个线上版本。方便后续追溯及复查代码。
  • develop分支
    1.开发分支,开发者各类开发功能的合并分支,即当前最新功能的分支。
    2.开发人员会将自己开发的功能分支提交到dev分支上,由主开发人员来进行审核,通过后合并到dev分支上,一般测试环境就是从develop分支拉取代码。
    3.不允许开发者在该分支上直接开发。
  • feature分支
    1.功能开发分支,需要开发新功能时,每个开发者以develop分支为基础,从dev或master分支拉取代码,并创建新的feature分支。
    2.功能开发完成后,就提交到develop分支上,由主开发者审核合并,功能开发完成后需要删除feature分支,下次开发时再冲突拉取创建。
  • release分支
    1.发布分支,feature分支合并到dev分支后,准备发布新版本时,再创建一个新的release分支,分支名可以以功能名命名,比如release-user,允许存在多个release分支。
    2.预生产环境从release分支拉取代码发布,如果出现bug就从release分支拉取bugfix分支进行修复,测试成功后,release分支合并到dev分支和master分支,并且删除release分支。
  • bugfix分支
    1.bug修复分支,也叫hotfix分支,正式发布之后会出现bug,这时需要开发者从master或者release分支拉取并创建一个bugfix分支,分支名可根据开发者名称来命名。
    2.修复完成之后,合并到master或release分支上,并且删除bugfix分支。

a.分支操作

  1. 查看分支,git branch
  2. 新建分支,git branch <分支名>
  3. 创建并切换分支,git branch -b <分支名>
  4. 切换分支,git checkout <分支名>
  5. 合并分支(若有冲突,需要解决再合并),git checkout <目标分支>,git merge <被合并的分支>
  6. 删除分支,git branch -d <分支名>

在这里插入图片描述

b.rebase 变基分支操作原理

把指定分支的信息,合并到当前分支上。
git rebase 分支名
遇到冲突,解决后继续执行
git rebase --continue
终止rebase行动
git rebase --abort
在这里插入图片描述
在这里插入图片描述

c.rebase和merge的区别

merge合并的特点:

  1. 合并后会自动生成一次commit提交记录
  2. 引入一次合并的历史记录,合并后的所有 commit 会按照提交时间从旧到新排列。
    在这里插入图片描述
    rebase合并的特点:
  3. 会合并之前的commit历史,并不一定按照时间线排列。
  4. 会生成一条分支线,看着比较简洁。
    在这里插入图片描述

三、Git同步远程仓库

  1. 查看远程代码库,git remote -v
  2. 添加删除远程代码库,git remote add/remove
  3. 本地分支—>远程分支,git push
  4. 远程分支—>本地分支(不自动合并),git fetch
  5. 远程分支---->本地分支(自动合并,可能冲突),git pull [git fetch + git merge]
    在这里插入图片描述
  6. 克隆远程仓库,git clone + 路径
  7. 向服务器询问远程仓库信息,git remote show origin

四、.gitignore

在一些项目中,我们不想让本地仓库的所有文件都上传到远程仓库中,而是有选择的上传。例如,一些生成的可执行
xx.exe文件,测试文件等。为了达到这样的目标,git引入了.gitignore文件,使用该文件可以选择性的上传文件。

  • 常用规则
    (1) 注释文件, 以#开头的文件在.gitignore中不起任何作用
    #content
    (2) 以‘/’仅屏蔽当前文件夹ToDo下的文件。需要注意的是空文件夹不会被追踪。
    /ToDo
    (3)以’/'结尾的表示屏蔽所有名为ToDo文件夹下的文件下的文件都会被屏蔽。
    ToDo/
    (4) 屏蔽所有扩展名未a的文件,例如 1.a,3.a文件
    *.a
  • 原则
  1. .gitignore”文件作用是可以忽略原来制定的规则,也可以根据自己的需要制定自己的规则。使用git过程中,总会有些文件无需纳入git的管理,也不希望它们出现在未跟踪文件列表,这时可以使用“.gitignore”文件自动忽略这些文件。
  2. 忽略操作系统自动生成的文件,比如缩略图等;
  3. 忽略编译生成的中间文件、可执行文件等,也就是如果一个文件是通过另一个文件自动生成的,那自动生成的文件
    就没必要放进版本库,比如vs生成的xx.obj文件;
  4. 忽略编译生成的中间文件、可执行文件等,也就是如果一个文件是通过另一个文件自动生成的,那自动生成的文件就没必要放进版本库,比如Java编译产生的.class文件;
  • 示例
    在这里插入图片描述

五、SSH公钥验证

git默认使用https协议,每次pull,push的时候其实存在一定的安全漏洞。本质每次pull和push还需要输入密码(没有提示输入是因为 windows 保存了你的账号密码作为凭证)。使用git的ssh协议,安全性更高,并且可以省去每次输入密码的步骤。
除此之外,https的httpspostbuff限制1M,大文件上传会出现问题。

  • 操作流程
  1. 配置自己的邮箱和用户名
    git config user.name xxx
    git config user.email xxx
  2. ssh-keygen -t rsa -C “这里换上你的邮箱” 说明:命令执行完后,会在指定的保存路径下会生成2个文件,id_rsa私钥文件和id_rsa.pub公钥文件。一般是在
    当前登录用户路径下,可以使用 ls ~/.ssh来查看
  3. 配置密码
    登录上对应的git,点击SSH and GPG keys -》New SSH key,把id_rsa.pub中的文件拷贝进去即

注:
ssh免密配置-公私密钥机制

url:git@github.com:git/git.git

目前的Key有4种类型,dsa/rsa/ecdsa/ed25519,默认rsa,但是由于一些安全问题,不推荐dsa/rsa,Windows在ssh层面直接拒绝dsa/rsa命令,存在拉不下代码的情况。

ssh-keygen -t ed25519 -C “your_email@example.com”,密钥默认存在~/.ssh/id_ed25519.pub

六、图形化界面推荐

  1. MAC
    在这里插入图片描述
  2. Windows
    在这里插入图片描述

总结

1)git基本命令和原理,管理版本的三个重要objects(blob/tree/commit),当然还有一个tag。
2)git为分布式版本管理系统,所以第一步把文件提交给本地仓库,第二步同步给远端仓库。
3)git有很多分支,每个分支都有自己的4个objects,不同分支可进行合并。
4)ssh比https更安全,且上传大文件没有问题。

相关内容

热门资讯

Mysql常用数据类型总结 整形 枚举类型ENUE整形       TINYINT,SMALLINT,MEDIUMINT,IN...
【flink sql】创建表 flink sql创建表语法 CREATE TABLE [IF NOT EXISTS] [catal...
python opencv 保... 👨‍💻个人简介: 深度学习图像领域工作者 dz...
Pytorch深度学习实战3-... 目录1 数据集Dataset2 数据加载DataLoader3 常用预处理方法4 模型处理5 实例&...
自定义类型的超详细讲解ᵎᵎ了解...   目录 1.结构体的声明 1.1基础知识 1.2结构体的声明 1.3结构体的特殊声明  1.4结构...
Docker等容器技术如何与移... 移动应用程序的开发面临着很多挑战,包括开发环境的设置、测试的困难、部署的复杂性等。由于...
【微服务】—— Nacos安装... 文章目录1. Windows安装1.1 下载安装包1.2 解压1.3 端口配置1.4 启动1.5 访...
【OpenGL】 为了理解这个函数我们需要先学习一些OpenGL的内容 OpenGL可视化 https://g...
hjr-详细说一下Redis集... Redis作用 缓存 一般我们用Redis做缓存,热点数据 击穿:访问到...
【蓝桥杯】 C++ 数字三角形... 文章目录题目描述输入描述输出描述实现代码解题思路注意点知识点 题目描述 上图给出了一个数字三角形。从...
VR全景展会丨探索未来,重塑现... 随着科技的不断发展,虚拟现实(VR)技术逐渐成为一个重要的...
C++数据类型 目录 C++基础数据类型 指针 指针类型 指针赋值 引用 参考:《深...
超实用!!! 三分钟将你的项目... 文章目录前言一、在项目中新增配置二、配置github page setting?三、如...
数据结构---队列 专栏:数据结构 个人主页:HaiFan. 专栏简介:这里是...
数字操作方法 系列文章目录 前端系列文章——传送门 JavaScript系列文章——传送门 文章目录系列文章目录...
Cartesi 2023 年 ... 查看 Cartesi Machine、Cartesi Rollups 和 Noether 的更新正在...
JavaWeb——jsp概述入... JSP定义:  在如下一个jsp文件里面有如下的代码  <%@ page content...
一切喜怒哀乐都来自于你的认知 01 有个学子,准备出国,父母请来清华的教授宁向东。请问教授࿱...
JAVA并发编程——synch... 引言         Java语言为了解决并发编程中存在的原子性、可见性和有序性问题,...
git学习----3.21 未... 文章目录前言Git :一个分布式版本控制工具目标一、概述1.1 开发中的实际场景1.2...
Qt优秀开源项目之十七:QtP... QtPromise是Promises/A+规范的Qt/C++实现。该规范的译...
【前端八股文】JavaScri... 文章目录Set概念与arr的比较属性和方法并集、交集、差集Map概念属性和方法String用索引值和...
海康硬盘录像机接入RTSP/o... EasyNVR安防视频云服务平台可支持设备通过RTSP/Onvif协议接入平台,能提供...
在混合劳动力时代如何避免网络安... 在混合劳动力时代如何避免安全网络风险 三年多来,混合工作一直是工作生活中不可或缺的一...
2023还不懂Jmeter接口... 这里介绍的Jmeter接口测试的的实战,如果文章内容没遇看懂的话,我这边...
基于4G/5G弱网聚合的多链路... 基于4G/5G多卡聚合(弱网聚合)的智能融合通信设备技术亮点 增强带宽提供可靠连接 通过将多个有线和...
如何使用Synplify综合v... 文章目录使用Synplify综合的好处synplify的教程方法1(无效)...
2023年全国最新高校辅导员精... 百分百题库提供高校辅导员考试试题、辅导员考试预测题、高校辅导员考试真题、辅导员证考试题库等ÿ...
2022年18个值得期待的Le... 有数百个独特的LearnDash附加组件,您可能很难选择您的LearnDash LMS...
【java基础】Stream流... 文章目录基本介绍流的创建流的各种常见操作forEach方法filter方法map方法peek方法fl...