浅显易懂的Git教程

Git概述

SVN与Git的对比

SVN(Subversion)

类型:集中式版本控制系统

工作流程:

  1. 从中央服务器下载最新版本到本地。
  2. 在本地进行开发。
  3. 提交更改回中央服务器。

优点:

  • 简单易用,适合小型团队。
  • 版本历史清晰。

缺点:

  • 单点故障:中央服务器宕机会导致无法访问版本库。
  • 容错性差:需要网络连接进行大多数操作。

Git

类型:分布式版本控制系统

优点:

  • 高效的分支和合并管理。
  • 无需网络连接即可进行大多数操作。
  • 更好的容错性,避免单点故障。

缺点:

  • 学习曲线相对较陡。
  • 对于小团队可能显得复杂。

Git工作流程

  1. 克隆远程仓库:使用 git clone 命令将远程仓库的代码复制到本地,创建一个完整的本地仓库。
  2. 检出代码并修改:使用 git checkout 切换到需要修改的分支,进行代码修改。
  3. 暂存代码:使用 git add 将修改的文件添加到暂存区,准备提交。
  4. 提交到本地仓库:使用 git commit 将暂存区的更改提交到本地仓库,记录修改的历史版本。
  5. 推送到远程仓库:使用 git push 将本地仓库的更改推送到远程仓库,与团队成员共享代码。

Git安装

下载地址: https://git-scm.com/download

找到对应电脑系统的网址:  

 配置选择,一直点击下一步即可: 

这里选择Git编辑器 Git 安装程序里面内置了 10 种编辑器,比如 Atom、Notepad、Notepad++、Sublime Text、Visual Studio Code、Vim 等等,根据需要自行选择,点击Next下一步继续

后面的就一直点next

环境配置

安装 Git 后首先要设置用户名称和 email 地址,因为每次 Git 提交都会使用该用户信息,此信息和注册的代码托管平台的信息无关

设置用户信息:

  • git config --global user.name “Seazean”

  • git config --global user.email "imseazean@gmail.com" //用户名和邮箱可以随意填写,不会校对

查看配置信息:

  • git config --list

  • git config user.name

通过上面的命令设置的信息会保存在用户目录下 /.gitconfig 文件中

本地仓库

获取仓库

  • 本地仓库初始化

    1. 在电脑的任意位置创建一个空目录(例如 repo1)作为本地 Git 仓库

    2. 进入这个目录中,点击右键打开 Git bash 窗口

    3. 执行命令 git init

      如果在当前目录中看到 .git 文件夹(此文件夹为隐藏文件夹)则说明 Git 仓库创建成功

  • 远程仓库克隆 通过 Git 提供的命令从远程仓库进行克隆,将远程仓库克隆到本地

    命令:git clone 远程 Git 仓库地址(HTTPS 或者 SSH)

  • 生成 SSH 公钥步骤

    • 设置账户

    • cd ~/.ssh(查看是否生成过 SSH 公钥)user 目录下

    • 生成 SSH 公钥:ssh-keygen -t rsa -C "email"

      • -t 指定密钥类型,默认是 rsa ,可以省略

      • -C 设置注释文字,比如邮箱

      • -f 指定密钥文件存储文件名

    • 查看命令:cat ~/.ssh/id_rsa.pub

    • 公钥测试命令:ssh -T git@github.com

工作过程

版本库(.git)

定义:.git 文件夹是Git的核心,包含所有版本控制的信息。

内容:

  • 配置信息:包括用户信息、远程仓库地址等。
  • 日志信息:记录了提交历史和变更信息。
  • 对象数据库:存储所有文件的版本和快照。

工作目录(工作区)

定义:工作目录是包含 .git 文件夹的主目录,主要用于存放开发代码。

特点:

  • 直接与代码进行交互,可以在这里编辑、删除或添加文件。
  • 代码的当前状态可以在此查看。

暂存区(Stage / Index)

定义:暂存区是一个临时存储修改的区域,通常存储在 .git/index 文件中。

功能:

  • 允许你选择性地添加修改到下一个提交,支持分步提交。
  • 确保只有经过验证的文件才会被提交到版本库。

