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 提示:跟上游仓库同步代码之前 ...
随机推荐
- Linux 实现静态路由实验
环境: 四台主机: A主机:eth0 NAT模式 R1主机:eth0 NAT模式,eth1 仅主机模式 R2主机:eth0 桥接模式,eth1仅主机模式 B主机:eth0 桥接模式 手动修改IP地址 ...
- 1.5 Linux中大量使用脚本语言,而不是C语言!
说到在 Linux 下的编程,很多人会想到用C语言,Linux 的内核.shell.基础命令程序,也的确是用C语言编写的,这首先证明了一点,C语言很强很通用. 到目前为止,C语言依然垄断着计算机工业中 ...
- mybatis入门,CRUD,万能Map,模糊查询
第一个Mybatis程序 核心配置文件mybatis-config.xml <?xml version="1.0" encoding="UTF-8" ?& ...
- linux篇-centos7安装DHCP服务器
1检查防火墙和selinux(关闭) 关闭防火墙和selinux,这边不多说 2检查DHCP状态 3安装DHCP软件包 4把系统默认的样例复制 5修改配置文件 option domain-name & ...
- 04C++核心编程(二-泛型编程)
Day08 笔记 1 函数模板 1.1 泛型编程 – 模板技术 特点:类型参数化 1.2 template< typename T > 告诉编译器后面紧跟着的函数或者类中出现T,不要报错, ...
- js循环调用axios异步请求,实现同步
准备: const axios = require('axios'); // axios请求 const res = []; const arr = ["a", "b&q ...
- Kafka到底有多高可靠?(RNG NB)
在聊Kafka高可靠之前,先在评论区来波RNG NB好不好! 什么叫可靠性? 大家都知道,系统架构有三高:「高性能.高并发和高可用」,三者的重要性不言而喻. 对于任意系统,想要同时满足三高都是一件非常 ...
- MTK 平台sensor arch 介绍-scp
架构介绍 路径:vendor/mediatek/proprietary/tinysys/scp 1.[build]编译相关 2.[driver]scp 的driver,I2C,power,eint 3 ...
- Zookeeper分布式锁实现Curator十一问
前面我们剖析了Redisson的源码,主要分析了Redisson实现Redis分布式锁的15问,理清了Redisson是如何实现的分布式锁和一些其它的特性.这篇文章就来接着剖析Zookeeper分布式 ...
- HDLBits->Circuits->Arithmetic Circuitd->3-bit binary adder
Verilog实例数组 对于一个定义好的简单module,例如加法器之类,如果我们要对其进行几十次几百次的例化,并且这些例化基本都是相同的形式,那么我们肯定不能一个个的单独对其进行例化,此时我们就可以 ...