【基础篇】Git 基础命令与核心概念

news2024/10/6 0:32:29

✅作者简介:大家好,我是小杨
📃个人主页:「小杨」的csdn博客

🐳希望大家多多支持🥰一起进步呀!


一,Git 初识

1.1,问题引入

不知道你工作或学习时,有没有遇到这样的情况:我们在编写各种文档时,为了防止出现文档丢失或者更改失误的情况,失误后也能恢复到原来的版本,不得不复制出一个副本,比如:

“文档报告-v1”

“文档报告-v2”

“文档报告-v3”

每个版本都有各自的内容,但最终只会有一份文档报告被我们使用。

但在此之前的工作都需要这些不同版本的文档报告,于是每次都要经过复制粘贴操作得到副本,产出的文件就会越来越多,虽然文件多不是什么大问题,但问题是:随着版本数量的不断增多,你是否还记得这些版本各自都是修改了什么吗?

这个文档报告是如此,我们写的项目代码也是如此,就是也存在上述这个问题的。那如何解决上述问题呢?


1.2,问题解决

那如何解决上述问题呢?这就便有了版本控制器。

何为版本控制器?所谓的版本控制器,就是能让你了解到一个文件的历史,以及它的发展过程的系统。

通俗的讲就是一个可以记录工程的每一次改动和版本迭代的一个管理系统,同时也方便多人协同作业。

目前最主流的版本控制器就是Git 。Git可以控制电脑上所有格式的文件,例如doc、 excel、dwg、dgn、rvt等等。对于我们开发人员来说,Git最重要的就是可以帮助我们管理软件开发项目中的源代码文件!

注意事项:

1,Git只能跟踪文本文件的改动,比如TXT文件,网页,所有的程序代码等等。版本控制系统可以告诉你每次的改动,比如在第5行添加了一个单词”Linux",或者在第8行删了一个单词"Windows"。

2,而对于图片、视频这些二进制文件,虽然也能由版本控制系统管理,但没法跟踪文件的变化,只能把二进制文件每次改动串起来。也就是只能知道图片从10OKB改成了120KB,但到底改了啥,版本控制系统不知道,也没法知道。


1.3,Git 的功能

Git 是目前最主流的版本控制器,其主要实现以下的功能:

  1. 版本控制和分支管理
  2. 本地与远程仓库操作:提交,拉取,合并,推送
  3. 团队协同开发:团队中的成员可通过克隆仓库到本地后进行独立开发

1.4,Git 的工作机制

在谈到Git的工作机制之前,首先了解几个基本概念:

  1. 工作区:在电脑上所能看到或者写代码文件的目录。
  2. 暂存区:临时存储工作区的代码,一般存放在.git目录下的index文件中,也被称为索引。
  3. 版本库:工作区有一个隐藏目录 .git,这个不算工作区,而是 Git 的版本库。其里面的所有文件都可被Git 管理和控制。
  4. objects:Git 的对象库,位于 .git/objects 目录下,修改的工作区内容会写入对象库的一个新的object对象中。

下面这个图展示了工作区、版本库中的暂存区和版本库之间的关系:

在这里插入图片描述

Git 的工作机制如下:

1,工作区的代码文件通过使用git add命令将其放到暂存区
2,暂存区的代码文件通过使用git commit命令将其提交到版本库
3,版本库的代码文件通过使用git push命令将其推送到远程仓库中


二,Git 使用

2.1,Centos 安装 Git

1. Git 查看命令:

git

2. Git 下载命令:

sudo yum -y install git

3. Git 版本查看命令:

git --version

4. Git 卸载命令:

sudo yum -y remove git 

2.2,Ubuntu 安装 Git

1. Git查看命令:

git

2. Git 下载命令:

sudo apt-get -y install git

3. Git 版本查看命令:

git --version

4. Git 删除命令:

sudo apt-get -y remove git

2.3,本地仓库创建

1. 创建一个文件夹并进入

mkdir gitcode

2. Git 本地仓库创建命令:

git init

3. Git本地仓库具体目录查看命令:

tree .git

4. 代码实操:

image-20240417212036088

