Git 分布式版本控制工具使用教程

1.关于Git

1.1  什么是Git

        Git是一款免费、开源的分布式版本控制工具,由Linux创始人Linus Torvalds于2005年开发。它被设计用来处理从很小到非常大的项目,速度和效率都非常高。Git允许多个开发者几乎同时处理同一个项目而不会互相干扰,并且在合并各自的修改时提供强大的支持。主要用于管理开发过程中的源代码文件(Java类、xml文件、html页面等)。
        其他的版本控制工具:SVN、CVS、VSS

1.2 Git的作用 

  • 代码回溯:Git在管理文件过程中会记录日志,方便回退到历史版本      

        Git在每次提交时都会创建一个唯一的提交ID,并记录下文件的快照。这意味着您可以随时查看项目的历史版本,了解每个文件的变化历程,甚至可以恢复到任意一个历史状态。

应用场景:

        错误修复: 如果新添加的代码导致了bug,可以通过git log找到引入问题的提交,然后使用git revertgit reset撤销该次提交。

        实验性开发: 在尝试新的特性或修改现有代码结构时,如果发现改动不理想,可以轻松回退到稳定版本。

  • 版本切换:Git存在分支的概念,一个项目可以有多个分支(版本),可以任意切换

        分支允许开发者在不影响主线(通常是main或master分支)的情况下进行新功能的开发、测试或修复bug。通过切换分支,可以在不同的开发任务之间快速切换

应用场景:        

        并行开发: 团队成员可以在各自的分支上工作,互不干扰。例如,前端开发人员可以在feature/frontend分支上工作,而后端开发人员则在feature/backend分支上工作。
        紧急修复: 当需要对线上版本进行紧急修复时,可以从生产分支(如release分支)创建一个修补分支(hotfix),修复完成后合并回生产分支。

  • 多人协作:Git支持多人协作,即一个团队共同开发一个项目,每个团队成员负责一部分代码,通 过Git就可以管理和协调

        Git通过分布式版本控制系统使得团队协作更加高效。每个人都可以拥有完整的项目副本,包括历史记录,这样即使没有网络连接也能继续工作。

应用场景:

        代码审查: 提交代码前,通常会发起一个Pull/Merge Request,邀请其他团队成员审查代码。这有助于提高代码质量,确保最佳实践得到遵循。

        冲突解决: 当多个开发者同时修改同一部分代码时,可能会发生冲突。Git提供了工具帮助识别和解决这些冲突。

  • 远程备份:Git通过仓库管理文件,在Git中存在远程仓库,如果本地文件丢失还可以从远程仓库获 取

        远程仓库不仅用于同步团队成员的工作进度,也是一个重要的备份手段。即便本地环境出现问题,也可以从远程仓库恢复丢失的数据。

应用场景:

        灾难恢复: 如果本地电脑损坏或者误删了重要文件,可以从远程仓库重新克隆整个项目。
        跨设备同步: 开发者可以在不同设备上工作,只需通过git pull和git push命令保持各处代码库的一致性。

2.Git概述

2.1 Git简介

Git 仓库分为两种:
本地仓库:开发人员自己电脑上的 Git 仓库
远程仓库:远程服务器上的 Git 仓库

commit:提交,将本地文件和版本信息保存到本地仓库
push:推送,将本地仓库文件和版本信息上传到远程仓库
pull:拉取,将远程仓库文件和版本信息下载到本地仓库

 2.2 Git下载与安装

官方下载地址: https://git-scm.com/download
选择合适的版本,下载完成后,双击完成安装即可,安装完成后可以在任意目录下点击鼠标右键,如果能够看到如下菜单则说明安装成功

 Git GUI Here:打开Git 图形界面

 Git Bash Here:打开Git 命令行

 Git安装目录结构如下

 3. Git 和代码托管中心

        代码托管中心是基于网络服务器的远程代码仓库,通常简称为远程库。它允许开发者存储、管理和共享他们的代码,并支持团队协作开发。根据其部署和访问方式的不同,可以分为局域网内的私有部署和互联网上的公共或私有服务。

局域网
        在企业内部或者特定组织内,为了更好地控制数据安全和访问权限,可以选择在局域网内搭建自己的远程代码仓库。

  • GitLab:一个开源的分布式版本控制系统,允许用户自行搭建并管理自己的远程代码仓库。GitLab提供了丰富的功能,包括项目管理、持续集成/持续部署(CI/CD)等,适用于各种规模的企业。
  • Gogs:Gogs是一款极易搭建的自助Git服务,具有轻量级、易于安装的特点。适合希望快速部署一个简单但功能齐全的Git服务器的小型团队或个人开发者。

