Git 命令总览

Git

Git 是一个版本控制系统,用于管理项目代码。通过 Git 可以轻松地进行代码的提交、更新和合并,确保项目代码的安全性和稳定性。同时,Git 还提供了丰富的工具和功能,如分支管理、代码审查、版本回退等,帮助开发更好地组织和管理项目代码,实现快速迭代和持续交付。
在这里插入图片描述

在 Git 中,工作区时指当前正在工作的目录。暂存区市位于工作区和仓库之间,用于存储准备提交到仓库的更改。当执行 git add 命令时,将更改从工作区添加到暂存区。仓库(也称为版本库)是Git存储项目历史记录的地方,包含项目的所有文件及其历史记录。当执行 git commit 命令时,将暂存区的更改提交到仓库中,成为项目的一个新版本。本地仓库和远程仓库通过 git push 和 git pull 同步代码。

.gitignore 忽略文件
.git 版本库

常用命令

git init 初始化,并在当前文件夹下创建一个 .git 文件夹。

git clone 复制 url 对应的项目仓库,git clone [url] (newname)。

git status 会显示工作区及暂存区域中不同状态的文件。 其中包含了已修改但未暂存,或已经暂存但没有提交的文件。查看当前项目里有多少文件需要关注,比如修改新增删除等。

git add 把要提交的文件添加到暂存区中。git add [<文件路径>]。

  • git add -u(或–update) [<文件路径>] 添加所有修改、已删除的文件到暂存区中。
  • git add -A(或–all) [<文件路径>] 添加所有修改、已删除、新增的文件到暂存区中。
  • git add . 等于 git add -A

git commit 将暂存区里的文件提交到本地仓库并添加描述信息。 git commit -m “<提交的描述信息>”

git log 查看提交记录历史。无参数是打印所有。

  • git log 打印从第一次提交到指定的提交的记录。
  • git log -<指定的数量> 打印指定数量的最新提交的记录。

git reset 根据传递的参数进行撤销操作,回退到指定版本。git reset [ --soft | --mixed | --hard ] [< commitid >]

  • soft: 仅重置 HEAD 指针,不修改暂存区和工作区,相当于取消之前的提交,但保留修改。即 git add 后的状态,等待再一次 commit。
  • mixed: 默认选项,重置 HEAD 指针并且将暂存区的文件恢复到指定的提交状态,但不影响工作区的文件。即还需要 git add 添加到暂存区和之后的 git commit 操作。
  • hard: 重置 HEAD 指针、暂存区和工作区,强制将所有修改都恢复到指定的提交状态,相当于完全取消之前的提交和修改。
  • 例如,要将 HEAD 指针重置到前一个提交,并保留之前的修改,可以使用:git reset --soft HEAD~1 HEAD表示最近的一次提交,~1表示前一个,这里也可以直接写前一个提交的 commit id。

git revert 功能和 git reset 类似,也是进行撤销,但是是生成一个新的版本来执行撤销的操作。

  • git revert

git diff 比较文件差异。无参数时比较当前文章与暂存区中文章差异,也就是没被暂存起来的更改。

  • git diff HEAD 比较当前文件和上次提交时的差异。
  • git diff 查看从指定的版本之后改动的内容。
  • git diff <分支名称> <分支名称> 比较两个分支之间的差异。