在这里使用tree .git命令进行查看Git本地仓库具体目录时,会出现上述报错信息。出现其报错原因是在centos中,tree命令不存在,需要通过sudo yum -y install tree 命令下载tree,操作如下:

image-20240417212631162

下载完成后通过使用tree .git命令就可以查看Git本地仓库具体目录了。

image-20240417212840976

5. 本地仓库创建注意

仓库是进行版本控制的一个文件目录,所以要想对文件进行版本控制,就必须先创建一个仓库出来,然后在创建的文件目录下使用git init指令执行创建一个Git本地仓库的操作。


2.4,本地仓库配置

当安装Git后首先要做的事情是设置你的用户名称e-mail地址,这是非常重要的。

  1. 特定配置添加命令:
git config [-global] user.name "Your Name"
git config [-global] user.email "email@example.com"

# 把 Your Name 改成你的昵称
# 把 email@example.com 改成邮箱的格式,只要格式正确即可。
  1. 所有配置查看命令:
git config -l
  1. 特定配置删除命令:
git config [--global] --unset user.name
git config [--global] --unset user.email
  1. 代码实操:

image-20240417214247412

5. 本地仓库配置注意

–global选项是一个可选项。如果使用了该选项,表示这台机器上所有的git仓库都会使用这个配置。如果你希望在不同仓库中使用不同的name或e-mail,可以不使用–global选项,但要注意的是,执行命令时必须要在仓库里,并且如果特定配置添加时使用了–global选项,删除特定配置时也需要使用该选项。


2.5,本地文件操作

1.本地文件准备:

touch file

2.本地文件添加命令:

git add [file1] [file2] ...  # 添加⼀个或多个⽂件到暂存区
git add [dir]                # 添加指定⽬录到暂存区,包括⼦⽬录
git add .                    # 添加当前⽬录下的所有⽂件改动到暂存区

3.本地文件提交命令:

 git commit -m "message"                       # 提交暂存区全部内容到仓库中
 git commit [file1] [file2] ... -m "message"   # 提交暂存区的指定⽂件到仓库区
 git commit [dir] ... -m "message"	           # 提交暂存区的指定目录到仓库区

4.本地文件提交记录查看命令:

git log [--pretty=oneline]

5.代码实操:

image-20240417222545411

6.本地仓库状态查看命令:

git status

7.文件差异查看命令:

git diff [file]              # 暂存区和工作区文件差异查看命令
git diff HEAD -- [file]      # 版本库和工作区文件差异查看命令

8.代码实操:

image-20240417225733879


2.6,本地仓库结构目录

通过使用tree .git 命令就可以查看本地仓库的结构目录,下图所示:

image-20240417231144776

在本地仓库的结构目录中,需要特别关注下面几个:

• index:暂存区,git add后会更新该内容。

• HEAD:默认指向 master 分支的一个指针。

• refs/heads/master:文件里保存当前 master 分支的最新commit id 。

• objects: 包含了创建的各种版本库对象及内容,可以简单理解为放了 git 维护的所有修改。

代码实操:

image-20240417234308038

注意1:查找object时要将commit id分成2部分,其前2位是文件夹名称,后38位是文件名称。找到这个文件之后,一般不能直接看到里面是什么,该类文件是经过sha(安全哈希算法)加密过的文件,我们可以使用 git cat-file 命令来查看版本库对象的内容。

注意2:通过使用git cat-file命令来查看版本库对象的内容,发现内容中有tree和parent。其中tree表示当前提交的文件状态快照,它包含了文件和子目录的信息,而parent表示当前提交对象的父提交,也就是它的前一个历史状态。


2.7,文件版本回退

git reset命令用于回退版本,可以指定退回某一次提交的版本。

git reset命令语法格式为:git reset [–soft | --mixed | --hard] [HEAD]

–soft:对于工作区和暂存区的内容都不变,只是将版本库回退到某个指定版本。

–mixed:默认参数,将暂存区和版本库的内容回退到指定版本,工作区文件不变。

–hard:将版本库,暂存区,工作区都回退到指定版本,使用该参数需要慎重考虑。