互联网
        对于需要跨地域协作的团队或希望公开分享自己项目的个人开发者,互联网上的代码托管平台是更好的选择。

  • GitHub:全球最大的代码托管平台之一,拥有庞大的开源社区。尽管它是外网服务,在某些地区可能无法直接访问,但它依然是全球开发者进行代码分享与合作的重要场所。
  • Gitee (码云):作为国内知名的代码托管平台,Gitee为中国的开发者提供了一个高效、稳定的环境来托管代码。它支持公有和私有仓库,非常适合中国境内的团队和个人使用,特别是在需要遵守国内法律法规的情况下。

        无论是选择局域网内的私有部署方案还是互联网上的公共平台,合适的代码托管中心都能极大提升团队的开发效率,促进知识共享和技术进步。同时,考虑到不同地区的网络环境和法律要求,选择适合自己需求的服务至关重要。

4. Git常用命令

4.1 Git全局设置

        在安装Git后,首先要进行的步骤是配置用户名称和电子邮件地址。这是因为每次提交更改时,Git都会使用这些信息来标识提交者。

设置用户信息

执行以下命令来设置全局用户名和电子邮件地址

git config --global user.name "你的名字"
git config --global user.email "你的邮箱地址"//例如
git config --global user.name "张三"
git config --global user.email "zhangsan@example.com"
查看配置信息

通过以下命令查看当前的所有Git配置项

git config --list

其他配置:

设置文本编辑器
默认情况下,Git会使用系统的默认文本编辑器(如vim或nano)。如果你有偏好使用的编辑器,可以通过以下命令设置

git config --global core.editor "编辑器路径"//例如使用VS Code编辑器
git config --global core.editor "code --wait"
配置别名

为了简化常用的Git命令,可以为它们创建别名

git config --global alias.co checkout
git config --global alias.br branch
git config --global alias.ci commit
git config --global alias.st status//也可以使用简短的命令执行
git co   # 等同于 git checkout
git br   # 等同于 git branch
git ci   # 等同于 git commit
git st   # 等同于 git status
查看特定配置项

如果想查看某个特定配置项的值,可以使用以下命令

git config [键名]//例如查看用户名
git config user.name

4.2 获取Git仓库

        要使用Git对代码进行管理,首先需要获得一个Git仓库。获取Git仓库通常有两种方式:在本地初始化一个新的Git仓库从远程仓库克隆

4.2.1 在本地初始化Git仓库

        假设有一个新的项目,还没有任何版本控制,可以在本地初始化一个新的Git仓库。

1.创建一个空目录

        在任意位置创建一个新的空目录,作为你的本地Git仓库。例如,在命令行中执行     

mkdir repo1//创建目录
cd repo1//进入目录
2.打开Git Bash窗口

        选择“Git Bash Here”来打开Git Bash窗口。

3.初始化Git仓库

        在Git Bash窗口中执行以下命令来初始化一个新的Git仓库,这将创建一个名为.git的隐藏文件夹,包含Git所需的所有元数据和配置文件

git init
4.验证Git仓库是否成功创建

        使用以下命令查看当前目录下的所有文件(包括隐藏文件),如果看到.git文件夹,则说明Git仓库已经成功创建

ls -a
5.添加初始文件并提交

        接下来可以添加一些初始文件,并进行第一次提交

echo "# My New Project" >> README.md
git add README.md
git commit -m "Initial commit"

4.2.2 从远程仓库克隆

        从远程仓库克隆是更常见的方式,特别是需要参与一个已有的项目或者基于某个开源项目进行开发时。

1.找到远程仓库地址

        首先你需要知道远程仓库的URL。这通常是一个HTTPS或SSH地址,例如:

  • GitHub: https://github.com/username/repository.git
  • GitLab: git@gitlab.com:username/repository.git
  • Gitee: https://gitee.com/username/repository.git
2.执行克隆命令 

        HTTPS vs SSH:克隆仓库时可以选择使用HTTPS或SSH协议。HTTPS不需要额外配置,但每次操作都需要输入用户名和密码(或个人访问令牌)。SSH则需要配置公钥/私钥对,但一旦配置完成,后续操作无需重复输入凭证

git clone https://github.com/username/repository.git//或者使用SSH方式
git clone git@github.com:username/repository.git

除了git clone外,还有其他常用的远程仓库管理命令,如git remote add(添加新的远程仓库)、git remote remove(移除远程仓库)等 

3.进入克隆下来的仓库目录

         克隆完成后,会自动创建一个与远程仓库同名的目录。进入该目录

