如何在github fork仓库发起Pull Request合入全流程

2023-10-31 01:59

本文主要是介绍如何在github fork仓库发起Pull Request合入全流程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言:我们要悄悄努力,不用惊艳所有人,只需要惊艳自己就好,因为你是自己人生唯一的负责人!

本篇文章将讲述,github Pull Request合入后,原仓库的commit log如何显示为一条线?
之前也写过类似的两篇文章:
1、github的pull Request使用
2、github上fork原项目,如何将本地仓库代码更新到最新版本?

不同之处在于合入方式,之前写的是按照"merge pull request“合入,在最近开发中,发现这样始终会多出一个commit,在fork仓库同步的时候又会多出一个commit,来回多了两个commit,并且commit log看起来也会交错在一起,不便于阅读。诸如下图:
在这里插入图片描述
通过本篇文章操作后,commit log如下图,清晰整洁。
在这里插入图片描述

一、图解全流程
在这里插入图片描述
二、详细步骤
1.、fork仓库
在这里插入图片描述
2、clone fork仓库到本地
在这里插入图片描述
3.、关联upstream原仓库
在fork本地仓库输入下面命令进行关联:

git remote add upstream <原仓库github地址>

查看仓库地址:

git remote -v

4、 fork本地仓库commit+push
修改完文件后执行下面命令:

git add .
git commit -m 'message'
// push推送到fork远程仓库
git push origin master

5、发起Pull Request
在fork远程仓库,点击Pull Request->New Pull Request,进入以下截图页面
base repository为原仓库的某个分支,
head repository为fork仓库发某个分支
head的某个分支代码合到base的某个分支
在这里插入图片描述
6、原仓库合入PR
进入原仓库的Pull requests可看到刚才发起的PR

github pull request介绍
三种合入方式介绍:

Merge pull request:将fork仓库的每一次提交都合并到原仓库,并且还产生了一个merge commit log。
Squash and merge:将多个commit合并为一个commit添加到原仓库中,会产生一个新的commit id。 Rebase
and merge:将fork仓库的每一次提交都rebase到原仓库,但github的rebase行为与git
rebase略有偏差。GitHub上的变基和合并始终会更新提交者信息并创建新的提交,也就是产生新的commit id。

选择“Squash and merge”进行合入
在这里插入图片描述
合入后会产生如下图的一条commit:
这条commit包含了发起PR时fork仓库的几个commit
在这里插入图片描述
7、fork本地仓库更新
原仓库合入后产生了一条新的commit id,为了保持一致,需要在fork本地仓库进行更新

// 更新并合并原仓库的master分支
git pull --rebase upstream master

更新前:test4和test5为两次commit
在这里插入图片描述
更新后:test4和test5合并为fork原仓库通过squash and merge产生的commit
在这里插入图片描述
8、修改文件后,再commit + push
这时,push推送到远程仓库,需要进行强制覆盖fork远程仓库。因为fork远程仓库仍是test4、test5两次提交的commit,而本地仓库已经更新同步为原仓库的合并commit。不强制覆盖则会在push时提示需要更新与远程分支同步。

git push origin master --force

在这里插入图片描述
至此fork、clone、commit、push、pull整个流程已完成。

愿看到这篇文章的童鞋们不断的学习!不断的爬坑!不断的总结!写出更优质的代码!

这篇关于如何在github fork仓库发起Pull Request合入全流程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C#提取PDF表单数据的实现流程

《C#提取PDF表单数据的实现流程》PDF表单是一种常见的数据收集工具,广泛应用于调查问卷、业务合同等场景,凭借出色的跨平台兼容性和标准化特点,PDF表单在各行各业中得到了广泛应用,本文将探讨如何使用... 目录引言使用工具C# 提取多个PDF表单域的数据C# 提取特定PDF表单域的数据引言PDF表单是一

PyCharm接入DeepSeek实现AI编程的操作流程

《PyCharm接入DeepSeek实现AI编程的操作流程》DeepSeek是一家专注于人工智能技术研发的公司,致力于开发高性能、低成本的AI模型,接下来,我们把DeepSeek接入到PyCharm中... 目录引言效果演示创建API key在PyCharm中下载Continue插件配置Continue引言

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

Python实现NLP的完整流程介绍

《Python实现NLP的完整流程介绍》这篇文章主要为大家详细介绍了Python实现NLP的完整流程,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 编程安装和导入必要的库2. 文本数据准备3. 文本预处理3.1 小写化3.2 分词(Tokenizatio

SpringBoot使用minio进行文件管理的流程步骤

《SpringBoot使用minio进行文件管理的流程步骤》MinIO是一个高性能的对象存储系统,兼容AmazonS3API,该软件设计用于处理非结构化数据,如图片、视频、日志文件以及备份数据等,本文... 目录一、拉取minio镜像二、创建配置文件和上传文件的目录三、启动容器四、浏览器登录 minio五、

Nginx、Tomcat等项目部署问题以及解决流程

《Nginx、Tomcat等项目部署问题以及解决流程》本文总结了项目部署中常见的four类问题及其解决方法:Nginx未按预期显示结果、端口未开启、日志分析的重要性以及开发环境与生产环境运行结果不一致... 目录前言1. Nginx部署后未按预期显示结果1.1 查看Nginx的启动情况1.2 解决启动失败的

Security OAuth2 单点登录流程

单点登录(英语:Single sign-on,缩写为 SSO),又译为单一签入,一种对于许多相互关连,但是又是各自独立的软件系统,提供访问控制的属性。当拥有这项属性时,当用户登录时,就可以获取所有系统的访问权限,不用对每个单一系统都逐一登录。这项功能通常是以轻型目录访问协议(LDAP)来实现,在服务器上会将用户信息存储到LDAP数据库中。相同的,单一注销(single sign-off)就是指

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

记录每次更新到仓库 —— Git 学习笔记 10

记录每次更新到仓库 文章目录 文件的状态三个区域检查当前文件状态跟踪新文件取消跟踪(un-tracking)文件重新跟踪(re-tracking)文件暂存已修改文件忽略某些文件查看已暂存和未暂存的修改提交更新跳过暂存区删除文件移动文件参考资料 咱们接着很多天以前的 取得Git仓库 这篇文章继续说。 文件的状态 不管是通过哪种方法,现在我们已经有了一个仓库,并从这个仓

取得 Git 仓库 —— Git 学习笔记 04

取得 Git 仓库 —— Git 学习笔记 04 我认为, Git 的学习分为两大块:一是工作区、索引、本地版本库之间的交互;二是本地版本库和远程版本库之间的交互。第一块是基础,第二块是难点。 下面,我们就围绕着第一部分内容来学习,先不考虑远程仓库,只考虑本地仓库。 怎样取得项目的 Git 仓库? 有两种取得 Git 项目仓库的方法。第一种是在本地创建一个新的仓库,第二种是把其他地方的某个