GitHub中Fork来的仓库如何进行双向更新


[TOC](文章目录)

一、做点贡献

想对别人的某个仓库”做点贡献”怎么办?

1. Fork该仓库

首先Fork该仓库,本文以git-learn这个仓库为例

GitHub中Fork来的仓库如何进行双向更新

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

GitHub中Fork来的仓库如何进行双向更新

2. Clone代码并修改

然后把这个仓库clone下来

git clone https://github.com/FlyLolo/git-learn.git

我新建了一个Student类

GitHub中Fork来的仓库如何进行双向更新

3. 提交修改到自己的仓库

然后将修改提交

git add .

git commit -m 'add student'

git push origin master

这样会将修改提交到自己账号下的git-learn仓库

那么如何将修改提交到源仓库呢?

4. 提交pull requests

如果想将修改提交到源仓库,需要进行pull requests

GitHub中Fork来的仓库如何进行双向更新

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

GitHub中Fork来的仓库如何进行双向更新

图中红框部分显示了提交修改的方向,即从自己账号仓库的main分支提交到源仓库的main分支。

点击create pull request按钮:

GitHub中Fork来的仓库如何进行双向更新

点击下面的按钮提交就可。

5. 源仓库审核pull requests

此时源仓库的作者在源仓库的pull requests页面就会看到如下的Merge pull请求

GitHub中Fork来的仓库如何进行双向更新

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

GitHub中Fork来的仓库如何进行双向更新

比如点击Merge pull request同意将修改合并。

二、Fork过来的仓库如何更新

当一个仓库被Fork过来之后,它是不会随着源仓库更新的,那么如果想同步源仓库的更新过来如何操作呢?

还是pull requests。

GitHub中Fork来的仓库如何进行双向更新

默认是向原仓库提交修改请求

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-q1L0ByGC-1654552184213)(git-tag-update.assets/image-20220602094759603.png)]

我们现在不一样,想用原仓库更新fork过来的仓库

首先修改左侧的,改成自己的仓库

GitHub中Fork来的仓库如何进行双向更新

此时会变成这样

GitHub中Fork来的仓库如何进行双向更新

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

GitHub中Fork来的仓库如何进行双向更新

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

GitHub中Fork来的仓库如何进行双向更新

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

GitHub中Fork来的仓库如何进行双向更新

更新即可,这样就完成了main分支的更新。

三、 如何获取并更新指定Tag

看一下如何通过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

GitHub中Fork来的仓库如何进行双向更新

切换到对应的文件夹

cd git-learn

2. 我要添加注释

我想对部分代码进行注释,并提交到自己的仓库。(源仓库估计不会接收这样的修改请求,自己看就行了)

修改一个文件,例如添加了一个注释

GitHub中Fork来的仓库如何进行双向更新

准备提交修改

GitHub中Fork来的仓库如何进行双向更新

提示detached HEAD

如果是在IDEA中也会提示失败

其实clone的时候已经有提示,见第一幅图的红框提示。需创建并切换到一个新的分支。我将其命名为 tag-v1.0

git switch -c tag-v1.0

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-aIHXykxD-1654552184220)(git-tag-update.assets/image-20220602071921679.png)]

push的时候如果未指定分支会有如下提示:

GitHub中Fork来的仓库如何进行双向更新

按提示操作:

GitHub中Fork来的仓库如何进行双向更新

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

GitHub中Fork来的仓库如何进行双向更新

3. 代码如何更新版本

如果此时源仓库更新了v2.0甚至v3.0版本,而我这里还是v1.0的代码怎么办?

3.1 一次失败的尝试

首先,我想到了第二节的反向pull request, 机智如我

GitHub中Fork来的仓库如何进行双向更新

做了如上图配置,右侧选择了源仓库的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

GitHub中Fork来的仓库如何进行双向更新

获取upstream的数据

git fetch upstream

GitHub中Fork来的仓库如何进行双向更新

可以看到获取到了源仓库的各个分支和tag。

也可以获取指定的tag

git fetch upstream tag v3.0

合并分支

git merge v3.0

GitHub中Fork来的仓库如何进行双向更新

如果像这样出现合并冲突,自行解决冲突即可。