cd repository
4.查看当前状态

         可以使用以下命令查看当前仓库的状态,确认所有文件都已正确下载

git status
 5.拉取最新更新

        如果远程仓库有其他人提交了新的更改,可以使用以下命令拉取最新的更新

//这里的main是默认的主分支名称,具体分支名称可能有所不同
git pull origin main

 克隆下来的仓库默认会切换到远程仓库的默认分支(通常是mainmaster)。可以通过

git branch命令查看所有分支,并使用git checkoutgit switch切换分支

 4.3 工作区、暂存区、版本库

        4.3.1 版本库

        版本库是指包含.git隐藏文件夹的整个目录结构,它是Git用来管理项目历史记录的核心组件。版本库存储了项目的完整历史记录、配置信息、日志信息以及各个文件的不同版本

  • 位置: .git文件夹通常位于你的工作区根目录下,并且默认是隐藏的。
  • 内容: 版本库包含了所有提交的历史记录、分支信息、标签、配置文件等。它还保存了每次提交的快照,而不是简单的差异(diff)。
  • 用途: 版本库可以轻松地查看项目的历史版本,回滚到任意一个历史状态,或者在不同的分支之间切换。
    ls -a
    # 输出可能包括 .git 文件夹

        4.3.2 工作区

        工作区是指包含.git文件夹的目录,也就是你当前正在工作的目录。在这个目录中,你可以直接编辑文件、添加新文件或删除文件

  • 位置: 工作区是你日常开发的主要场所,通常是你打开代码编辑器的地方。
  • 内容: 包含所有的源代码文件、资源文件和其他相关文档。这些文件可以是未被Git跟踪的新文件,也可以是已经提交过的旧文件。
  • 用途: 工作区是编写和测试代码的地方。在这里,你可以自由地修改文件,然后决定哪些更改需要提交到版本库。

        4.3.3 暂存区

        暂存区是一个临时区域,用于存放即将提交到版本库的更改。它位于.git文件夹内的index文件中。暂存区允许你在提交之前选择哪些更改应该包含在下一个提交中

  • 位置: 暂存区实际上是由.git/index文件表示的,但它通常被称为“暂存区”或“stage”。
  • 内容: 暂存区保存了那些已经被标记为将要提交的文件更改。这些更改在暂存区中等待最终提交到版本库。
  • 用途: 暂存区提供了一个中间步骤,让你可以在提交之前仔细检查和选择要包含的更改。这有助于保持提交的清晰和有组织性。
//添加文件到暂存区
git add filename.txt//查看暂存区状态
git status//从暂存区移除文件
git reset filename.txt//提交(commit)
git commit -m "本次提交的描述信息"//推送本地提交到远程仓库
git push

 4.4 Git工作区中文件的状态

Git工作区中的文件存在两种状态:

  • untracked 未跟踪(未被纳入版本控制)
  • tracked 已跟踪(被纳入版本控制)

        1)Unmodified 未修改状态
        2)Modified 已修改状态
        3)Staged 已暂存状态
注意:文件的状态会随着我们执行Git的命令发生变化

 4.5 本地仓库操作

本地仓库常用命令如下:

  • git status 查看文件状态,由于工作区中文件状态的不同,执行 git status 命令后的输出也会不同
  • git add 将文件的修改加入暂存区,命令格式:git add fileName。加入暂存区后再执行 git status 命令,可以发现文件的状态已经发生变化
  • git reset 将暂存区的文件取消暂存或者是切换到指定版本( 注意:每次Git提交都会产生新的版本号,通过版本号就可以回到历史版本)

取消暂存命令格式:git reset 文件名

切换到指定版本命令格式:git reset --hard 版本号

  • git commit 将暂存区的文件修改提交到版本库,命令格式:git commit -m msg 文件名

-m:代表message,每次提交时需要设置,会记录到日志中
可以使用通配符*一次提交多个文件

  • git log 查看日志,通过git log命令查看日志,可以发现每次提交都会产生一个版本号,提交时设置的message、提交人、邮箱、提交时间等信息都会记录到日志中

 4.6 远程仓库操作

远程仓库常用命令如下:

  • git remote 查看远程仓库,如果要查看已经配置的远程仓库服务器,可以执行 git remote 命令,它会列出每一个远程服务器的简称。
    如果已经克隆了远程仓库,那么至少应该能看到 origin ,这是 Git 克隆的仓库服务器的默认名字。

可以通过-v参数查看远程仓库更加详细的信息
本地仓库配置的远程仓库都需要一个简称,后续在和远程仓库交互时会使用到这个简称

  • git remote add 添加远程仓库,添加远程仓库命令格式:git remote add 简称 远程仓库地址

