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,并在日常开发中得到应用。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

ESP32学习(2)——点亮LED灯

1.前期准备 开发板原理图如下&#xff1a; 可见LED灯接在了GPIO2口 那么要如何编写代码控制GPIO口的电平高低呢&#xff1f; 我们可以参考micropython的官方文档Quick reference for the ESP32 — MicroPython latest documentation 可见&#xff0c;需要导入machine包 若要…

【教程】C++语言基础学习笔记(九)——指针

写在前面&#xff1a; 如果文章对你有帮助&#xff0c;记得点赞关注加收藏一波&#xff0c;利于以后需要的时候复习&#xff0c;多谢支持&#xff01; 【C语言基础学习】系列文章 第一章 《项目与程序结构》 第二章 《数据类型》 第三章 《运算符》 第四章 《流程控制》 第五章…

面向智算服务,构建可观测体系最佳实践

作者&#xff1a;蓟北 构建面向 AI、大数据、容器的可观测体系 &#xff08;一&#xff09;智算服务可观测概况 对于越来越火爆的人工智能领域来说&#xff0c;MLOps 是解决这一领域的系统工程&#xff0c;它结合了所有与机器学习相关的任务和流程&#xff0c;从数据管理、建…

【C语言】内存函数memcpy和memmove的功能与模拟实现

1.memcpy 功能&#xff1a;把source指向的前num个字节内容拷贝到destination指向的位置去&#xff0c;可以拷贝任意类型的数据。 注&#xff1a;1.memcpy并不关心\0&#xff0c;毕竟传的也不一定是字符串&#xff0c;因此拷贝过程中遇到\0也不会停下来。 2.num的单位是字节&a…

基于Echarts的可视化项目

整体的效果 概览区域 <!-- 概览区域模块制作 --><div class"panel overview"><div class"inner"><ul><li><h4>2190</h4><span><i class"icon-dot"></i>设备总数</span></…

Java 基于springboot+vue在线外卖点餐系统,附源码

博主介绍&#xff1a;✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;…

深度学习的新进展:探索人工智能的未来

文章目录 &#x1f4d1;引言深度学习技术概述计算机视觉领域的深度应用自然语言处理的深度革命跨领域应用的深度拓展深度学习的挑战与未来展望结语 &#x1f4d1;引言 在科技日新月异的今天&#xff0c;深度学习作为人工智能领域的一颗璀璨明珠&#xff0c;正在引领着技术创新…

ElasticSearch分词器和相关性详解

目录 ES分词器详解 基本概念 分词发生时期 分词器的组成 切词器&#xff1a;Tokenizer 词项过滤器&#xff1a;Token Filter 停用词 同义词 字符过滤器&#xff1a;Character Filter HTML 标签过滤器&#xff1a;HTML Strip Character Filter 字符映射过滤器&#x…

linux系统zabbix监控配置电话告警

电话报警 睿象云官网操作zabbix-server主机操作睿象云操作zabbix-server的web页面操作 睿象云官网&#xff1a;https://www.aiops.com/ 睿象云官网操作 登录睿象云平台后点击智能告警平台 在集成栏选择监控工具选择zabbix 填写应用名称保存并获取key zabbix-server主机操…

php基础学习之文件包含

描述 在一个php脚本中&#xff0c;将另一个php文件包含进来&#xff0c;合作实现某种功能 这个描述看起来似乎和C/Java等语言的头文件/包有点类似&#xff0c;但本质是不一样的 打个比方&#xff1a; C/Java的头文件/包更像是一个工具箱&#xff0c;存放各种很完善的工具&#…

找不到目标和方向,怎么办?

现代社会里&#xff0c;许多人常见的症状&#xff0c;就是「空心病」。 什么是空心病呢&#xff1f;类似这样&#xff1a; 我知道要有目标&#xff0c;但我就是不知道想做什么&#xff0c;感觉对一切事物都提不起兴趣&#xff0c;没有动力&#xff0c;怎么办&#xff1f; 这个…

骑士遍历初级版

时间限制&#xff1a;1秒 内存限制&#xff1a;128M 题目描述 如图&#xff0c;从左下角A点出发&#xff0c;马只能向右走&#xff0c;根据马走日字的规则&#xff0c;究竟如何走才能到达右上角B点 输入描述 两个整数x、y&#xff0c;代表右上角B点的坐标&#xff0c…

AcWing 112. 雷达设备(区间贪心)

[题目概述] 假设海岸是一条无限长的直线&#xff0c;陆地位于海岸的一侧&#xff0c;海洋位于另外一侧。 每个小岛都位于海洋一侧的某个点上。 雷达装置均位于海岸线上&#xff0c;且雷达的监测范围为 d&#xff0c;当小岛与某雷达的距离不超过 d 时&#xff0c;该小岛可以被雷…

Excel练习:日历

Excel练习&#xff1a;日历 ‍ 题目&#xff1a;制作日历 ‍ ​​ 用rows和columns函数计算日期单元格偏移量 一个公式填充所有日期单元格 ​​ ‍

FT2232调试记录(2)

FT2232调试记录 &#xff08;1&#xff09;获取当前连接的FTDI设备通道个数:&#xff08;2&#xff09;获取当前连接的设备通道的信息:&#xff08;3&#xff09;配置SPI的通道:&#xff08;4&#xff09;如何设置GPIO:&#xff08;5&#xff09;DEMO测试&#xff1a; FT2232调…

Unity 工具之 UniWebView 内嵌网页/浏览器到应用中,并且根据UGUI大小放置(简单适配UGUI)

目录 Unity 工具之 UniWebView 内嵌网页/浏览器到应用中&#xff0c;并且根据UGUI大小放置&#xff08;简单适配UGUI&#xff09; 一、简单介绍 二、UniWebView 组件上的几个参数属性选项介绍 三、一些关键接口介绍 四、Transition 五、Memory Management&#xff08;内存…

OJ刷题:找出单身狗1,2【建议收藏点赞】

目录 1. 单身狗12. 单身狗2 1. 单身狗1 代码实现&#xff1a; #include <stdio.h>int main() {int arr[] { 1,2,3,2,1 };int sz sizeof(arr) / sizeof(arr[0]);int i 0;int tmp 0;for (i 0; i < sz; i){tmp ^ arr[i];}printf("%d\n", tmp);return 0; …

微信小程序介绍、账号申请、开发者工具目录结构详解及小程序配置

目录 一、微信小程序介绍 1.什么是小程序&#xff1f; 2.小程序可以干什么&#xff1f; 3.微信小程序特点 二、账号申请 1.账号注册 2.测试号申请 三、安装开发工具 四、开发小程序 五、目录结构 JSON 配置 小程序配置 app.json 工具配置 project.config.json 页…

PHP毕业设计图片分享网站76t17

图片分享网站主要是为了提高工作人员的工作效率和更方便快捷的满足用户&#xff0c;更好存储所有数据信息及快速方便的检索功能&#xff0c;对系统的各个模块是通过许多今天的发达系统做出合理的分析来确定考虑用户的可操作性&#xff0c;遵循开发的系统优化的原则&#xff0c;…

Linux 查看 系统基本信息 uname

基本用法&#xff1a; 在终端中输入"uname"即可显示系统的内核名称。 可以结合不同的参数使用&#xff0c;获取更详细的系统信息。 常见参数&#xff1a; “-s”&#xff1a;显示操作系统名称。 “-n”&#xff1a;显示网络节点主机名。 “-r”&#xff1a;显示内核版…