常用命令

  • git status:非常重要,可以清楚地查看哪些文件已修改、已暂存或未跟踪。
  • git add filename:可以使用 git add . 来添加所有更改的文件。
  • git commit -m 'message':建议在消息中描述更改内容,以便于未来回顾。
  • git rm filename:如果删除了文件,建议立即执行 git commit,确保版本更新。
  • git mv filename:移动文件时,这条命令会自动处理跟踪关系,保持文件历史。
  • git reset filename:可用于将特定文件从暂存区移回工作区,便于进一步编辑。
  • git checkout filename:需谨慎使用,因为会丢失未保存的修改。
  • git log:可用 git log --oneline 查看简洁版本。
  • git reflog:非常有用,能帮助恢复意外删除的提交。

其他指令说明

  • git commit -a:此命令会自动将所有已跟踪文件的修改添加到暂存区,然后直接执行提交。注意:只会添加已跟踪的文件,对于新文件(未跟踪的文件)不会包含在提交中。
  • git checkout HEAD -- files:该命令用于将指定文件恢复到最后一次提交的状态,所有未保存的修改将被丢弃。使用时要谨慎,确保重要修改已备份或确认不需要保留。

文件状态

Untracked(未跟踪):

这些文件尚未被Git纳入版本控制,通常是新创建的文件。

Tracked(已跟踪):

包含三种子状态:

  • Unmodified(未修改):自上次提交以来没有变更。
  • Modified(已修改):自上次提交以来有更改但未暂存。
  • Staged(已暂存):已将更改添加到暂存区,准备提交。

查看文件状态

  • git status:提供详细的状态信息,帮助了解当前项目的文件状态。
  • git status -s:以简洁的方式列出文件状态,适合快速查看。

文件忽略

一般我们总会有些文件无需纳入Git 的管理,也不希望它们总出现在未跟踪文件列表。 通常都是些自动生成的文件,比如日志文件,或者编译过程中创建的临时文件等。 在这种情况下,我们可以在工作目录中创建一个名为 .gitignore 的文件(文件名称固定),列出要忽略的文件模式。

# 忽略所有日志文件
*.log

# 忽略临时文件
temp/

远程仓库

工作流程

Git 有四个工作空间的概念,分别为 工作空间、暂存区、本地仓库、远程仓库。

  • 工作空间:本地文件夹中正在处理的代码和文件,进行修改和编辑的地方。
  • 暂存区(Staging Area):用于临时存储即将提交的更改。当你使用 git add 命令时,文件会被放入暂存区。
  • 本地仓库:存储所有版本历史的地方。你可以通过 git commit 命令将暂存区的更改保存到本地仓库中。
  • 远程仓库:存储在网络上的版本库,通常用于协作。常见的远程仓库有GitHub、gitee等。

远程操作

  • git fetch:从远程仓库获取最新的提交和更新,但不会自动合并到你的工作空间。需要手动合并(使用 git merge)。
  • git pull:相当于先执行 git fetch,然后再自动合并远程更改到当前分支。可以看作是 fetch + merge 的组合。

常用命令

查看仓库

  • git remote:列出所有远程仓库的简写,有助于快速查看当前配置。
  • git remote -v:显示远程仓库的URL,便于确认远程地址是否正确。
  • git remote show <shortname>:提供远程仓库的详细信息,包括分支信息、追踪状态等。

添加仓库

  • git remote add <shortname> <url>:添加新的远程仓库,确保URL格式正确(例如HTTPS或SSH)。

克隆仓库

  • git clone <url>:会创建一个本地副本,并自动设置远程仓库的默认名称为origin。

删除仓库

  • git remote rm <shortname>:移除本地对远程仓库的引用,不会影响远程仓库的内容。

拉取仓库

  • git fetch <shortname>:获取远程仓库的更新,但不进行合并,适合检查变更。
  • git pull <shortname> <branchname>:拉取并合并,通常用于更新当前分支。当出现 fatal: refusing to merge unrelated histories 时,解决此问题可以在 git pull 命令后加入--allow-unrelated-histories 参数。

推送仓库

  • git push <shortname> <branchname>:将本地分支推送到指定的远程分支,确保有推送权限。