一个本地仓库可以关联多个远程仓库

  • git clone 从远程仓库克隆,Git 克隆的是该Git 仓库服务器上的几乎所有数据(包括日志信息、历史记录等)。克隆仓库的命令格式: git clone 远程仓库地址
  • git pull 从远程仓库获取最新版本并合并到本地仓库,命令格式:git pull 远程仓库简称 分支名称

如果当前本地仓库不是从远程仓库克隆,而是本地创建的仓库,并且仓库中存在文件,此时再从远程仓库拉取文件的时候会报错(fatal: refusing to merge unrelated histories )
解决此问题可以在git pull命令后加入参数--allow-unrelated-histories

  • git push 推送到远程仓库,将本地仓库内容推送到远程仓库,
    命令格式:git push 远程仓库简称
    分支名称在使用git push命令将本地文件推送至远程仓库时,如果是第一次操作,需要进行身份认证,认证通过才可以推送,如下

    上面的用户名和密码对应的就是我们用户名和密码,认证通过后会将用户名和密码保存到
    windows系统中,后续再推送则无需重复输入用户名和密码。

控制面板 > 用户账户 > 凭据管理器
推送完成后可以到远程仓库中查看文件的变化。

一个仓库可以有多个分支,默认情况下在创建仓库后会自动创建一个master分支

4.7 分支操作 

        分支是Git 使用过程中非常重要的概念。使用分支意味着你可以把你的工作从开发主线上分离开来,以免影响开发主线。
        本地仓库和远程仓库中都有分支,同一个仓库可以有多个分支,各个分支相互独立,互不干扰。通过git init 命令创建本地仓库时默认会创建一个master分支。

  • git branch 查看分支

git branch 列出所有本地分支

git branch -r 列出所有远程分支

git branch -a 列出所有本地分支和远程分支

  • git branch [name] 创建分支
  • git checkout [name] 切换分支
  • git push [shortName] [name] 推送至远程仓库分支
  • git merge [name] 合并分支 

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

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

相关文章

基于java手机销售网站设计和实现(LW+源码+讲解)

专注于大学生项目实战开发,讲解,毕业答疑辅导,欢迎高校老师/同行前辈交流合作✌。 技术范围:SpringBoot、Vue、SSM、HLMT、小程序、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容:…

GitHub Pages + Jekyll 博客搭建指南(静态网站搭建)

目录 🚀 静态网站及其生成工具指南🌍 什么是静态网站?📌 静态网站的优势⚖️ 静态网站 VS 动态网站 🚀 常见的静态网站生成器对比🛠️ 使用 GitHub Pages Jekyll 搭建个人博客📌 1. 创建 GitHu…

1.【线性代数】——方程组的几何解释