HEAD:表示回退的版本,有三种写法,分别为:直接使用commit id,HEAD(当前版本),HEAD^(上一版本),HEAD0(当前版本),HEAD1(上一版本)。


2.8,文件撤销修改

文件撤销修改有3种情况以及对应的解决方法:

  1. 工作区内容未添加和提交:直接修改工作区内容【不推荐,容易操作失误】,使用git checkout -- [file]命令撤销修改【推荐】。
  2. 工作区内容添加但未提交:使用git reset --mixed HEAD [file]命令将暂存区内容回退到当前版本,接着进行上述第一种情况操作。
  3. 工作区内容添加并已提交:使用git reset --hard HEAD^ [file]命令将版本库,暂存区,工作区内容回退到上一版本。

2.9,文件删除

文件删除不仅需要将工作区文件删除,还需要将版本库中的文件删除。有2种方式:

  1. 首先需要使用git rm [file]命令删除工作区和暂存区的文件,然后通过git commit命令进行删除版本库中的文件。
  2. 首先需要使用rm [file]命令删除工作区文件,然后通过git addgit commit命令依次进行删除暂存区和版本库中的文件。

三,分支管理

3.1,分支管理理解

Git分支管理是一种组织和管理代码变更的方法,它允许团队在同一个代码库中同时进行多个独立的工作。通过使用分支,团队可以在不影响主要代码流的情况下开发新功能、修复bug、测试变更等。

  1. 主分支(Main/Branch):主分支是项目的主要分支,通常用于发布稳定版本。在过去,主分支通常被称为“master”,但随着对语言的更新,更倾向于使用“main”。
  2. 开发分支(Develop Branch):开发分支是用于整合和测试新功能的分支。团队成员通常从主分支创建开发分支,并在此处进行开发工作。当开发完成并且测试通过时,开发分支通常会被合并回主分支。
  3. 功能分支(Feature Branch):功能分支用于开发单个功能或修复单个问题。每个功能或问题通常对应一个独立的功能分支。功能分支通常从开发分支创建,并在完成后被合并回开发分支。
  4. 发布分支(Release Branch):发布分支用于准备发布新版本。在发布分支上进行最后的测试、修复bug和准备版本号等工作。完成后,发布分支会被合并回主分支,并且通常会被打上标签以标记发布版本。
  5. 修复分支(Hotfix Branch):修复分支用于紧急修复生产环境中的bug。它们通常是从主分支分支出来的,并且在修复后会合并回主分支和开发分支。

3.2,分支管理操作

1.分支查看

git branch            # 列出所有本地分支,当前分支会用星号标记。
git branch -a         # 列出所有本地和远程分支。

2.分支创建

git branch <branch-name> 

3.分支切换

git checkout <branch-name> 

4.分支合并

git merge <branch-name>           # 将指定分支合并到当前分支。
git merge --no-ff <branch_name>   # 以非快进模式合并分支,保留合并历史。

5.分支删除

git branch -d <branch-name>
git branch -d <branch_name>       # 删除指定的本地分支,如果分支未合并,则会报错。
git branch -D <branch_name>       # 强制删除指定的本地分支,即使分支未合并也会删除。

6.分支创建并切换

git branch -b <branch-name> 

7.分支重命名

git branch -m <old_branch_name> <new_branch_name

8.合并基点查看

git merge-base <branch1> <branch2>   # 查看两个分支的最近共同祖先,通常用于解决合并冲突。

9.分支历史查看

git log --oneline --graph --all      # 以图形化方式查看所有分支的提交历史。

10.远程分支跟踪

git branch -u <remote>/<branch>      # 将当前分支设置为追踪指定的远程分支。

11.分支推送

git push <remote> <branch_name>      # 将本地分支推送到远程仓库。
git push -u <remote> <branch_name>   # 第一次推送分支时,使用 -u 参数建立追踪关系。

12.远程分支拉取

git fetch <remote>                   # 从远程仓库拉取所有分支的更新。
git fetch <remote> <branch_name>     # 从远程仓库拉取指定分支的更新。

13.默认分支设置

git config --global init.defaultBranch <branch_name>   #设置新建仓库时的默认分支。

