Git快速掌握,通俗易懂

Git分布式版本控制工具

介绍


Git是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。Git是由Linus Torvalds为了帮助管理Linux内核开发而开发的一个开放源码的版本控制软件。Git可以帮助开发者们管理代码的版本,避免代码冲突,方便合并代码等。而在当下Git已经成为最重要的开发工具之一

什么是版本控制?

前面说了这么多,肯定会有博友会问,既然Git是一个版本控制工具,那版本控制又是什么呢?

版本控制是一种记录一个或若干文件内容变化,以便将来查阅特定版本修订情况的系统。它可以帮助你管理项目中的文件、代码和数据,跟踪它们的变化,以及协同团队成员之间的工作。

举个例子,对于软件来说,我们所知的修图软件ps有2023版、2022版等不同版本,而代码编辑器vscode也有2021版、2019版等多个版本。这里所指的就是这些软件的版本。对于文件来说,版本控制也是非常重要的。无论是文档、图片还是代码文件,我们都可能需要创建不同版本的副本来追踪和管理变化。

举个例子,假设你正在编辑一份报告文档,你可能会经历多次修改和修订。每次修改后,你可以使用版本控制系统保存一个新的版本,以便随时回溯到之前的版本。这样,如果你发现某个修改有问题或者想要查看之前的更改,你可以轻松地找到并恢复到之前的版本。

另外,版本控制也可以用于团队协作。当多个人同时编辑同一个文件时,版本控制系统可以自动检测冲突并帮助解决。每个人所做的修改都会被视为不同的版本,系统会将它们合并在一起,确保最终的文件是完整且没有冲突的。

为什么要学习Git?

常见的版本控制工具有Git、Subversion(SVN)、Mercurial等,而Git因为其开源的特性已经是现在最流行的版本控制工具

Git不仅可以进行版本控制,还能将文件内容以及版本记录保存在远程服务器上。这样,无论你在哪里,只要有网络连接,就可以获取到你的项目文件,极大地提高了工作的便捷性。

虽然Git在存储空间上比SVN更占用空间,(因为Git在每个端都保留了所有的版本历史),但是其在流行程度、功能丰富方面却比SVN有优势。Git 相对于SVN不仅仅是个版本控制系统,它也是个内容管理系统,工作管理系统等。因此,学习Git无疑是一个值得的选择。

git工作原理 / 流程:

fetch/clone
checkout
push
checkout
add
commit
Remote
Repository
workspace
lndex

Workspace:工作区
Index / Stage:暂存区
Repository:仓库区(或本地仓库)
Remote:远程仓库

这个流程图描述了 Git 的常用命令之间的关系:

  • 开发人员可以使用 git clone 从远程仓库克隆项目到本地。
  • 他们可以使用 git push 将本地仓库的更改推送到远程仓库。
  • 他们可以使用 git add 将文件添加到暂存区。
  • 然后使用 git commit 将暂存区的更改提交到本地仓库。
  • 使用 git checkout 可以在分支之间切换,以及创建新的分支。

git pull 命令包含在 git clonegit checkout 中,因为它用于从远程仓库拉取最新更改到本地仓库。

1. Git安装配置


在使用Git之前,我们需要先安装GitGit目前支持在Linux/Unix、Solaris、Mac和Windows平台上运行。
Git的各平台安装包下载地址如下:https://git-scm.com/downloads
在这里插入图片描述
点击Windonws版本安装即可,完成安装之后,就可以使用命令行的 git 工具

在这里插入图片描述
我们点击右键这里会出现两个新的右键菜单,一个叫做Git GUI here,一个叫做Git Bash here

  • Git GUI here就是它自带的客户端工具
  • Git Bash here是一个命令行窗口

基本配置

点击Git Bash here在命令行窗口进行一下配置

1.设置用户信息

用户名:

git config --global user.name "注册名"

邮箱:

git config --global user.email "注册邮箱"

2.查看配置信息

查看全局配置信息:

git config --global --list

这将列出全局配置信息,包括用户名、邮箱等。
在这里插入图片描述

2. 远程仓库配置


远程仓库有很多,比如github,国内的码云,局域网自建git服务器,托管在其他地方的服务器,本文以github为例
网址https://github.com没有注册的可以先去注册一下

新建仓库: 点击右上角,加号,new repository
在这里插入图片描述

下一步
请添加图片描述

填写完成后 点击右下发创建存储库
在这里插入图片描述

如,我已经建立好的仓库
在这里插入图片描述

