Git 常用操作总结

news2025/1/12 12:17:20

版本控制系统(VCS)是管理文件和目录所做的更改的工具,每一次提交便记录下目录及其文件的内容,以及较上一版本的更改。通过这样去跟踪项目的更改过程,方便与他人进行协作,或者撤销不想要的更改以回退到此前的任一个版本。常见的有GitSVNCVSRCS等,其中最常用的便是Git

一、关键术语

  • 本地储存库(local repository):包含项目文件的本地目录
  • 远程储存库(remote repository):托管在服务器(如 GitHub、GitLab、BitBucket)上的项目文件目录
  • 克隆(clone):复制储存库到新的路径
  • 提交(commit):每次提交操作产生一个项目的快照
  • 分支(branch):从某个提交开始从主分支中分离出去的一个项目副本
  • 合并(merge):将两个分支合并(一般需要处理文件冲突)
  • .gitignore:在提交中选择性忽略的文件(例如过大的数据集、私人信息等)
  • 暂存区(staging area):保留部分更改在下一次提交
  • Git stash:类似暂存区,用于缓存可能稍后要撤销的更改
  • Commit ID:每个提交的哈希值编码,用于唯一确认
  • HEAD:最近提交的代号,避免定位时需要输入一长串的哈希值,可用 HEAD~n 表示最近的第 n 次提交

二、初始设置

设置用户信息,团队协作时用来确定更改人,以便于沟通。

git config --local user.email useremail@domain.com
git config --local user.name username 

指定设置的范围:

  • 只在当前项目目录有效(默认):--local
  • 对于当前系统用户的所有项目有效:--global
  • 对于当前机器的所有用户的所有项目有效:--system

列出所有设置值:

git config --list

查看某个设置值:

git config --get <key>

为常用操作设置别名:

git config --global alias.ga add
git config --global alias.gc commit

ga filename
gc -m "commit description"

三、基本操作

从远程服务器复制储存库

git clone <remote-repo-url>
git clone -branch <branch_name> <repo-url>      # 指定复制的分支
git clone <repo_url> <dir_name>     # 复制到指定的路径

两种克隆方式:HTTP 链接和 SSH 链接

git clone https://github.com/username/reponame.git
git clone git@github.com:username/reponame.git

在本地目录新建储存库

git init
git init [directory]

管理远程储存库

git remote      # 列出远程储存库
git remote add <connection_name> <url_to_remote>    # 链接远程储存库
git remote rm <connection_name>     # 删除链接
git remote rename <connection_name> <new_name>      # 重命名链接

四、文件操作

添加文件到暂存区以及从暂存区移除文件

git add <filename_or_directory>
git rm <filename_or_directory>
git add .   # 接受正则,“.”代表添加全部

更改操作(先执行上面的添加操作,再执行更改提交)

git status  # 显示更改情况,包括已暂存未提交或已更改未暂存
git diff    # 更加详细版本的 git status,包含具体更改内容
git diff <id1> <id2>    # 比较任意两个提交版本
git commit -m "commit description"      # 提交暂存区的更改
git commit -am "commit description"     # 提交所有的更改,包括未暂存的
git commit --amend -m "new description" # 重新编辑最近的提交的描述信息

贮藏操作(临时保存工作副本以便稍后返回,而不需要提交)

git stash       # 储存更改
git stash -U    # 较上,包括未跟踪的文件
git stash --all # 较上,包括所有文件,甚至 ignored 的文件
git stash pop   # 应用此前的储存,并清除储存区
git stash apply # 应用但不清除
git stash drop  # 删除但不应用

撤销更改(检查提交,并在有需要时撤销之前的提交)

git checkout HEAD~2         # 切换到最近的第二个提交版本
git checkout <commit_id>    # 按 id 切换到某一个提交版本
git reset HEAD~1            # 撤销提交,但不会改变工作目录的文件
git reset --hard <commit_id>    # 回到该版本,文件也跟着改变
git revert <commit_id>      # 只撤销该次提交包含的更改,而 reset 会撤销该提交以及此后的所有更改

五、仓库操作

(1)分支

如下图,常规操作为,在主分支的基础上,创建新的分支,此时新分支为主分支的副本,内容一致。接下来在新分支进行新的工作(例如为程序加入新的功能),同时主分支可以继续原来的工作(如完善原有的功能),最后处理文件冲突并合二为一。按照同样的原理可以创建多个分支,并根据需要在不同的分支之间进行合并。

请添加图片描述