其他建议

  • 定期使用 git status 检查当前状态,确保工作区的变更和分支状态清晰。
  • 使用 git log 查看提交历史,有助于追踪更改和版本控制。
  • 结合使用 .gitignore 文件,以防止不必要的文件被推送到远程仓库。

版本管理

使用 Git 进行版本管理可以帮助我们跟踪和管理代码的历史记录。

git reset --hard <commit_hash>

这里的 <commit_hash> 是我们想要切换到的版本的唯一索引值(commit ID)。

注意事项

数据丢失风险:

使用 --hard 选项会丢弃所有未提交的更改,包括工作区和暂存区的更改。如果你有未保存的工作,确保先备份或使用 git stash。

查看提交历史:

在执行重置之前,可以使用以下命令查看提交历史,以找到想要切换的版本:

git log

恢复到最新状态:

如果我们需要恢复到最新的提交,可以使用:

git reset --hard origin/<branch_name>

创建新分支:

如果我们想在旧版本上进行修改而不影响主分支,可以考虑先创建一个新分支:

git checkout -b <new_branch_name> <commit_hash>

分支管理

分支的好处

  • 隔离开发:不同特性或修复可以在独立分支上开发,避免相互影响。
  • 并行工作:多个团队或开发者可以同时在不同分支上工作,提高效率。
  • 简化合并:在完成特性后,可以将分支合并回主分支,确保整合稳定。
  • 试验和回滚:可以在分支上进行试验,若不满意可轻松回滚而不影响主线代码。
  • 版本控制:清晰记录每个特性或修复的开发过程,便于管理和审查。

常用命令

查看分支

  • git branch:列出所有本地分支。
  • git branch -r:列出所有远程分支。
  • git branch -a:列出所有本地和远程分支。

创建分支

  • git branch branch-name:创建新分支,但仍在当前分支。
  • git checkout -b branch-name:创建并切换到新分支。

推送分支

  • git push origin branch-name:将新分支推送到远程仓库。

切换分支

  • git checkout branch-name:切换到指定的分支。

合并分支

  • git merge branch-name:将指定分支合并到当前分支。处理冲突时,需要手动解决文件冲突后执行 git add,然后提交合并。

删除分支

  • git branch -d branch-name:删除本地分支(需确保已合并)。
  • git push origin --delete branch-name:删除远程分支。(origin 是引用名)
  • git branch -D branch-name:强制删除本地分支,即使未合并。

标签管理

Git 的标签(tag)用于为代码库中的特定提交创建标记,通常用于标识重要的版本(如发布版本)。标签可以帮助开发者快速找到特定的提交,并且非常适合用于版本控制和发布管理。

查看标签

  • git tag:列出所有本地标签。
  • git show tag-name:查看指定标签的详细信息,包括标签信息和对应的提交。

标签作用:标签用于在项目的关键时刻(如发布版本、重大修改或升级)保存快照,便于永久标记项目历史的重要阶段。

新建标签

  • git tag tag-name:创建一个新标签,如 git tag v1.0.1。

推送标签

  • git push [remotename] [tagname]:将指定标签推送到远程仓库。
  • git push [remotename] --tags:推送所有本地标签到远程仓库。

切换标签

  • git checkout tag-name:切换到指定标签。请注意,切换到标签时,工作目录会进入“分离头指针”(detached HEAD)状态。

删除标签

  • git tag -d tag-name:删除本地标签。
  • git push origin :refs/tags/tag-name:删除远程标签。

IDEA使用git

环境配置

File → Settings 打开设置窗口,找到 Version Control 下的 git 选项

选择 git 的安装目录后可以点击 Test 按钮测试是否正确配置

创建仓库

1、VCS → Import into Version Control → Create Git Repository

2、选择工程所在的目录,这样就创建好本地仓库了

3、点击git后边的对勾,将当前项目代码提交到本地仓库

注意: 项目中的配置文件不需要提交到本地仓库中,提交时,忽略掉即可

分支管理

  • 创建分支:VCS → Git → Branches → New Branch → 给分支起名字 → ok

  • 切换分支:idea 右下角 Git → 选择要切换的分支 → checkout

  • 合并分支:VCS → Git → Merge changes → 选择要合并的分支 → merge

  • 删除分支:idea 右下角 → 选中要删除的分支 → Delete

