【Git】Git-常用命令备忘录(三)

git作为一个vcs(version control system),是越用越香,那么还有哪些比较香的地方呢!?

1.远程仓库中拉取指定分支

一定遇到这种情况,github看到一个心仪的开源仓库,但是分支太多,我们只想要我们需要的分支。

git clone -b <指定分支名> <远程仓库地址>

2.递归克隆

项目里包含的一些库或者一些模块是存在了别的仓库,可以用递归来克隆回来。一次性就能解决所有的依赖模块

git clone --recursive https://github.com/dotnet/aspnetcore.git

3.切换到指定分支

分支众多,要切换到指定分支

#branch分支管理
git branch
git switch 分支名

4.创建标签

git tag v1.0
#默认标签是打在最新提交的commit上

5.为指定的commit id创建标签

上面标签,是为最新的一次提交创建的。但是我们想吃后悔药——为之前的提交创建标签,该怎么做呢!?

$ git log --pretty=oneline --abbrev-commit
$ git tag 标签值 commitId#查看标签信息
$ git show 标签值

6.删除标签

$ git tag -d v0.1#删除远程标签
$ git tag -d v0.9
$ git push origin :refs/tags/v0.9

7.推送标签至远程仓库

#推送指定标签至远程
$ git push origin v0.1#推送全部标签至远程
$ git push origin --tags

8.切换至标签

#tag标签管理
git tag
#切换
git checkout tag值

9.本地没有远程标签

#查看本地标签
git tag -l#查看远程标签
git ls-remote -t#删除本地标签
git tag -d 待删除的标签值#拉取远程的标签
git fetch origin --prune-tags#再次查看本地标签
git tag

10.gitignore文件重新生效

从gitee 创建仓库,可选择创建不同项目下.gitignore文件模板。但是我们修改.gitignore文件,并不生效。.gitignore只能忽略那些原来没有被track的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore是无效的,把要忽略的文件改为未track状态

git rm -r --cached .  #清除缓存   取消跟踪所有文件,但不删除本地文件
git add . #重新trace file  
git commit -m "update .gitignore" #提交和注释  
git push origin master #可选,如果需要同步到remote上的话  

11.本地关联远程

一般情况,常规操作是先在github或者gitee创建远程仓库,然后

git clone 
git add -A
git commit -m ""
git push -u origin master

但是还有一种情况,先通过git init创建的本地仓库,突然发现今天写的代码太优美了,要整个远程仓库存起来。

#初始化-建立本地仓库
git init#把本地仓库与远程仓库关联
git remote add origin git@gitee.com:RandyField/xxxxx.git#push
git push -u origin master#但是可能会出现如下错误! [rejected]        master -> master (non-fast-forward)
error: failed to push some refs to 'git@gitee.com:RandyField/xxxxx.git'
hint: Updates were rejected because the tip of your current branch is behind
hint: its remote counterpart. Integrate the remote changes (e.g.
hint: 'git pull ...') before pushing again.
hint: See the 'Note about fast-forwards' in 'git push --help' for details.#原因是创建远程仓库,和本地仓库没有关联,也具有差异#把远程仓库和本地同步,消除差异,把两段不相干的分支进行强行合并
git pull origin master --allow-unrelated-histories git add -A
git commit -m "[dev]init"
git push -u origin master

12.变基->快进合并

将提交到某一分支上的所有修改都移至另一分支上,就好像“重新播放”一样(将一个分支的修改操作在另一个分支最新的提交基础上在依次应用)。

#小明童鞋,克隆
git clone xxx.git#小明童鞋,创建了dev分支
git switch -c devgit add .
git commit -m "c"git add xxx.go
git commit -m "update xxx.go"git add App.vue
git commit -m "update App.vue"#大明童鞋,克隆
git clone xxx.git
git add main.js
git push -u origin master#小明童鞋
git switch master
git pull
git switch dev
git rebase master
#有冲突,需要手动合并文件解决,解决冲突后使用git add表示冲突已经解决
git add .
#表示继续下一个冲突
git rebase --continue
#切换至master
git switch master
#快进合并
git merge dev# 其他命令
git rebase --skip #表示跳过当前冲突,
git rebase --abort #表示退出rebase模式,回到运行git rebase master命令之前的状态