git branch --list   # 列出所有分支
git branch -a       # 列出所有分支,包括远程储存库中的
git branch <new_branch_name>        # 创建新的分支
git checkout <branch_name>          # 切换到某个分支
git checkout -b <new_branch_name>   # 创建新分支并切换到新分支
git branch -d <branch_name>         # 安全删除分支,避免删除未合并的更改
git branch -D <branch_name>         # 忽视更改强行删除
git branch -m <new_name>            # 重命名
git push <remote_repo> branch~      # 上传分支到远程储存库
git push <remote_repo> --delete <branch_name>   # 从远程储存库中删除分支
git diff <branch1> <branch2>        # 对比两个分支
git diff <branch1> <branch2>        # 对比两个分支中的某个文件

# 切换到主分支并合并
git checkout main
git merge <other_branch>

(2)其他

git fetch       # 同步 .git 文件夹,但不改变项目中的文件
git merge       # 合并远程和本地(会更改文件)
git pull        # 同步并合并(会更改文件)
git log         # 查看提交历史
git log --stat  # 详细版,包括文件更改细节
git log --after="YYYY-MM-DD" --before="yesterday"   # 按时间列出
# 还可以使用 last month、last year 之类的关键词

END

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

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

相关文章

DR模式部署LVS负载均衡集群

目录 一、配置负载调度器 1.配置虚拟 IP 地址&#xff08;VIP&#xff1a;192.168.146.180&#xff09; 2.调整 proc 响应参数 3. 配置负载分配策略 ​编辑二、部署共享存储&#xff08;NFS服务器&#xff1a;192.168.146.20&#xff09; 三、配置节点服务器 1.配置虚拟…

解决vue中mapbox地图显示一半的问题

解决vue中mapbox地图显示一半的问题 问题描述&#xff1a; 在vue中创建mapbox地图&#xff0c;地图只显示一般&#xff0c;查看浏览器开发者工具。发现将canvas.mapboxgl-canvas 的position:absolute去掉就解决了 。 代码修改&#xff1a;获取到canvas.mapboxgl-canvas,并修改…

zookeeper第一课-Zookeeper特性与节点数据类型详解

1、Zookeeper特性与节点数据类型详解 ZooKeeper 是一个开源的分布式协调框架&#xff0c;是Apache Hadoop 的一个子项目&#xff0c;主要用来解决分布式集群中应用系统的一致性问题。 Zookeeper 的设计目标是将那些复杂且容易出错的分布式一致性服务封装起来&#xff0c;构成一…

在Linux中部署ELK架构

ELK&#xff08;ElasticSearch分布式搜索引擎、Logstash数据收集处理引擎和Kibana可视化化平台&#xff09;是在大型后端架构中&#xff0c;一个标准的数据采集方案。 在公网IP为x.x.x.x的服务器上部署Elasticsearch LogstashfilebeatredisKibana架构。这种架构先通过Logstash…

高并发场景:redis+lua防重校验

大家平时在做有并发量下单的项目时&#xff0c;代码层面基本上就分为这么几个步骤&#xff1a;参数校验--->防重校验--->库存校验扣减--->下单成功--->支付。 最近公司有个商城项目说要30分钟达到1亿的并发量。当时听到突然猛了一下。真是牛逼克拉斯呀。 不过该说…

apache php mysql python 环境部署与离线安装deb包

文章目录 1.背景介绍2. 主要涉及操作2.1 安装系统&#xff1a;2.2 apache mysql php安装2.3 配置2.4 python相关库安装 3. 操作记录3.1 软件安装3.2 读取文件内容后进行文件内容抽取3.3 执行以上的sh脚本3.4 所学3.5 打包发送 4. 参考文献 1.背景介绍 使用的系统为ubuntu18.04…

密码学学习笔记(四):Authenticated Encryption - 认证加密

加密数据的最新方法是使用一种称为一体式结构的认证加密算法&#xff0c;该算法也称为有附加数据的认证加密。从之前的博客中&#xff0c;我们看到在特定的操作模式中使用的分组密码&#xff0c;如CBC、OFB、CFB、CTR&#xff0c;提供了IND-CPA安全性。 但是IND-CCA安全性呢&a…

电脑卡顿甚至崩溃?那重置系统吧

我们平时用电脑&#xff0c;最怕遇到蓝屏、死机、报错&#xff0c;等等问题。有时还会碰到些奇奇怪怪的系统问题 文章目录 问题场景&#xff1a;解决方案&#xff1a;一、重启电脑二、移除外接设备三、系统还原1、设置系统还原2、如何进行系统还原3、系统还原失败怎么办 四、卸…

有源差分探头的电压限定和检查步骤

