fork gitlab项目,使用git rebase合并多次提交

2024-05-25 05:08

本文主要是介绍fork gitlab项目,使用git rebase合并多次提交,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

以前的做法

使用fork和git rebase

fork

git rebase

提交mr(Merge Request)


昨天第一次使用fork和git rebase,记录下。。。

以前的做法

以前习惯做法都是clone公司原有项目到本地,然后自己checkout一个新的分支(如dev)进行开发,开发测试完成后,会有组长负责去merge我的dev分支到master。

当然在这个需求的开发期间可能有无数次的git commit和git push。

使用git log可以看到自己在做这个需求期间提交了n次。。。

使用fork和git rebase

fork

选择需要fork的项目,点击【fork】,大约1分钟左右的时间,等fork完了以后就会看到自己名下已经有了该项目

 

然后就是常规操作了,clone自己名下的项目到本地,默认是master分支,然后自己根据当前需求checkout一个新的分支进行需求开发

git clone http://git.xxx.cn/xxx.xie/goutil.git// 例如:新开一个alert分支,进行告警相关功能开发
git checkout -b alert

然后就在alert分支开发---测试---提交

// add修改过的文件
git add main.go 
// 提交修改的msg
git commit -am "xxx" 
// 列出远程项目url
git remote -v
// 设置当前分支的上游
git remote add upstream http://git.xxx.cn/xxx.xie/ops.git
// 提交alert分支的修改
git push origin lert

如果已经设置过upstream,想要修改之前的upstream

git remote set-url upstream http://git.xxx.cn/rd/txxe.git

 

git rebase

合并之前的多次提交。

https://www.cnblogs.com/hujunzheng/p/9732936.html

// 我目前在alert分支,设置master作为rebase。这里还可以设置需要合并前多少次的提交
// git rebase -i master~1 ,表示合并前2次的提交
// -i 代表进入交互模式// 第一步:
git rebase -i master// 第二步
// 进入交互模式后,会出现最近几次的pick,把pick修改为s
// 参考https://www.codercto.com/a/45325.html
// https://www.cnblogs.com/hujunzheng/p/9732936.html// 第三步:
wq 保存后退出// 第四步:
修改 需要提交的msg// 第五步:
wq 保存退出最后出现类似的信息,说明rebase成功。
Successfully rebased and updated refs/heads/alert.

提交mr(Merge Request)

在gitlab下找到需要提交mr的项目的分支(我的alert分支),

选择对应的项目和分支

然后就是等待你的mr被处理,处理完了以后就merge到自己名下的master分支。 

首先clone fork出来的仓库到本地git clone git@github.com:123/456.git在 fork 的代码库中添加上游代码库的 remote 源git remote add upstream git@github.com:789/456.git获取原始仓库分支和对应的提交git fetch upstream在本地实现与upstream的同步git rebase upstream/master
成功的话提示如下:
$ git rebase upstream/master
First, rewinding head to replay your work on top of it...
Fast-forwarded master to upstream/master.推送自己的本地仓库到自己的远程仓库git push

https://blog.csdn.net/pl0321/article/details/86655288

这篇关于fork gitlab项目,使用git rebase合并多次提交的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1000559

相关文章

使用Python和OpenCV库实现实时颜色识别系统

《使用Python和OpenCV库实现实时颜色识别系统》:本文主要介绍使用Python和OpenCV库实现的实时颜色识别系统,这个系统能够通过摄像头捕捉视频流,并在视频中指定区域内识别主要颜色(红... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间详解

Windows下C++使用SQLitede的操作过程

《Windows下C++使用SQLitede的操作过程》本文介绍了Windows下C++使用SQLite的安装配置、CppSQLite库封装优势、核心功能(如数据库连接、事务管理)、跨平台支持及性能优... 目录Windows下C++使用SQLite1、安装2、代码示例CppSQLite:C++轻松操作SQ

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热

Python常用命令提示符使用方法详解

《Python常用命令提示符使用方法详解》在学习python的过程中,我们需要用到命令提示符(CMD)进行环境的配置,:本文主要介绍Python常用命令提示符使用方法的相关资料,文中通过代码介绍的... 目录一、python环境基础命令【Windows】1、检查Python是否安装2、 查看Python的安

Python并行处理实战之如何使用ProcessPoolExecutor加速计算

《Python并行处理实战之如何使用ProcessPoolExecutor加速计算》Python提供了多种并行处理的方式,其中concurrent.futures模块的ProcessPoolExecu... 目录简介完整代码示例代码解释1. 导入必要的模块2. 定义处理函数3. 主函数4. 生成数字列表5.

Python中help()和dir()函数的使用

《Python中help()和dir()函数的使用》我们经常需要查看某个对象(如模块、类、函数等)的属性和方法,Python提供了两个内置函数help()和dir(),它们可以帮助我们快速了解代... 目录1. 引言2. help() 函数2.1 作用2.2 使用方法2.3 示例(1) 查看内置函数的帮助(

Linux脚本(shell)的使用方式

《Linux脚本(shell)的使用方式》:本文主要介绍Linux脚本(shell)的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录概述语法详解数学运算表达式Shell变量变量分类环境变量Shell内部变量自定义变量:定义、赋值自定义变量:引用、修改、删

SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志

《SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志》在SpringBoot项目中,使用logback-spring.xml配置屏蔽特定路径的日志有两种常用方式,文中的... 目录方案一:基础配置(直接关闭目标路径日志)方案二:结合 Spring Profile 按环境屏蔽关

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.

Python中使用uv创建环境及原理举例详解

《Python中使用uv创建环境及原理举例详解》uv是Astral团队开发的高性能Python工具,整合包管理、虚拟环境、Python版本控制等功能,:本文主要介绍Python中使用uv创建环境及... 目录一、uv工具简介核心特点:二、安装uv1. 通过pip安装2. 通过脚本安装验证安装:配置镜像源(可