3. 生成(配置)SSH


git客户端安装后,如何和远程仓库,如github连接呢?我们使用SSH。

SSH是Secure Shell的缩写,它是一种用于安全远程登录到计算机系统并在网络上传输数据的协议。SSH通过加密的方式保护数据在网络上传输的安全性,因此它广泛应用于远程管理和文件传输

我们刚注册完账号后还没有配置SSH密钥,我们先生成一个SSH
在这里插入图片描述

检查是否已有SSH密钥对:

在终端(Linux和macOS)或命令提示符(Windows)中运行以下命令来检查是否已经存在SSH密钥对:

ls -al ~/.ssh

如果已经存在密钥对,则会显示在该目录下。

生成SSH(以有SSH可以跳过这一步)

ssh-keygen -t rsa -C "自己的邮箱"

生成成功,如下图所示:
SSH文件存放在C:/User/用户/.ssh

  • id_rsa: 这是你的SSH私钥文件。私钥文件用于身份验证,通常不应该泄露给其他人。

  • id_rsa.pub: 这是与私钥相关联的公钥文件。公钥文件可以与他人共享,以便他们将其添加到他们的服务器上,以允许你通过私钥进行身份验证

在这里插入图片描述

如果找不到C:/User/用户/.ssh

生成一个新的SSH密钥
打开 Git Bash,输入如下命令,然后连续按三个回车即可:

ssh-keygen -t rsa -C "你的邮箱"

然后会出来提示Enter file in which to save the key 后面是一个路径,你就会找到你想要的.ssh文件夹了,去电脑里找吧
在这里插入图片描述

github配置SSH

用记事本打开id_rsa.pub文件,全选,复制全文
在这里插入图片描述

打开github 点击右上角用户头像 点击设置 点击SSH密钥
请添加图片描述

点击New SSH key创建一个新SSH密钥
请添加图片描述

起一个标题,将之前复制的密钥粘贴上去
在这里插入图片描述

测试SSH连接,在控制台输入

ssh -T git@github.com

按照提示输入yes,回车,提示successfully之类的就说明SSH连接正常,github上的钥匙也会变成绿色
在这里插入图片描述

4. 推送文件到远程仓库


建立本地仓库

选择一个需要版本管理的项目文件夹,这里以我桌面的一个文件夹为例
在这里插入图片描述
打开文件夹右键 git bash中执行命令,将该文件夹初始化为一个仓库

git init

在这里插入图片描述
执行命令后文件夹内会出现一个隐藏的文件夹.git,没有的话,设置一下文件夹选项,显示隐藏文件
在这里插入图片描述

远程推送文件

基本流程:add->commit->push

  1. 添加并提交文件到本地仓库:
    使用 git add 命令将文件添加到暂存区,然后使用 git commit 命令将文件提交到本地仓库:

    git add <文件名>
    git commit -m "提交信息"
    
  2. 连接到远程仓库:
    如果还没有连接到远程仓库,你需要使用 git remote add 命令添加远程仓库地址:

    git remote add origin <远程仓库URL>
    

    其中 <远程仓库URL> 是你在GitHub上创建的仓库的地址。
    在这里插入图片描述

  3. 推送本地提交到远程仓库:
    一旦连接到了远程仓库,你可以使用 git push 命令将本地提交推送到远程仓库:

    git push origin <分支名>
    

    其中 <分支名> 是你要推送到的远程仓库的分支名称。

    如果想要首次推送到 master(主要分支),加上 -u 参数会将本地分支与远程分支关联起来。

    git push -u origin master
    

在这里插入图片描述
提交成功
在这里插入图片描述

常用的Git命令及其用法


  1. git init:初始化一个新的Git仓库。

    git init
    
  2. git clone:克隆现有仓库到本地。

    git clone <仓库URL>
    
  3. git add:将文件添加到暂存区。

    git add <文件名>
    
  4. git commit:将暂存区中的文件提交到本地仓库。

    git commit -m "提交信息"
    
  5. git status:查看当前工作区和暂存区的状态。

    git status
    
  6. git log:查看提交历史记录。

    git log
    
  7. git branch:列出本地分支,或者创建新分支。

    git branch <分支名>
    
  8. git checkout:切换分支。

    git checkout <分支名>
    
  9. git merge:合并指定分支到当前分支。

    git merge <要合并的分支>
    
  10. git pull:拉取远程仓库的变化并合并到本地。

    git pull origin <分支名>
    
  11. git push:推送本地变化到远程仓库。

    git push origin <分支名>
    
  12. git remote -v:查看远程仓库的信息。

    git remote -v
    
  13. git remote add:添加一个新的远程仓库。

    git remote add <远程仓库名> <仓库URL>
    
  14. git remote remove:移除指定的远程仓库。

    git remote remove <远程仓库名>
    
  15. git diff:查看工作区与暂存区的差异。

    git diff
    

