GitHub中Fork来的仓库如何进行双向更新
一、做点贡献
想对别人的某个仓库“做点贡献”怎么办?
1. Fork该仓库
首先Fork该仓库,本文以git-learn这个仓库为例

这样自己的账号下就会出现这样一个仓库

2. Clone代码并修改
然后把这个仓库clone下来
git clone https://github.com/FlyLolo/git-learn.git
我新建了一个Student类

3. 提交修改到自己的仓库
然后将修改提交
git add .
git commit -m 'add student'
git push origin master
这样会将修改提交到自己账号下的git-learn仓库
那么如何将修改提交到源仓库呢?
4. 提交pull requests
如果想将修改提交到源仓库,需要进行pull requests

点击上图的pull requests按钮,可以看到自动做了配置

图中红框部分显示了提交修改的方向,即从自己账号仓库的main分支提交到源仓库的main分支。
点击create pull request按钮:

点击下面的按钮提交就可。
5. 源仓库审核pull requests
此时源仓库的作者在源仓库的pull requests页面就会看到如下的Merge pull请求

可以对该请求做相应的处理

比如点击Merge pull request同意将修改合并。
二、Fork过来的仓库如何更新
当一个仓库被Fork过来之后,它是不会随着源仓库更新的,那么如果想同步源仓库的更新过来如何操作呢?
还是pull requests。

默认是向原仓库提交修改请求
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-q1L0ByGC-1654552184213)(git-tag-update.assets/image-20220602094759603.png)]
我们现在不一样,想用原仓库更新fork过来的仓库
首先修改左侧的,改成自己的仓库

此时会变成这样

点击图中的蓝字“ compare across forks”,可以看到箭头两边都是自己的仓库

更改右侧的仓库,最终结果如下图

已经找到了更新,点击右上角的create pull request 按钮

更新即可,这样就完成了main分支的更新。
三、 适用于阅读源码
看一下如何通过Fork方式满足的我源码阅读需求。
首先我想阅读的是指定版本的源码,例如tomcat的10.0.21版本,这需要我去clone它的tag 10.0.21,这样才能保证版本一致。
1. 如何Clone指定的标签
这里我指定了标签 v1.0
git clone -b v1.0 https://github.com/FlyLolo/git-learn.git

切换到对应的文件夹
cd git-learn
2. 我要添加注释
我想对部分代码进行注释,并提交到自己的仓库。(源仓库估计不会接收这样的修改请求,自己看就行了)
修改一个文件,例如添加了一个注释

准备提交修改

提示detached HEAD
如果是在IDEA中也会提示失败
其实clone的时候已经有提示,见第一幅图的红框提示。需创建并切换到一个新的分支。我将其命名为tag-v1.0
git switch -c tag-v1.0
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-aIHXykxD-1654552184220)(git-tag-update.assets/image-20220602071921679.png)]
push的时候如果未指定分支会有如下提示:

按提示操作:

提交成功。网页查看一下,已经有了新建的分支:

3. 代码如何更新版本
如果此时源仓库更新了v2.0甚至v3.0版本,而我这里还是v1.0的代码怎么办?
3.1 一次失败的尝试
首先,我想到了第二节的反向pull request, 机智如我

做了如上图配置,右侧选择了源仓库的tag v3.0 ,如愿的识别出了差异,但此时才发现原来的create pullrequest按钮没有了,尝试失败。
3.2 通过upstream获取更新合并
查看现有的remote地址
git remote -v
添加源仓库地址到upstream
git remote add upstream https://github.com/Test-2022/git-learn.git
再次查看remote地址列表
git remote -v

获取upstream的数据
git fetch upstream

可以看到获取到了源仓库的各个分支和tag。
也可以获取指定的tag
git fetch upstream tag v3.0
合并分支
git merge v3.0