3.3,分支管理注意

1,分支合并策略有两种,分别为:fast forwardnon-fast forward

fast forward :在合并分支时,Git 可以简单地将目标分支指针向前移动到要合并的分支的最新提交,而不需要创建新的合并提交。这种方式的合并操作不会产生额外的合并提交,因此合并历史非常干净,分支图也非常线性清晰。

non-fast forward:在合并分支时,Git 需要创建一个新的合并提交,将两个分支的更改集成在一起。这种方式的合并操作会在提交历史中创建一个新的合并节点,显示两个分支的合并点。

image-20240418182306193

2,分支合并冲突问题

场景1:master分支和dev分支各自都分别有新的提交,在这种情况下,Git试图把各自的修改合并起来,但这种合并就可能会有冲突。

当Git合并分支时,如果发现有冲突,它会在文件中标记出这些冲突,这种标记使用<<<<<<<=======,和>>>>>>>来区分不同分支的内容。

这时,你需要手动解决这个冲突,编辑文件,然后提交解决后的结果。这样做可以确保冲突得到正确解决,并且合并结果被正确保存。

image-20240418222849741

场景2:现有主分支master运行代码程序,修复分支fix修复bug,开发分支dev2开发功能,fix分支和dev2分支都有新的提交,在这种情况下,Git试图把各自的修改合并起来,会出现合并冲突。

当将修复分支(fix)合并到主分支(master)后,接着再把功能分支(dev2)合并至主分支,可能引入了一些与正在开发的功能(在dev2分支上)不兼容的更改,从而导致主分支的代码出现错误。

image-20240418230808530

解决这个问题的方法就是:在dev2分支上合并master,再让master去合并dev2,这样做的目的是有冲突可以在dev2分支上解决并进行测试,而不影响master主分支。

image-20240418230609198


四,远程操作

4.1,远程仓库克隆

1,使用HTTPS方式克隆

git clone https:....

2,使用SSH方式克隆

git clone ssh:....

注:在使用SSH方式克隆仓库时,需要添加公钥至远程仓库中,如果未进行添加,服务器会拒绝我们的clone操作。设置方式:

  1. 查看服务器主目录中有没有.ssh目录

  2. 再看.ssh目录中有没有id_rsa(私钥)id_rsa.pub(公钥)这两个文件

  3. 如果没有上述两个文件,则需要创建SSH KEY

    ssh-keygen -t rsa -C "邮箱"     # 邮箱要与Gitee上的保持一致
    
  4. 使用cat命令查看id_rsa.pub(公钥)这个文件,然后将出现的一串公钥复制

  5. 把复制的公钥粘贴至Gitee的添加公钥页面,确认即可


4.2,远程仓库推送

远程仓库克隆到本地仓库之后,需要配置本地仓库的user.name和user.email。操作命令如下:

git config [user.name/user.email] [值]

这里的用户名和邮箱也要和Gitee上的保持一致。

git push [远程仓库名] [本地分支]:[远程分支]

如果本地分支和远程分支相同,可以省略:[远程分支]


4.3,远程仓库拉取

在日常开发工作中,需要从远处仓库中拉取最新的代码,操作命令如下:

git pull [远程仓库名] [远程分支]:[本地分支]

五,标签管理

在Git中,标签(tag)是用于标记特定提交的版本号或者别名。标签可以帮助你在代码库中标记重要的里程碑、版本发布等信息。

5.1,创建标签

1,轻量级标签(Lightweight Tags):只是一个指向特定提交的引用

git tag <tag_name>

2,带注释的标签(Annotated Tags):包含更多关于该标签的信息,如标签作者,发布日期,发布说明等

git tag -a <tag_name> -m "tag message"

5.2,查看标签

1,查看所有标签:

git tag

2,查看特定标签的详细信息:

git show <tag_name>

5.3,删除标签

git tag -d <tag_name>

5.4,推送标签到远程仓库

1,推送单个标签:

git push origin <tag_name>

2,推送所有标签:

git push origin --tags

5.5,删除远程仓库上的标签

git push origin --delete <tag_name>

结语

