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.hqwc.cn/news/470686.html

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

相关文章

无人机地面站技术,无人机地面站理论基础详解

地面站作为整个无人机系统的作战指挥中心&#xff0c;其控制内容包括:飞行器的飞行过程&#xff0c;飞行航迹&#xff0c; 有效载荷的任务功能&#xff0c;通讯链路的正常工作&#xff0c;以及 飞行器的发射和回收。 无人机地面站总述 地面站作为整个无人机系统的作战指挥中心…

分层图最短路

分层最短路用更加具体或者形象一点的说法就是有限制的最短路径问题。 通常是拆点解决问题,原图中的点加上一个当前点的状态&#xff0c;成为一个新的点 P4568 [JLOI2011] 飞行路线 P4568 [JLOI2011] 飞行路线 #include <bits/stdc.h> #define int long long #define …

2024.2.14

1.请编程实现二维数组的杨慧三角 #include<stdio.h> #include<string.h> int main(int argc, const char *argv[]) { int n,i,j;printf("please enter n:");scanf("%d",&n);int arr[n][n];for(i0;i<n;i){for(j0;j<i;j){if(j0 || ij…

C++类和对象-多态->多态的基本语法、多态的原理剖析、纯虚函数和抽象类、虚析构和纯虚析构

#include<iostream> using namespace std; //多态 //动物类 class Animal { public: //Speak函数就是虚函数 //函数前面加上virtual关键字&#xff0c;变成虚函数&#xff0c;那么编译器在编译的时候就不能确定函数调用了。 virtual void speak() { …

C++文件操作->文本文件(->写文件、读文件)、二进制文件(->写文件、读文件)

#include<iostream> using namespace std; #include <fstream>//头文件包含 //文本文件 写文件 void test01() { //1.包含头文件 fstream //2.创建流对象 ofstream ofs; //3.指定打开方式 ofs.open("test.txt", ios::out); //4.写…

将人工智能应用于 DNS 流量以阻止恶意软件感染

Infoblox Inc. 透露&#xff0c;它正在利用人工智能 (AI) 来识别恶意软件来源的网站。然后可以阻止这些网站以使 IT 环境更加安全。 Infoblox 产品管理副总裁 Craig Sanderson 桑德森表示&#xff0c;SOC Insights 将机器学习算法应用于 BloxOne 威胁防御平台域名服务器 (DNS)…

[职场] 生育津贴如何申领与计算 #经验分享#微信#职场发展

生育津贴如何申领与计算 生育津贴如何申领? 生育津贴即为产假工资&#xff0c;相当于女职工在享受符合生育政策休假期间的工资。生育津贴高于本人产假工资标准的&#xff0c;用人单位不得克扣生育津贴低于本人产假工资标准的&#xff0c;差额部分由用人单位补足。 一、大部…

ArcgisForJS基础

文章目录 0.引言1.第一个ArcgisForJS应用程序1.1.安装部署ArcgisForJS1.2.实现ArcgisForJS应用程序 2.开发与调试工具2.1.集成开发环境2.2.调试工具2.3.Firebug 0.引言 ArcGIS API for JavaScript是一款由Esri公司开发的用于创建WebGIS应用的JavaScript库。它允许开发者通过调…

Vi 和 Vim 编辑器

Vi 和 Vim 编辑器 vi 和 vim 的基本介绍 Linux 系统会内置 vi 文本编辑器 Vim 具有程序编辑的能力&#xff0c;可以看做是 Vi 的增强版本&#xff0c;可以主动的以字体颜色辨别语法的正确性&#xff0c;方便程序设计。 代码补完、编译及错误跳转等方便编程的功能特别丰富&…

探索设计模式的魅力:创建型设计模式的比较与决策

设计模式专栏&#xff1a;http://t.csdnimg.cn/U54zu 目录 一、设计模式概览 1.1 创建型模式 二、比较创建型设计模式 1.1 适用场景典型用例 1.2 关键要素与差异对比 1.3 结构图 三、模式选择指南 3.1 场景分析 3.2 决策流程图 四、结语 4.1 优势 4.2 考量因素 一、…

MySQL 基础知识(六)之数据查询(二)

目录 6 数值型函数 7 字符串函数 8 流程控制函数 9 聚合函数 10 分组查询 (group by) 11 分组过滤 (having) 12 限定查询 (limit) 13 多表查询 13.1 连接条件关键词 (on、using) 13.2 连接算法 13.3 交叉连接 (cross join) 13.4 内连接 (inner join) 13.5 外连接 …

装饰工程|装饰工程管理系统-项目立项子系统的设计与实现|基于Springboot的装饰工程管理系统设计与实现(源码+数据库+文档)

装饰工程管理系统-项目立项子系统目录 目录 基于Springboot的装饰工程管理系统设计与实现 一、前言 二、系统功能设计 三、系统实现 1、管理员功能实现 &#xff08;2&#xff09;合同报价管理 &#xff08;3&#xff09;装饰材料总计划管理 &#xff08;4&#xff0…