如果像这样出现合并冲突,自行解决冲突即可。
GitHub中Fork来的仓库如何进行双向更新的更多相关文章
- github中fork分支和pullrequest的最佳实践
github中fork分支和pullrequest的最佳实践 */--> code {color: #FF0000} pre.src {background-color: #002b36; co ...
- 利用git把本地项目传到github+将github中已有项目从本地上传更新
利用git把本地项目传到github中 1.打开git bash命令行,进入到要上传的项目中,比如Spring项目,在此目录下执行git init 的命令,会发下在当前目录中多了一个.git的文件夹( ...
- 如何在Github中删除已有仓库或文件
一.删除已有仓库如果我们想要删除Github中没有用的仓库,应该如何去做呢? 进入到我们需要删除的仓库里面,找到“settings”即仓库设置: 然后,在仓库设置里拉到最底部,找到“Danger Zo ...
- github上fork的项目,如何同步原作者更新的内容?
一.引言 我在github上fork了一个项目,之后原作者又更新了内容,我想把原作者更新的内容同步到我fork的项目仓库中.在此记录一下同步步骤. 二.同步步骤 打开fork的项目的主页,点击Ne ...
- github中fork的使用
转载https://www.cnblogs.com/patchouli/p/6511251.html 由于git的权限控制功能比较弱,如果想给某个项目提供代码除了直接获得项目的push权限外,gith ...
- 出于迁移项目的考虑,GitHub 中 Fork 出来的项目,如何与原项目断开 Fork 关系?
如果需要为 GitHub 上的项目做贡献,我们通常会 Fork 到自己的名称空间下.在推送代码之后添加 pull request 时,GitHub 会自动为我们跨仓库建立 pull request 的 ...
- GitHub中有关已建仓库及上传项目文件的删除
上传了项目,竟然发现找不到删除的地方,真是囧... 1. 已建仓库的删除 点击 settings,进入以下界面,点击箭头指向的按钮 进入以下界面 2. 某个文件的删除 直接点开文件,在右上角有个删除工 ...
- [转]五步git操作搞定Github中fork的项目与原作者同步
命令如下: git clone xxx-fork.git git remote add xxx xxx.git git fetch xxx git merge xxx/master git push ...
- gitlab或github下fork后如何同步源的新更新内容?
两种方式: 项目 fetch 到本地,通过命令行的方式 merge 懒人方法,只用 Github ,不用命令行 1.项目 fetch 到本地,通过命令行的方式 merge 提示:跟上游仓库同步代码之前 ...
随机推荐
- Ubuntu 16.4安装1050ti显卡驱动问题及解决
不得不说,ubuntu上安装nvidia驱动坑是真的多!!! 本来在之前已经安装好了,从 显卡驱动到cuda再到cudnn去不没问题,就已一次推送而来的显卡驱动更新,把我的环境全部弄坏,为了吸取教训, ...
- Springboot 整合 MyBatisPlus[详细过程]
Springboot 整合 MyBatisPlus[详细过程] 提要 这里已经将Springboot环境创建好 这里只是整合MyBatis过程 引入Maven依赖 添加MyBatisPlus启动依赖, ...
- 实战|Linux大文件切割
一个执着于技术的公众号 日常工作中需要对日志文件进行分析,当日志文件过大时,Linux中使用vim.cat.grep.awk等这些工具对大文件日志进行分析将会成为梦魇,具体表现在: 执行速度缓慢,文件 ...
- linux的简介与安装
linux简介: https://www.cnblogs.com/pyyu/p/9277153.html Linux就是个操作系统:它和Windows XP.Windows7.8.10什么的一样就是一 ...
- Dns2tcp隧道
0x01 dns2tcp绕过的原理 dns2tcp是一款基于c/s架构的软件,它可以将通信报文夹藏在udp协议的TXT解析记录中,进而形成dns隧道.dns隧道通过dns2tcpc对本地端口的监听,实 ...
- Web安全学习笔记 SQL注入下
Web安全学习笔记 SQL注入下 繁枝插云欣 --ICML8 SQL注入小技巧 CheatSheet 预编译 参考文章 一点心得 一.SQL注入小技巧 1. 宽字节注入 一般程序员用gbk编码做开发的 ...
- Spring Ioc源码分析系列--Ioc容器注册BeanPostProcessor后置处理器以及事件消息处理
Spring Ioc源码分析系列--Ioc容器注册BeanPostProcessor后置处理器以及事件消息处理 前言 上一篇分析了BeanFactoryPostProcessor的作用,那么这一篇继续 ...
- Css实例之信息提交
代码实例: <!DOCTYPE html><html><head><meta charset="UTF-8"><title&g ...
- 判断数据类型(typeof&instanceof&toString)
一.数据类型 ES6规范中有7种数据类型,分别是基本类型和引用类型两大类 基本类型(简单类型.原始类型):String.Number.Boolean.Null.Undefined.Symbol 引用类 ...
- Linux详解(基础、环境配置、项目部署入门)
Linux(CentOS 7)操作系统 消息队列(Kafka.RabbitMQ.RocketMQ),缓存(Redis),搜索引擎(ES),集群分布式(需要购买多台服务器,如果没有服务器我们就只能使用虚 ...