rebase干了什么?

  • 找到masterdev最近一个共同的父commit对象

  • 并找出这个共同的父commit对象到dev分支最新提交对象之间的所有对象,将这些对象依次添加至master分支最新一次提交后。这个过程很像将一个数组追加到另一个数组,没错append操作。

  • 这时我们git rebase master会提示有冲突(因为我们在master和dev可能修改了相同的文件),对冲突文件进行手工合共,然后git add .标记冲突解决,git rebase --continue告诉Git冲突已经解决。

  • dev分支上变基(git rebase master)。这时我们回到msater分支执行 git merge dev就可以进行"快进(fast-forward)"模式合并。

参考链接

https://git-scm.com/book/zh/v2/Git-%E5%88%86%E6%94%AF-%E5%8F%98%E5%9F%BA

https://www.jianshu.com/p/6960811ac89c

https://blog.csdn.net/fly_zxy/article/details/82586861

长按二维码关注

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

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

相关文章

jenkins换服务器找不到包,服务器重启后Jenkins项目部分丢失问题解决方法

UVALive 4670 Dominating Patterns --AC自动机第一题题意:多个模板串,一个文本串,求出那些模板串在文本串中出现次数最多. 解法:AC自动机入门模板题. 代码: #include #include phpMyAdmin - 错误 您应升级到 MySQL 5&period;5&period;0 或更高版本&comma;解决办法。…

mysql表类型_MySQL表类型的选择

P131)创建表时的默认引擎是InnoDB&#xff0c;如果要修改默认的存储引擎&#xff0c;可以在参数文件中设置default-table-type。查看当前的默认存储引擎&#xff0c;可以使用一下命令&#xff1a;创建新表的时候可以通过增加ENGINE关键字设置新建表的存储引擎。也可以通过ALTER…

计算机怎么取消脱敏设置,一种敏感数据自适应的脱敏方法、系统技术方案

【技术实现步骤摘要】一种敏感数据自适应的脱敏方法、系统本专利技术涉及计算机技术与信息安全领域&#xff0c;并且更具体地&#xff0c;涉及一种敏感数据自适应的脱敏方法、系统。技术介绍随着数据时代的到来&#xff0c;数据中蕴藏的巨大价值得以挖掘&#xff0c;同时也带来…

ASP.NET Core Controller与IOC的羁绊

前言看到标题可能大家会有所疑问Controller和IOC能有啥羁绊&#xff0c;但是我还是拒绝当一个标题党的。相信有很大一部分人已经知道了这么一个结论&#xff0c;默认情况下ASP.NET Core的Controller并不会托管到IOC容器中&#xff0c;注意关键字我说的是"默认"&#…

win10 mysql my.cnf_MySQL配置文件无法修改的解决方法(Win10)

帮别人解决的问题&#xff0c;记录一下。问题描述MySQL的版本是5.7&#xff0c;操作系统是window10。MySQL安装在 C:\Program Files 下。最近需要在MySQL安装目录下的 my-default.ini 配置文件里面加上一个新的配置项&#xff1a;max_allowed_packet100M编辑文件后保存&#xf…

服务器机房 维护,服务器机房建设与管理维护.pdf

服务器服务器机房机房建设与管理维护建设与管理维护服务器服务器机房机房建设与管理维护建设与管理维护电子科技大学信息中心目录服务器机房的设计和建设服务器机房的设计和建设服务器机房的运行维护和管理服务器机房的设计与建设一、机房对信息化的发展的重要性二、计算机…

引入Jaeger——扩展

Jaeger是收集全链路跟踪的信息&#xff0c;在Jaeger收集的信息中&#xff0c;有请求的url信息&#xff0c;有每个请求的时间间隔&#xff0c;借助这些信息可以进行报警&#xff0c;比如一次较长的请求&#xff0c;或者是某些请求的次数和先后等。不管报警的业务规则是什么&…