这就是本期博客的全部内容啦!如果有什么其他的问题无法自己解决,可以在评论区留言哦!

最后,如果你觉得这篇文章写的还不错的话或者有所收获的话,麻烦小伙伴们动动你们的小手,给个三连呗(点
赞👍,评论✍,收藏📖),多多支持一下!各位的支持是我最大的动力,后期不断更新优质的内容来帮助大家,一起进步。那我们下期见!


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

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

相关文章

JAVA前端快速入门基础_javascript入门(01)

写在前面:本文用于快速学会简易的JS&#xff0c;仅做扫盲和参考作用 1.JS是什么 JavaScript是一门跨平台&#xff0c;面向对象的脚本语言(即不需要编译&#xff0c;可以直接通过浏览器进行解释)。JS和Java是两门完全不相同的语言&#xff0c;但是基础的语法是类似的 2.JS的引…

uniapp 微信小程序 分享海报的实现

主页面 <template><view class"page"><!-- 自定义导航栏--><Navbar title"我的海报"></Navbar><view class"container"><poster ref"poster" :imageUrl"image" :imageWidth"7…

【MHA】MySQL高可用MHA源码1-主库故障监控

1 阅读之前的准备工作 1 一个IDE工具 &#xff0c;博主自己尝试了vscode安装perl的插件&#xff0c;但是函数 、变量 、模块等都不能跳转&#xff0c;阅读起来不是很方便。后来尝试使用了pycharm安装perl插件&#xff0c;阅读支持跳转&#xff0c;自己也能写一些简单的测试样例…

达梦(DM) SQL日期操作及分析函数

达梦DM SQL日期操作及分析函数 日期操作SYSDATEEXTRACT判断一年是否为闰年周的计算确定某月内第一个和最后一个周末某天的日期确定指定年份季度的开始日期和结束日期补充范围内丢失的值按照给定的时间单位查找使用日期的特殊部分比较记录 范围处理分析函数定位连续值的范围查找…

【定制化体验:使用Spring Boot自动配置,打造个性化Starter】

项目结构 Pom <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http://maven.apache.org/POM/4…

LabVIEW高效目标跟踪系统

LabVIEW高效目标跟踪系统 随着机器视觉技术的飞速发展&#xff0c;设计和实现高效的目标跟踪系统成为了众多领域关注的焦点。基于LabVIEW平台&#xff0c;结合NI Vision机器视觉库&#xff0c;开发了一种既高效又灵活的目标跟踪系统。通过面向对象编程方法和队列消息处理器程序…

【CTF Crypto】CTFShow 萌新 密码3 Writeup(摩尔斯电码+培根密码)

萌新 密码3 3 题目名称&#xff1a;我想吃培根 题目描述&#xff1a; – — .-. … . …–.- … … …–.- -.-. — — .-… …–.- -… …- - …–.- -… .- -.-. — -. …–.- … … …–.- -.-. — — .-… . .-. …–.- – – -… -… – -… – -… – – – -… -… -……

鸿蒙(HarmonyOS)性能优化实战-Trace使用教程

概述 OpenHarmony的DFX子系统提供了为应用框架以及系统底座核心模块的性能打点能力&#xff0c;每一处打点即是一个Trace&#xff0c;其上附带了记录执行时间、运行时格式化数据、进程或线程信息等。开发者可以使用SmartPerf-Host调试工具对Trace进行解析&#xff0c;在其绘制…

yudao-cloud微服务系统系统模块+后台管理系统成功运行

&#x1f339;作者主页&#xff1a;青花锁 &#x1f339;简介&#xff1a;Java领域优质创作者&#x1f3c6;、Java微服务架构公号作者&#x1f604; &#x1f339;简历模板、学习资料、面试题库、技术互助 &#x1f339;文末获取联系方式 &#x1f4dd; 系列文章目录 第一章 芋…

精酿啤酒:酿造工艺的自动化与智能化发展

随着科技的不断进步&#xff0c;自动化与智能化已成为啤酒酿造工艺的重要发展方向。Fendi Club啤酒紧跟时代潮流&#xff0c;积极推动酿造工艺的自动化与智能化发展&#xff0c;旨在提高生产效率、确保产品品质和满足市场需求。 Fendi Club啤酒引入自动化生产设备。他们采用自动…