这些是Git中一些常见的命令,但Git还提供了许多其他功能强大的命令,可以根据实际需要查阅Git官方文档或者通过 git --help 查看帮助信息。

结语


Git是一个强大的版本控制系统,通过掌握上述基本概念和常用命令,你可以更好地管理和协作项目代码。除了本文介绍的内容,Git还有许多高级功能和技巧,可以根据实际需求进行学习和探索。希望本文能够帮助你快速入门Git,并在日常开发中得到应用。

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

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

相关文章

怎么用postman调用webservice(反推SoapUI)

<soapenv:Envelope xmlns:soapenv“http://schemas.xmlsoap.org/soap/envelope/” xmlns:lis“LisDataTrasen”> soapenv:Header/ soapenv:Body lis:Test lis:test111111111</lis:test> </lis:Test> </soapenv:Body> </soapenv:Envelope> Conten…

html从零开始8:css3新特性、动画、媒体查询、雪碧图、字体图标【搬代码】

css3新特性 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge"><meta name"viewport" content"widthdevice-width, …

35岁转行,是我人生中最正确的选择

前言 经常听到有人说&#xff0c;35岁是职场的分水岭&#xff0c;但我觉得我的35岁&#xff0c;人生才刚刚开始。 35岁前后&#xff0c;我生二胎&#xff0c;考研&#xff0c;跳槽&#xff0c;转行&#xff0c;从传统行业到服务业&#xff0c;从服务业到新能源行业&#xff0…

ctfshow-文件上传(web151-web161)

目录 web151 web152 web153 web154 web155 web156 web157 web158 web159 web160 web161 web151 提示前台验证不可靠 那限制条件估计就是在前端设置的 上传php小马后 弹出了窗口说不支持的格式 查看源码 这一条很关键 这种不懂直接ai搜 意思就是限制了上传类型 允许…

波奇学Linux:文件系统

磁盘认识 磁盘被访问的基本单元是扇区-512字节。 磁盘可以看成多个同心圆&#xff0c;每个同心圆叫做磁道&#xff0c;多个扇区组成同心圆。 我们可以把磁盘看做由无数个扇区构成的存储介质。 要把数据存到磁盘&#xff0c;先定位扇区&#xff0c;用哪一个磁头&#xff0c;…

[word] word中怎么插入另外一个word文档 #媒体#职场发展

word中怎么插入另外一个word文档 word中怎么插入另外一个word文档&#xff1f;有有些小伙伴在制作文档的时候&#xff0c;可能需要用到多个文档进行配合制作&#xff0c;今天小Q来给大家演示一下&#xff0c;插入Word文档的方法&#xff0c;插入其他类型文档的方法也是一样的。…

Excel模板2:进度条甘特图

Excel模板2&#xff1a;进度条甘特图 ‍ 今天复刻B站up【名字叫麦兜的狗狗】的甘特图&#xff1a;还在买Excel模板吗&#xff1f;自己做漂亮简洁的甘特图吧&#xff01;_哔哩哔哩_bilibili 阿里网盘永久分享&#xff1a;https://www.alipan.com/s/cXhq1PNJfdm 当前效果&…

【无标题】Matlab之annotation函数——创建图形注释(箭头、椭圆、矩形)

应用1&#xff1a;创建文本箭头注释 创建一个简单线图并向图窗添加文本箭头。用归一化的图窗坐标指定文本箭头位置&#xff0c;起点为 (0.3,0.6)&#xff0c;终点为 (0.5,0.5)。通过设置 String 属性指定文本说明。 figure plot(1:10) x [0.3 0.5]; y [0.6 0.5]; annotation…

高中信息技术—数据采集与编码(二)

编码 编码是指信息按照某种格式转化为另一种格式的过程。 在计算机领域编码主要分为字符编码、条形码、二维码、声音编码、图像编码、视频编码 计算机存储容量单位 计算机中最小的存储单位&#xff1a;位&#xff0c;bit或b 计算机中基本单位&#xff1a;字节&#xff0c;Byte…