mysql 操作类 C .net_.NET MYSQL数据库操作基类( C#源码)

使用MySql.Data.dll&#xff0c;它.Net访问MySQL数据库的一个驱动  下载DbHelperMySql.CSusing System;using System.Collections;using System.Collections.Specialized;using System.Data;using System.Data.SqlClient;using System.Configuration;using MySql.Data.Types;…

判断 服务器架构性能 数据,服务器架构之性能扩展-第五章(6)

Mysql>create table t2 like t1;//复制表结构Mysql>insert into t2 select * from t1; //复制数据内容索引是一种快速查询的有效方法&#xff0c;可以通过alter增加索引或create语句创建。mysql>alter table t1 add ind_id (id);mysql>alter table t1 add unique/p…

微服务畅想录

关于微服务的文章&#xff0c;网络上很多&#xff0c;也比较专业。下面&#xff0c;我尝试着用简单的话写点自己对微服务的理解&#xff0c;非常接地气&#xff0c;但只是一家之言&#xff0c;大家还是带着辩证的眼光来读。1、微服务的本质是什么&#xff1f;微服务的本质是&am…

mysql sql 检测磁盘_MySQL 数据库磁盘占用情况查询

查询所有数据库占用磁盘空间大小的SQL语句&#xff1a;select TABLE_SCHEMA, concat(truncate(sum(data_length)/1024/1024,2), MB) as data_size,concat(truncate(sum(index_length)/1024/1024,2),MB) as index_sizefrom information_schema.tablesgroup by TABLE_SCHEMAorder…

anjularjs ajax 调用,AngularJS AJAX调用的服务(AngularJS Ajax Call in Service

我想我的应用程序&#xff0c;使AJAX调用一个RESTful Web服务。 在我的html文件是连接到一个范围对象两个文本框。 这两个领域都连接到通过NG-变“后”功能。 post方法发送“形式”变量从范围的API和web服务增加了两个数字&#xff0c;并用JSON文件&#xff0c;该文件现在包含的…

如何在 ASP.NET Core 中 使用 功能开关

.NET Core 中的 功能管理 (Feature Management) 包可用于实现 功能开关&#xff0c;什么意思呢&#xff1f;就是可以通过 功能开关 特性动态的改变应用程序的行为而不需要改变任何的业务逻辑代码&#xff0c;听起来是不是挺有意思&#xff0c;本篇我们就来讨论如何使用这个包。…

存储mysql数据存在特殊字符时处理_SQL数据库对于保存特殊字符的解决办法

数据库的Char、Vachar类型可以兼容汉字&#xff0c;但特殊字符不行&#xff0c;在保存包含有特殊字符的字符串、正文时&#xff0c;会将特殊符号替换成一个”?”号。例如&#xff1a; “基础教育课程手机报•特刊” 》 “基础教育课程手机报?特刊”解决办法是将字段改成NCha…

接口 Swagger 部分Web API的隐藏

背景Swagger是目前最受欢迎的REST APIs文档生成工具&#xff0c;同时也是API的在线测试工具。功能强大谁用谁知道。我就不用在这里推广它了。今天要解决的问题是&#xff1a;如果让一些特定的API接口在Swagger中不显示&#xff0c;即从Swagger中过滤掉一些不想展示的接口&#…

mysql流程控制_Mysql之流程控制结构

顺序结构&#xff1a;程序从上往下依次执行分支结构&#xff1a;程序从两条或多条路径中选择一条去执行循环结构&#xff1a;程序在满足一定条件的基础上&#xff0c;重复执行一段代码一、分支结构1、if函数功能&#xff1a;实现简单的双分支语法&#xff1a;if(表达式1, 表达式…

文件共享服务器第二部,第二章-构建Samba文件共享服务器.docx

洛阳鸿卓国际IT洛阳鸿卓国际IT教育培训中心姓名&#xff1a; 梁冬辉时间&#xff1a;2012章实验报告所在班级&#xff1a; T1181月16实 验 任 务日Linux服务器版系统的地址为Win dows系统的地址为网络拓扑检查smb服务消息是否安装[rootocaThOSt /]# cd /unt/Asianux/RPMS/i roo…

「译」 .NET 5 新增的Http, Sockets, DNS 和 TLS 遥测

.NET 一直在稳定的增加和改善对应用程序进行跨平台的诊断分析&#xff0c;在.NET Core 3.0&#xff0c; 我们看到了 EventCounters[1] 的介绍&#xff0c;用于观察和分析指标测量。我最近在几个 .NET Core 的应用程序中使用 counters&#xff0c;来跟踪服务一段时间内 http 的请…

服务器磁盘系统,服务器磁盘阵列与操作系统

服务器磁盘阵列与操作系统 内容精选换一换硬件要求如表1所示。操作系统要求如表2所示。上表中所需Ubuntu下载地址&#xff1a;服务器1&#xff1a;Ubuntu 18.04.1镜像包、Ubuntu 16.04.4 镜像包。服务器2&#xff1a;Ubuntu 16.04.3 镜像包。在安装操作系统过程中“选择软件列表…

Prism for WPF 搭建一个简单的模块化开发框架

站长今天发现一个好项目&#xff0c;看原文贴图挺不错的&#xff0c;好项目应该让更多人知道&#xff0c;特别是该项目使得Prism搭建&#xff0c;网上使用prism做的开源成熟项目不多&#xff0c;这个值得大家研究。看项目gitee仓库截图&#xff0c;项目不错&#xff0c;star太少…