推送仓库

  1. VCS → Git → Push → 点击 master Define remote

  2. 将远程仓库的 url 路径复制过来 → Push

克隆仓库

File → Close Project → Checkout from Version Control → Git → 指定远程仓库的路径 → 指定本地存放的路径 → clone

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

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

相关文章

vs2022快捷键异常不起作用解决办法

安装了新版本的vs2022&#xff0c;安装成功后&#xff0c;发现快捷键发生异常&#xff0c;之前常用的快捷键要么发生改变&#xff0c;要么无法使用&#xff0c;比如原来注释代码的快捷键是ctrlec&#xff0c;最新安装版本变成了ctrlkc&#xff0c;以前编译代码的快捷键是F6或者…

初始MYSQL数据库(6)—— 事务

找往期文章包括但不限于本期文章中不懂的知识点&#xff1a; 个人主页&#xff1a;我要学编程(ಥ_ಥ)-CSDN博客 所属专栏&#xff1a; MYSQL 目录 事务的概念 事务的ACID特性 使用事务 查看支持事务的存储引擎 事务的语法 保存点 自动/手动提交事务 事务的隔离性和…

Python模拟鼠标轨迹[Python]

一.鼠标轨迹模拟简介 传统的鼠标轨迹模拟依赖于简单的数学模型&#xff0c;如直线或曲线路径。然而&#xff0c;这种方法难以捕捉到人类操作的复杂性和多样性。AI大模型的出现&#xff0c;能够通过深度学习技术&#xff0c;学习并模拟更自然的鼠标移动行为。 二.鼠标轨迹算法实…

【原创】java+swing+mysql仓库管理系统设计与实现

个人主页&#xff1a;程序员杨工 个人简介&#xff1a;从事软件开发多年&#xff0c;前后端均有涉猎&#xff0c;具有丰富的开发经验 博客内容&#xff1a;全栈开发&#xff0c;分享Java、Python、Php、小程序、前后端、数据库经验和实战 文末有本人名片&#xff0c;希望和大家…

Qt开发技巧(四)“tr“使用,时间类使用,Qt容器取值,类对象的删除,QPainter画家类,QString的转换,用好 QVariant类型

继续讲一些Qt技巧操作 1.非必要不用"tr" 如果程序运行场景确定是某一固定语言&#xff0c;就不需要用tr,"tr"之主要针对多语种翻译的&#xff0c;因为tr的本意是包含英文&#xff0c;然后翻译到其他语言比如中文&#xff0c;不要滥用tr&#xff0c;如果没有…

‌内网穿透技术‌总结

内网穿透是一种网络技术&#xff0c;通过它可以使外部网络用户访问内部网络中的设备和服务。一般情况下&#xff0c;内网是无法直接访问的&#xff0c;因为它位于一个封闭的局域网中&#xff0c;无法从外部访问。而通过内网穿透&#xff0c;可以将内部网络中的设备和服务暴露在…

底盘四轮转向运动学解析(含代码)

目录 写在前面的话四轮转向运动学解析四轮转向理论图解robot_control.py 完整代码关键参数完整代码 公式解析&#xff08;根据代码&#xff09;反相--模式1详细图解 正相--模式2轴心--模式3 写在前面的话 网上找了很多资料&#xff0c;对于四轮转向运动学描述的很少&#xff0…

爬虫过程 | 蜘蛛程序爬取数据流程(初学者适用)

蜘蛛程序&#xff08;也称网络爬虫&#xff0c;是搜索引擎的重要组成部分&#xff09; 主要功能&#xff1a;遍历互联网&#xff0c;抓取网站信息并建立索引&#xff0c;便于用户在搜索引擎中检索到最新的网页内容工作原理&#xff1a;从初始网站页面的URL开始&#xff0c;发送…

最适配达梦、人大金仓的sql工具是什么?

SQLynx是一款功能强大的数据库管理工具&#xff0c;它不仅支持Oracle、MySQL等国际主流数据库&#xff0c;还很好地支持了武汉达梦、人大金仓等国产数据库。这款工具具有以下几个特点&#xff1a; 1.广泛支持&#xff1a;SQLynx支持多种数据库系统&#xff0c;包括PostgreSQL、…