git stash 会把当前目录中的所有改动(但不包括未track的文件)存储在一个特殊的栈中,使你的文件状态处于上一次最新提交处。

  • git stash list 查看栈内记录。
  • git stash pop stash@{index} 恢复并删除某个记录(index从0开始。
  • git stash apply stash@{index} 恢复并保留这个记录。
  • git stash drop stash@{index} 删除某个记录。
  • git stash clear 删除全部记录。

git branch 列出所有本地分支。

  • git branch [branch-name] 新建一个分支,但依然停留在当前分支。
  • git branch -r 列出所有远程分支。
  • git branch -a 列出所有本地分支和远程分支。
  • git branch -d [branch-name] 删除分支。
  • git branch --track [branch] [remote-branch] 将现有分支与指定远程分支建立追踪关系。

git checkout 可以用于创建、切换分支或恢复工作树文件。

  • git checkout [branch-name] 切换分支。
  • git checkout -b [branch-name] 新建一个分支,并切换到该分支 = git branch + git checkout
  • git checkout -b origin/ 基于远程库分支创建分支。
  • 使用 checkout 切换分支时,先从本地库查找分支,在本地库没找到时,就去远程库中查找,在远程库也没有找到就会报错。
  • git checkout – (如果是 . 就是所有文件) 用于让工作区中的文件回到最近一次 git add 或 git commit 的状态。

git fetch 用于从远程仓库获取最新的提交历史和分支信息,但并不自动合并或修改本地代码。

  • git fetch <remote_name> 获取远程仓库的最新提交历史,但不会应用到当前工作目录中。更新本地仓库的远程分支指针,指向远程仓库的最新提交。如果需要将远程分支的更改应用到本地分支,可以使用 git merge 或 git rebase 命令来完成合并操作。

git merge 将一个分支合并到另一个分支上。

  • git merge 将指定的分支合并到当前所在的分支上。
  • git merge origin/ 合并远程分支到当前分支上。
  • 解决冲突:当Git在合并过程中碰到了冲突,它会编辑受影响的文件中的相关内容,并添加视觉标记用以展示冲突中双方在此部分的不同内容。这些视觉标记为:<<<<<<<,=======,>>>>>>>。要找到冲突发生的具体位置,在文件中搜索这些视觉标记会非常便捷地达成目的。当你完成了冲突的修复并准备好继续进行合并,只需要执行git add命令把已经解决好冲突的文件添加暂存区,告诉Git这些冲突已经解决完毕即可。

git rebase 变基,改变当前分支的起点。

  • git rebase <基分支> 将当前分支在基分支的最新提交点后面将差异提交逐个提交,最后将当前分支的 HEAD 指针指向最新的提交点。「基分支」的 HEAD 位置是不变的。要想完成分支合并,完成变基之后,需要再进行分支间的合并等操作。
  • 用变基可以使提交历史更线性,但是会改写提交历史,所以也要谨慎使用。

git remote 用于管理远程仓库的命令,它允许你查看、添加、删除以及重命名远程仓库的配置。

  • git remote 列出你的本地仓库中配置的所有远程仓库的名称。
  • git remote add 添加一个新的远程仓库到你的本地仓库配置中。
  • git remote remove 移除远程仓库。

git pull 将远程仓库的更改拉取到本地,并自动执行 git merge 操作进行合并。

  • git pull 不带任何参数,会默认将其关联的远程分支拉下来,并与当前分支进行合并。
  • git pull origin master:local_branch 显式指定要拉取的远程分支和本地分支。

git push 将本地代码推送到远程仓库,并于远程仓库中的对应分支进行同步。

  • git push origin master 将当前分支(master 分支)的提交推送到名为 origin 的远程仓库的 master 分支。
  • 如果你在本地仓库中进行了提交,并且远程仓库也有更新的提交,那么在执行 git push 命令时,可能会出现拒绝推送的情况。这时,你需要先使用 git pull 命令将远程仓库的更新拉取到本地仓库,解决冲突后再次尝试执行 git push。

git tag 用于管理标签的命令,通常用于发布版本或者重要的里程碑。

  • git tag 这会列出所有的标签,按字母顺序排序。
  • git tag <tag_name> 会在当前 HEAD 所指向的提交上创建一个轻量标签。
  • git tag -a <tag_name> -m “tag message” 创建带注释的标签。
  • git show <tag_name> 会显示指定标签的详细信息,包括标签对象、标签消息和标签所指向的提交。
  • git push origin <tag_name> 将标签推送到远程仓库(不会自动带过去)。

git rm 删除工作区文件,并且将这次删除放入暂存区。git rm 相当于 linux rm + git add 命令。

  • git rm [file1] [file2] … 删除工作区文件。
  • git rm --cached file 把文件从暂存区域移除,但该文件会保留在工作区。

git cherry-pick 选择性地将某个提交应用到当前分支上,而不需要合并整个分支。

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

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

相关文章

后端之卡尔曼滤波

后端之卡尔曼滤波 前言 在很久之前&#xff0c;人们刚结束信息传递只能靠信件的时代&#xff0c;通信技术蓬勃发展&#xff0c;无线通信和有线通信走进家家户户&#xff0c;而著名的贝尔实验室就在这个过程做了很多影响深远的研究。为了满足不同电路和系统对信号的需求&#…

Rabbitmq消息顺序的问题以及解决方案

1.1消息顺序的场景 场景1&#xff1a;一个queue&#xff0c;多个consumer 一个queue&#xff0c;有多个consumer去消费&#xff0c;这样就会造成顺序的错误&#xff0c;consumer从MQ里面读取数据是有序的&#xff0c;但是每个consumer的执行时间是不固定的&#xff0c;无法保…

docker部署-RabbitMq

1. 参考 RabbitMq官网 docker官网 2. 拉取镜像 这里改为自己需要的版本即可&#xff0c;下面容器也需要同理修改 docker pull rabbitmq:3.12-management3. 运行容器 docker run \ --namemy-rabbitmq-01 \ -p 5672:5672 \ -p 15672:15672 \ -d \ --restart always \ -…

Radio Silence for mac 好用的防火墙软件

Radio Silence for Mac是一款功能强大的网络防火墙软件&#xff0c;专为Mac用户设计&#xff0c;旨在保护用户的隐私和网络安全。它具备实时网络监视和控制功能&#xff0c;可以精确显示每个网络连接的状态&#xff0c;让用户轻松掌握网络活动情况。 软件下载&#xff1a;Radio…

软件工程学习笔记12——运行维护篇

运行维护篇 一、版本发布1、关于软件版本2、版本发布前&#xff0c;做好版本发布的规划3、规范好发布流程&#xff0c;保障发布质量 二、DevOps工程师1、什么是 DevOps 三、线上故障1、遇到线上故障&#xff0c;新手和高手的差距在哪里2、大厂都是怎么处理线上故障的 四、日志管…

Grafana实时监控minio的极简方法

背景 想监控一下minio的部分信息. 使用过程中需要关注的内容挺多的. 只看简单的node感觉已经不够了. 所以想监控易一下. ERLANG 复制 全屏 方式和方法 minio其实集成了prometheus 支持的监控指标 只需要在配置文件中放开就可以了. 虽然可以使用mc 的命令 create beartoken 但…

如何在Flutter中进行网络请求?

Hello&#xff01;大家好&#xff0c;我是咕噜铁蛋&#xff0c;你们的好朋友&#xff01;今天&#xff0c;我想和大家分享一下在Flutter中如何进行网络请求。Flutter作为一个跨平台的开发框架&#xff0c;网络请求是其实现数据交互的重要一环。下面&#xff0c;我将详细介绍几种…

稀碎从零算法笔记Day32-LeetCode:每日温度

算是引出“单调栈”这种数据结构&#xff0c;后面会用这个思想处理下接雨水问题 前言&#xff1a;单调栈模式匹配——题目中提到“求第一个最大/最小的元素” 题型&#xff1a;栈、单调栈、数组 链接&#xff1a;739. 每日温度 - 力扣&#xff08;LeetCode&#xff09; 来源…

【漏洞复现】chatgpt pictureproxy.php SSRF漏洞(CVE-2024-27564)

0x01 漏洞概述 ChatGPT pictureproxy.php接口存在服务器端请求伪造 漏洞&#xff08;SSRF&#xff09; &#xff0c;未授权的攻击者可以通过将构建的 URL 注入 url参数来强制应用程序发出任意请求。 0x02 测绘语句 fofa: icon_hash"-1999760920" 0x03 漏洞复现 G…

TheMoon 恶意软件短时间感染 6,000 台华硕路由器以获取代理服务

文章目录 针对华硕路由器Faceless代理服务预防措施 一种名为"TheMoon"的新变种恶意软件僵尸网络已经被发现正在侵入全球88个国家数千台过时的小型办公室与家庭办公室(SOHO)路由器以及物联网设备。 "TheMoon"与“Faceless”代理服务有关联&#xff0c;该服务…

I/O模型的一些理解

I/O模型的一些理解 一些基本的概念同步阻塞、同步非阻塞、异步阻塞、异步非阻塞总结概念 I/O模型一些例子 从源头解释从TCP发送数据的流程说起阻塞I/O | 非阻塞I/OI/O多路复用信号驱动I/O异步I/O再谈IO模型里面的同步异步 参考连接 参考链接 参考链接 一些基本的概念 阻塞(b…

面试算法-124-二叉树的最近公共祖先

题目 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 百度百科中最近公共祖先的定义为&#xff1a;“对于有根树 T 的两个节点 p、q&#xff0c;最近公共祖先表示为一个节点 x&#xff0c;满足 x 是 p、q 的祖先且 x 的深度尽可能大&#xff08;一个节点也可以是它…