[UI5 常用控件] 09.IconTabBar,IconTabHeader,TabContainer

文章目录 前言1. IconTabBar1.1 简介1.2 基本结构1.3 用法1.3.1 颜色&#xff0c;拖放&#xff0c;溢出1.3.2 Icons Only , Inner Contents1.3.3 showAll,Count,key,IconTabSeparator 1.3.4 Only Text1.3.5 headerMode-Inline1.3.6 design,IconTabSeparator-icon1.3.7 DensityM…

分布式文件系统 SpringBoot+FastDFS+Vue.js【二】

分布式文件系统 SpringBootFastDFSVue.js【二】 六、实现上传功能并展示数据6.1.创建数据库6.2.创建spring boot项目fastDFS-java6.3.引入依赖6.3.fastdfs-client配置文件6.4.跨域配置GlobalCrosConfig.java6.5.创建模型--实体类6.5.1.FastDfsFile.java6.5.2.FastDfsFileType.j…

【并发编程】AQS原理

&#x1f4dd;个人主页&#xff1a;五敷有你 &#x1f525;系列专栏&#xff1a;并发编程 ⛺️稳中求进&#xff0c;晒太阳 1. 概述 全称是 AbstractQueuedSynchronizer&#xff0c;是阻塞式锁和相关的同步器工具的框架 特点&#xff1a; 用 state 属性来表示资源的状…

网络爬虫实战 | 上传以及下载处理后的文件

以实现爬虫一个简单的&#xff08;SimFIR (doctrp.top)&#xff09;网址为例&#xff0c;需要遵循几个步骤&#xff1a; 1. 分析网页结构 首先&#xff0c;需要分析该网页的结构&#xff0c;了解图片是如何存储和组织的。这通常涉及查看网页的HTML源代码&#xff0c;可能还包…

从汇编角度解释线程间互斥-mutex互斥锁与lock_guard的使用

多线程并发的竞态问题 我们创建三个线程同时进行购票&#xff0c;代码如下 #include<iostream> #include<thread> #include<list> using namespace std; //总票数 int ticketCount100; //售票线程 void sellTicket(int idx) {while(ticketCount>0){cou…

图像识别基础之模板匹配

principle 图像匹配 本质&#xff1a;图像的相似度很高(矩阵的相似度很高) code /*\brief 我的图像匹配函数&#xff0c;获取差方和均值最小的矩阵作为结果\param srcPicFile:用以匹配的图像文件\param templatePicFile:模板图像文件\param destPicFile:输出的检测结果文件…

leetcode142. 环形链表 II

leetcode142. 环形链表 II 题目 思路 集合法 将节点存入set&#xff0c;若重复出现则说明是环 快慢指针法 分别定义 fast 和 slow 指针&#xff0c;从头结点出发&#xff0c;fast指针每次移动两个节点&#xff0c;slow指针每次移动一个节点&#xff0c;如果 fast 和 slow指…

BIO、NIO、Netty演化总结

关于BIO&#xff08;关于Java NIO的的思考-CSDN博客&#xff09;和NIO&#xff08;关于Java NIO的的思考-CSDN博客&#xff09;在之前的博客里面已经有详细的讲解&#xff0c;这里再总结一下最近学习netty源码的的心得体会 在之前的NIO博客中我们知道接受客户端连接和IO事件的…

懒人精灵 之 Lua 捕获 json解析异常 ,造成的脚本停止.

Time: 2024年2月8日20:21:17 by:MemoryErHero 1 异常代码 Expected value but found T_END at character 12 异常代码 Expected value but found T_OBJ_END at character 223 处理方案 - 正确 json 示范 while true do--Expected value but found T_END at character 1--Ex…

tcp 中使用的定时器

定时器的使用场景主要有两种。 &#xff08;1&#xff09;周期性任务 这是定时器最常用的一种场景&#xff0c;比如 tcp 中的 keepalive 定时器&#xff0c;起到 tcp 连接的两端保活的作用&#xff0c;周期性发送数据包&#xff0c;如果对端回复报文&#xff0c;说明对端还活着…

【lesson53】线程控制

文章目录 线程控制 线程控制 线程创建 代码&#xff1a; 运行代码&#xff1a; 强调一点&#xff0c;线程和进程不一样&#xff0c;进程有父进程的概念&#xff0c;但在线程组里面&#xff0c;所有的线程都是对等关系。 错误检查: 传统的一些函数是&#xff0c;成功返回0&…