一 方程组的几何解释 概述举例举例一1. matrix2.row picture3.column picture 概述 三种表示方法 matrixrow picturecolumn picture 举例 举例一 { 2 x − y 0 − x 2 y 3 \begin{cases} 2x - y 0 \\ -x 2y 3 \end{cases} {2x−y0−x2y3​ 1. matrix [ 2 − 1 − 1 …

ZZNUOJ(C/C++)基础练习1091——1100(详解版)⭐

目录 1091 : 童年生活二三事(多实例测试) C C 1092 : 素数表(函数专题) C C 1093 : 验证哥德巴赫猜想(函数专题) C C 1094 : 统计元音(函数专题) C C 1095 : 时间间隔(多…

innovus如何分步长func和dft时钟

在Innovus工具中,分步处理功能时钟(func clock)和DFT时钟(如扫描测试时钟)需要结合设计模式(Function Mode和DFT Mode)进行约束定义、时钟树综合(CTS)和时序分析。跟随分…

java高级知识之集合

前言 集合是java开发中的重点内容,需要掌握的东西很多,面试中可问的东西很多,无论是深度还是广度。集合框架中Collection对应的实现类如下所示,这些都是要完全掌握,一个可以分为三大类List集合、Set‘集合以及Map集合…

51c自动驾驶~合集49

我自己的原文哦~ https://blog.51cto.com/whaosoft/13164876 #Ultra-AV 轨迹预测新基准!清华开源:统一自动驾驶纵向轨迹数据集 自动驾驶车辆在交通运输领域展现出巨大潜力,而理解其纵向驾驶行为是实现安全高效自动驾驶的关键。现有的开…

Unity-Mirror网络框架-从入门到精通之MultipleMatches示例

文章目录 前言MultipleMatchesLobbyViewRoomViewMatchGUIPlayerGUI总结前言 在现代游戏开发中,网络功能日益成为提升游戏体验的关键组成部分。本系列文章将为读者提供对Mirror网络框架的深入了解,涵盖从基础到高级的多个主题。Mirror是一个用于Unity的开源网络框架,专为多人…

VMware Workstation创建虚拟机

目录 创建新的虚拟机 虚拟机快照功能 虚拟机添加空间 其他注意事项 创建新的虚拟机 打开VMware Workstation:启动软件后,点击“创建新的虚拟机”。 选择安装方式: 典型安装:适合大多数用户,会自动完成大部分配置…

DeepSeek AI R1推理大模型API集成文档

DeepSeek AI R1推理大模型API集成文档 引言 随着自然语言处理技术的飞速发展,大语言模型在各行各业的应用日益广泛。DeepSeek R1作为一款高性能、开源的大语言模型,凭借其强大的文本生成能力、高效的推理性能和灵活的接口设计,吸引了大量开发…

活泼瘤胃球菌(Ruminococcus gnavus)——多种疾病风险的潜在标志物

​ 前几日,南方医科大学深圳医院院长周宏伟教授团队在国际顶尖医学期刊《Nature Medicine》上发表了一项重要研究。首次揭示一种名为活泼瘤胃球菌(Ruminococcus gnavus)的细菌产生的物质——苯乙胺,在肝性脑病发生中的关键作用。 ​ 同时谷禾的人群检测数…

8.flask+websocket

http是短连接,无状态的。 websocket是长连接,有状态的。 flask中使用websocket from flask import Flask, request import asyncio import json import time import websockets from threading import Thread from urllib.parse import urlparse, pars…

qiime2:安装与使用

试一下docker安装 docker pull quay.io/qiime2/amplicon:2024.10 docker images docker run -v {挂载的目录}:/data quay.io/qiime2/amplicon:2024.10 qiime -h使用 import.txt docker run -v ~/diarrhoea/MJ/qingzhu:/data quay.io/qiime2/amplicon:2024.10 qiime tools imp…

技术实战|ELF 2学习板本地部署DeepSeek-R1大模型的完整指南(一)

DeepSeek作为国产AI大数据模型的代表,凭借其卓越的推理能力和高效的文本生成技术,在全球人工智能领域引发广泛关注。DeepSeek-R1作为该系列最新迭代版本,实现了长文本处理效能跃迁、多模态扩展规划、嵌入式适配等技术维度的突破。 RK3588作为…

DeepSeek本地部署_桌面版AnythingLLM本地知识库搭建

一.DeepSeek本地部署 1.下载并安装:ollama Download Ollama on macOSDownload Ollama for macOShttps://ollama.com/download 安装是否成功确认,管理员权限运行PowerShell: ollama -h 2.下载安装DeepSeek 管理员方式运行PowerShell&#…

BGP基础协议详解

BGP基础协议详解 一、BGP在企业中的应用二、BGP概述2.1 BGP的特点2.2 基本配置演示2.3 抓包观察2.4 BGP的特征三、BGP对等体关系四、bgp报文4.1 BGP五种报文类型(重点)4.2 BGP报文格式-报文头格式4.3 Open报文格式4.4 Update报文格式4.5 Notification报文格式4.6 Route-refre…

2025.2.10 每日学习记录3:技术报告只差相关工作+补实验

0.近期主任务线 1.完成小论文准备 目标是3月份完成实验点1的全部实验和论文。 2.准备教资笔试 打算留个十多天左右,一次性备考笔试的三个科目 1.实习申请技术准备:微调、Agent、RAG 据央视财经,数据显示,截至2024年12月…

算法 ST表

目录 前言 一,暴力法 二,打表法 三,ST表 四,ST表的代码实现 总结 前言 ST表的主要作用是在一个区间里面寻找最大值,具有快速查找的功能,此表有些难,读者可以借助我的文章和网上的课程结…

25考研材料复试面试常见核心问题真题汇总,材料考研复试面试有哪些经典问题?材料考研复试过程最看重什么内容?

材料复试面试难!千万不要死磕!复试是有技巧的! 是不是刷了三天三夜经验贴,还是不知道材料复试会问啥?去年我复试时被导师连环追问"非晶合金的原子扩散机制",差点当场宕机...今天学姐掏心窝总结&…

Docker Compose介绍及安装使用MongoDB数据库详解

在现代容器化应用部署中,Docker Compose是一种非常实用的工具,它允许我们通过一个docker-compose.yml文件来定义和运行多容器应用程序。然而,除了Docker之外,Podman也提供了类似的工具——Podman Compose,它允许我们在…