rabbitmq集群配置

1&#xff0c;配置环境变量 MY_POD_NAME&#xff1a;当前Pod的名称 RABBITMQ_ERLANG_COOKIE&#xff1a;设置Erlang Cookie用于节点间通信安全验证&#xff0c;值来自/nfs/rabbitmq/lib/.erlang.cookie文件内容 RABBITMQ_NODENAME&#xff1a;根据Pod名称动态生成了RabbitMQ…

Typora for Mac:轻量级Markdown编辑器

Typora for Mac是一款专为Mac用户设计的轻量级Markdown编辑器&#xff0c;它以其简洁的界面和强大的功能&#xff0c;成为了Markdown写作爱好者的首选工具。 Typora for Mac v1.8.10中文激活版下载 Typora的最大特色在于其所见即所得的编辑模式&#xff0c;用户无需关心复杂的M…

【软件】ERETCAD-Env:在轨空间环境3D动态仿真软件

文章介绍了Extreme-environment Radiation Effect Technology Computer-Aided Design – Environment (ERETCAD-Env)软件&#xff0c;文章的介绍和展示了ERETCAD-Env软件的功能和特点&#xff0c;这是一款用于动态模拟在轨卫星所处空间环境的计算机辅助设计软件。强调了该软件在…

TCP关闭连接时的一些思考

TCP协议是TCP/IP栈中最复杂的协议&#xff0c;它最大的优点是传输的可靠性&#xff0c;这通过面向连接、按序传输、超时重传、流量控制等机制保证其传输的可靠性。但这并不是我们今天要讨论的重点&#xff01; TCP通信的过程分别是三个阶段&#xff1a;建立连接、传输数据、关…

SpringCloud Hystrix 实战

一、配置 1.引入jar包 单独使用hystrix &#xff0c;不配合openFegin使用的话&#xff0c;单独使用hystrix,需要引入spring-cloud-starter-netflix-hystrix包。要使用的hystrix-dashboard 界面的话需要引入spring-boot-starter-actuator 包和spring-cloud-starter-netflix-hy…

SpringBoot中多数据源灵活切换解决方案

本篇内容介绍了“SpringBoot中如何使用Dynamic Datasource配置多数据源”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! 源码地址/文档说明 功能特性: 支持 数据源分组…

通信原理(2)--随机过程

通信原理(2)–随机过程 3.1随机过程的基本概念 随机过程{x(t)}由一族时间函数 x i ( t ) x_i(t) xi​(t)&#xff0c;i1,2.3…组成&#xff0c;每一个时间函数 x i ( t ) x_i(t) xi​(t)称为随机过程{x(t)}的一个样本函数&#xff08;一个实现&#xff09; 每个样本函数在时间…

python-opencv实现最近邻插值和双线性插值对图片上采样

使用背景 当我们需要把图像进行放大或者缩小的时候&#xff0c;第一反应是使用resize()实现。很多情况下&#xff0c;我们会调用最近邻插值和双线性插值去放大图片&#xff0c;当然要说没有分辨率的损失那是不可能的&#xff0c;只能说在放大图片的过程中尽可能增加了图片的分…

Hybrid Homomorphic Encryption:SE + HE

参考文献&#xff1a; [NLV11] Naehrig M, Lauter K, Vaikuntanathan V. Can homomorphic encryption be practical?[C]//Proceedings of the 3rd ACM workshop on Cloud computing security workshop. 2011: 113-124.[MJS16] Maux P, Journault A, Standaert F X, et al. To…

Matlab|交直流系统潮流计算(含5种控制模式)

目录 1 主要内容 程序参考流程图 2 部分代码 3 程序结果 4 下载链接 1 主要内容 该程序参考文献《交直流系统潮流计算及相互关联特性分析》&#xff0c;采用5种交直流潮流控制方式&#xff1a;1.定电流定电压 2.定电流定熄弧角 3.定功率定电压 4.定功率定熄弧角 5.定触发角…