为了使传统示波器能够显示和测试高共模电压的电路波形&#xff0c;有源差分探头对示波器测量性能延伸到了电子功率变换器、 逆变器、 电机的速度控制、 开关电源和许多应用程序的测试。 差分探头外观构成&#xff1a; A-输出线&#xff1a;连接示波器的 BNC 输出连接头和辅助性…

【操作系统】c语言--进程调度算法(FCFS和SPN)

创作不易&#xff0c;本篇文章如果帮助到了你&#xff0c;还请点赞 关注支持一下♡>&#x16966;<)!! 主页专栏有更多知识&#xff0c;如有疑问欢迎大家指正讨论&#xff0c;共同进步&#xff01; &#x1f525;c系列专栏&#xff1a;C/C零基础到精通 &#x1f525; 给大…

Docker轻量级可视化工具Portainer

掌握Portainer的部署和使用。 Portainer 是一款轻量级的应用&#xff0c;它提供了图形化界面&#xff0c;用于方便地管理Docker环境&#xff0c;包括单机环境和集群环境。 Portainer&#xff08;https://www.portainer.io/&#xff09;是一个流行的开源Docker管理工具&#xff…

【设计模式】第八章:桥接模式详解及应用案例

系列文章 【设计模式】七大设计原则 【设计模式】第一章&#xff1a;单例模式 【设计模式】第二章&#xff1a;工厂模式 【设计模式】第三章&#xff1a;建造者模式 【设计模式】第四章&#xff1a;原型模式 【设计模式】第五章&#xff1a;适配器模式 【设计模式】第六章&…

前端为什么使用svg图片

参考链接&#xff1a; 1.http://www.youngzi.cn/5392.html 2.https://baijiahao.baidu.com/s?id1728784571128338709&wfrspider&forpc SVG是什么&#xff1f;SVG有什么用&#xff1f;为什么要使用SVG&#xff1f;本篇文章就给大家介绍一下SVG的相关知识&#xff0c;让…

【Unity】HyBridCLR初探

完成目标: 创建热更新程序集加载热更新程序集,并执行其中热更新代码,打印 Hello, HybridCLR修改热更新代码,打印 Hello, World准备环境​ 安装Unity HybridCLR也支持2019.4.x,但新手请先按照下面要求跑通流程后,再根据安装HybridCLR文档尝试2019.4.x。 安装 2020.3.26+…

如何部署LVS负载均衡集群(DR模式)

目录 一、集群概念与NAT模式LVS集群 二、部署LVS集群&#xff08;DR模式&#xff09; 第一步 关闭防火墙和安全机制 第二步 手动配置ip_vs 第三步 安装ipvsadm工具 第四步 创建虚拟网卡 第五步 修改虚拟网卡配置内容 第六步 开启虚拟网卡并加入路由 第七步 调整proc相…

linux学习(韩顺平 一周学会linux)

b站链接&#xff1a;b站 共27个小时 P3-P85 linux基础篇 P86-P90 java定制篇 P91-P107 大数据shell篇 P108-P115 python定制篇 P117-P141 linux高级篇 P142-P153 面试题 四个阶段&#xff1a; 一、基本操作 二、配置 三、搭建开发环境 四、写一些基本的shell脚本 五、安全设置…

list容器语法

文章目录 listlist基本概念list的优点&#xff1a;list的缺点&#xff1a;重要性质 list 的使用方法list构造函数list 赋值和交换list 长度/大小操作list 插入元素和删除元素访问list 反转和排序sort链表排序案例forward_list&#xff08;C11&#xff09;forward_list 的使用方…

Openlayers实战:绘制点、线、圆、多边形

Openlayers地图中,绘制图形是非常重要的一个功能。Openlayers主要使用draw类来绘制图形,在实际项目中经常会绘制点、线、多边形、矩形等。 下面的示例是绘制点、线、圆形、多边形。 效果图 源代码 /* * @Author: 大剑师兰特(xiaozhuanlan),还是大剑师兰特(CSDN) * @此…

抖音关键词排名怎么做

抖音seo关键词搜索排名推广 产品及合作流程 了解抖音seo关键词搜索流量——用工具选择需要优化的关键词确认——预存套餐及服务——付款签约——开通关键词管理后台——建运营群流程化推进 如何选择优化的关键词? 先选3-5个主词 在工具分别输入主词 列出来的词&#xff0c…

【AJAX】跨域问题笔记

跨域 一、同源策略&#xff08;Same-Origin Policy&#xff09; 是浏览器的安全机制。 同源&#xff1a;协议、域名、端口号必须完全相同 客户端 服务端 违背同源策略就是跨域 二、如何解决跨域 1、JSOPN &#xff08;1&#xff09;JSONP是什么 JSONP(JSON with Padding…