MySQL学习笔记(持续更新中)

1、Mysql概述 1.1 数据库相关概念 三个概念&#xff1a;数据库、数据库管理系统、SQL 名称全称简称数据库存储数据的仓库&#xff0c;数据是有组织的进行存储DataBase&#xff08;DB&#xff09;数据库管理系统操纵和管理数据库的大型软件DataBase Mangement System&#xf…

电子看板实时监控数据可视化助力工厂精细化管理

在当今竞争激烈的制造业领域&#xff0c;工厂的精细化管理成为提高竞争力的关键。而电子看板实时监控数据可视化作为一种先进的管理工具&#xff0c;正为工厂的精细化管理带来巨大的助力。 一、工厂精细化管理的挑战 随着市场需求的不断变化和客户对产品质量要求的日益提高&am…

Qt 模型视图(三):视图类QAbstractItemView

文章目录 Qt 模型视图(三):视图类QAbstractItemView1.基本概念1.1.使用现有视图1.2.使用模型1.3.使用模型的多个视图1.4.在视图之间共享选择 Qt 模型视图(三):视图类QAbstractItemView ​ 模型/视图结构是一种将数据存储和界面展示分离的编程方法。模型存储数据&#xff0c;视…

Ubuntu22.04关闭631端口的方法

何为631端口&#xff1f; 631端口主要用于访问和控制网络打印服务&#xff0c;是linux下CUPS&#xff08;Common UNIX Printing System&#xff0c;通用UNIX打印系统&#xff09;服务的端口。Linux中的CUPS&#xff08;Common UNIX Printing System&#xff0c;通用UNIX打印系…

VisualStudio的“应用代码更改“按钮功能

无意发现这个按钮&#xff0c;因为开发这么多年也没专门尝试这个按钮&#xff0c;于是好奇它的功能。 光标放在按钮上面提示了“应用代码更改”&#xff0c;于是猜想应该是在调试不断开的情况下支持热应用更改。 经过验证&#xff0c;功能确实如同猜想的一样&#xff0c;具体验…

【Elasticsearch系列廿一】ES7 SQL 新特性

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

基于c++实现的简易shell

代码逻辑 核心思想 解析命令行&#xff0c;拆解命令及其选项创建子进程&#xff0c;在子进程中执行命令如果是前台执行命令&#xff0c;则父进程就阻塞等待子进程中命令执行结束后回收子进程的资源如果是后台执行命令&#xff0c;则父进程不进行阻塞等待&#xff0c;可继续向下…

【ArcGIS微课1000例】0123:数据库中要素类批量转为shapefile

除了ArcGIS之外的其他GIS平台,想要打开ArcGIS数据库,可能无法直接打开,为了便于使用shp,建议直接将数据库中要素类批量转为shapefile。 文章目录 一、连接至数据库二、要素批量转shp一、连接至数据库 打开ArcMap,或者打开ArcCatalog,找到数据库连接,如下图: 数据库为个…

Laravel邮件发送:从配置到发邮件的指南!

Laravel邮件发送功能如何实现&#xff1f;怎么使用Laravel发信&#xff1f; Laravel作为一款流行的PHP框架&#xff0c;提供了强大且易用的邮件发送功能。AokSend将详细介绍如何从配置到实际发送邮件的全过程&#xff0c;帮助你快速掌握Laravel邮件发送的技巧。 Laravel邮件发…

数据中台!企业的必备还是可有可无?(附数据中台构建完整脑图)

数据中台&#xff01;企业的必备还是可有可无&#xff1f;&#xff08;附数据中台构建完整脑图&#xff09; 前言数据中台 前言 在这个数据爆炸的时代&#xff0c;数据已经成为了企业最宝贵的资产之一。然而&#xff0c;如何有效地管理和利用这些数据&#xff0c;却是许多企业…

Linux驱动开发 ——架构体系

只读存储器&#xff08;ROM&#xff09; 1.作用 这是一种非易失性存储器&#xff0c;用于永久存储数据和程序。与随机存取存储器&#xff08;RAM&#xff09;不同&#xff0c;ROM中的数据在断电后不会丢失&#xff0c;通常用于存储固件和系统启动程序。它的内容在制造时或通过…