Original: https://www.cnblogs.com/FlyLolo/p/git-fork-update.html
Author: FlyLolo
Title: GitHub中Fork来的仓库如何进行双向更新

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/581838/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • 详细记录一次stampstime字段引起pxc集群脑裂

    事故回顾 运维执行导入sql,导入后收到master2和master3节点宕机的报警;检查集群状态发现master1进入初始化模式,无法读写;master2和master3已经下线…

    Linux 2023年6月14日
    068
  • 基于Swoole和Redis实现的并发队列处理系统

    由于PHP不支持多线程,但是作为一个完善的系统,有很多操作都是需要异步完成的。为了完成这些异步操作,我们做了一个基于Redis队列任务系统。 大家知道,一个消息队列处理系统主要分为…

    Linux 2023年5月28日
    080
  • 部署前后端为独立的 Docker 节点

    在『服务器部署 Vue 和 Django 项目的全记录』一文中,介绍了在服务器中使用 Nginx 部署前后端项目的过程。然而,当 Web 应用流量增多时,需要考虑负载均衡、流量分发…

    Linux 2023年6月7日
    0105
  • SpringBoot + Vue + ElementUI 实现后台管理系统模板 — 后端篇(五): 数据表设计、使用 jwt、redis、sms 工具类完善注册登录逻辑

    (1) 相关博文地址: SpringBoot + Vue + ElementUI 实现后台管理系统模板 — 前端篇(一):搭建基本环境:https://www.cnblogs.c…

    Linux 2023年6月11日
    0152
  • 计算机网络基础

    计算机网络基础 计算机网络的定义和功能 计算机网络是利用通信设备和线路,将分布在地理位置不同的、功能独立的多个计算机系统连接起来,以功能完善的网络软件(网络通信协议及网络操作系统等…

    Linux 2023年6月7日
    080
  • Java基础系列–07_String、StringBuffer和StringBuilder

    String类(1)字符串:字符串是 常量;它们的值在 创建之后不能更改,存储在堆中。如果字符串多次赋值,其实是每次重新赋值的时候程序都先在内存中寻找已开辟的空间是否存在该值;如果…

    Linux 2023年6月7日
    065
  • Linux 下统计文件夹下文件的数量

    1、查看当前目录下的文件数量(不包含子目录中的文件) 2、查看当前目录下的文件数量(包含子目录中的文件) 3、 查看当前目录下的文件夹目录个数(不包含子目录中的目录),同上述理,如…

    Linux 2023年6月13日
    096
  • CentOS——Redis消息订阅发布

    作用: 发布订阅类似于信息管道,用来进行系统之间消息解耦。类似于mq,rebbitmq,rocketmq,kafka,activemq 主要有消息发布者和消息订阅者。 比如:订单支…

    Linux 2023年5月28日
    097
  • firewalld dbus接口使用指南

    404. 抱歉,您访问的资源不存在。 可能是URL不正确,或者对应的内容已经被删除,或者处于隐私状态。 [En] It may be that the URL is incorre…

    Linux 2023年5月27日
    0106
  • 聊聊Mysql主从同步读写分离配置实现

    Hi,各位热爱技术的小伙伴您们好,好久没有写点东西了,今天写点关于mysql主从同步配置的操作日志同大家一起分享。最近自己在全新搭建一个mysql主从同步读写分离数据库简单集群,我…

    Linux 2023年6月14日
    084
  • 趣谈IO多路复用的本质

    在《轻松搞懂5种IO模型》中,我发起了一个投票。 答案是【同步IO多路复用】。目前,60%的朋友答对了。原因这里解释一下。 同步和异步的概念区别 同步:线程自己获取结果。(一条线索…

    Linux 2023年5月27日
    059
  • 常见Git命令汇总

    前言 最近,有朋友私信让我就 git 使用做篇文章分享,分享一下我在日常工作中是如何使用 git的。我当场就收费两包辣条,最后讨价还价,…

    Linux 2023年6月13日
    081
  • cobbler的部署

    cobbler部署 //配置yum源 [root@localhost ~]# curl -o /etc/yum.repos.d/CentOS-Base.repo https://m…

    Linux 2023年6月13日
    082
  • 配置nginx只打印延迟超过0.1s和非2XX的accesslog

    背景 当业务accesslog全开时,写入es的qps达到了10W,评估后觉得不太值得,所以考虑抽样打印。查看相关文档后发现目前我们使用的nginx版本不支持抽样打印,所以考虑其他…

    Linux 2023年6月14日
    097
  • Python 排序算法之快速排序

    快速排序之分治法三步走 """ 快速排序 分治法(divide and conquer),三步走 1. Partition:选择一个基准(pivot)…

    Linux 2023年6月13日
    090
  • CentOS8 AnolisOS8 yum安装 No match for argument: htop Error: Unable to find a match: htop

    镜像下载、域名解析、时间同步请点击阿里云开源镜像站 CentOS8 AnolisOS8 yum安装失败 今天有人反馈服务器卡,登录上服务器,想看下CPU以及内存使用情况,觉得top…

    Linux 2023年5月27日
    062
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球