GitHub fork 合作开发 - 快速实现版
目录
- 一 预备条件
- 二 fork项目
- 三 将项目clone到本地
- 四 push代码到自己的仓库
- 五 通过pull request提交代码
- 六 通过本地配置upstream来同步更新主repo的内容
- 七 通过主repo创建pull request来同步更新主repo的内容
- 八 后记
一 预备条件
- windows用户安装git for windows客户端:https://gitforwindows.org/
- 已拥有GitHub帐号,并且配置好了sshkey
二 fork项目
- 浏览器登陆自己的GitHub帐号,打开你要fork的项目地址,如:https://github.com/southday/devtoolstest
- 点击右上角 Fork,如图:

- fork项目后,你就可以在自己的Repositories中看到刚才fork的项目,点击进入该项目

三 将项目clone到本地
- 打开devtoolstest项目后,点击右边绿色框的“Clone or download”,复制项目git地址

- 运行 Git Bash(也可以使用Git GUI),命令行进入到你要把项目clone到的位置,在该目录下执行命令:
- >git clone https://github.com/lcxv/devtoolstest.git

- cd 目录名 // 表示进入指定目录,支持相对路径和绝对路径
- cd .. // (2个点)表示退回到上一级目录
- cd . // (1个点)表示进入当前目录
- pwd // 显示当前所在目录
- ls // 展示当前目录下的内容
四 push代码到自己的仓库
- 进入到devtoolstest/目录下,创建:Test.java,编写输出Hello world的代码(或者在其他地方写好,拷贝到该目录下也行)
- 执行命令:>git add Test.java
- 执行命令:>git commit -m "添加 Test.java"
- 执行命令:>git push origin master
- 注:如果你之前没在本地Git for windows上登陆过GitHub,那么会提示你输入用户名、密码进行登陆;
- 注:关于git add、commit、push等命令的详细解释及相关概念,需要自行查阅资料,可以参考:Git教程 - 廖雪峰的官方网站
- >git lol 命令是用于查看项目提交、合并等记录,默认没有这个命令,是通过alias命令配置别名产生的,如果你想用该命令,需要先执行下面的命令进行别名设置:
- >git config --global alias.lol "log --graph --decorate --pretty=oneline --all --abbrev-commit"

- 显示提交成功后,打开浏览器,看看自己的devtoolstest项目(刷新一下页面),如我的地址是:https://github.com/lcxv/devtoolstest

- 点击 Test.java,就可以看到你之前提交的内容:

五 通过pull request提交代码
- 第4步结束,你的内容还只是提交到了你自己的repo上,并没有提交到主repo(即你Fork的repo)
- 把页面切换到 “Pull requests”,然后 New pull request

- 从 哪里(源)merge 到哪里(目的),这个根据具体情况选择,本例中是要把之前在lcxv/devtoolstest/中的Test.java merge 到 southday/devtoolstest/中,如下:

- 写上 Title 和 Write,然后 Create pull reques

- 然后对方(主repo)就会有关于你的 pull request,如下:

- 对方觉得你写的内容不错,就会同意你的请求,把代码合并到主repo中

六 通过本地配置upstream来同步更新主repo的内容
- 主repo中添加了一个文件“southday-add.md”,现在我们要在本地中同步该内容
- 先获取主repo项目的git地址,如本例中,主repo项目git地址为:https://github.com/southday/devtoolstest.git
- 命令行进入到本地仓库目录,然后执行下面的命令进行remote配置:
- >git remote add upstream https://github.com/southday/devtoolstest.git
- 然后执行命令:>git remote -v 检查是否配置成功,下面出现了 upstream 以及对应的主项目git地址,说明配置成功

- 执行命令:>git pull upstream master 来获取主repo中添加的“southday-add.md”文件

- 如果主repo不是添加文件,而是修改了原文件,比如修改了:"README.md" 文件
- 那么执行命令:>git fetch upstream 来更新修改内容

- 执行到这里,主repo的改动已经同步到了你的仓库中了(本地 & 远程),你可以刷新浏览器看看 lcxv/devtoolstest/中的内容有没有变
七 通过主repo创建pull request来同步更新主repo的内容
- lcxv 浏览器访问自己的repo(https://github.com/lcxv/devtoolstest),然后点击点击 New pull request,如下:

- 和第5步相反,我们现在是要将 southday/devtoolstest/中的内容 推给 lcxv/devtoolstest/,所以需要修改推送方向,如图:

- 源改为:southday/devtoolstest 后,页面会自动刷新,然后提示你:There isn’t anything to compare. 这是因为你没还没有修改目的仓库,源->源,肯定没东西可更新的,这时,点击稍微右上角的“compare across forks”,再将目的仓库改为:lcxv/devtoolstes


- 接下来的操作和第5步中的类似,创建 pull request 后,可以 Merge pull request

- 这样,你远程仓库中的内容就得到了同步,接下来用自己的远程仓库去同步本地仓库的内容,在本地仓库下执行命令:
- >git fectch origin
- >git pull origin master


八 后记
至此,GitHub fork 合作开发 快速实现版结束,需要注意:
- 本例中只讲了怎么操作,却没讲为什么这样做,所以需要自己去学习Git的相关知识
- 参与者一般是没有权限把代码直接 push 到 主repo的,大家都是走 pull request流程,这样多了一个审核步骤也比较稳妥
参考内容:
- Git教程 - 廖雪峰的官方网站
- git 简明指南
- 如何高效利用GitHub
- fork 同步更新:
- GitHub 实现多人协同开发权限控制
转载请说明出处,have a good time! :D
GitHub fork 合作开发 - 快速实现版的更多相关文章
- 在github fork的项目中推送与抓取
github -- fork提交项目:自己的仓库和原仓库进行Git同步的操作. 1. 获取你fork的原仓库的更新过的最新代码:如果没有远程原始分支则需要增加. git remote add upst ...
- 最新番茄花园win7系统快速稳定版
这是最新番茄花园win7系统64位快速稳定版 V2016年2月,该系统由系统妈整理和上传,系统具有更安全.更稳定.更人性化等特点.集成最常用的装机软件,集成最全面的硬件驱动,精心挑选的系统维护工具,加 ...
- 雨林木风ghost win7 64位快速装机版V2016年
雨林木风ghost win7 64位快速装机版V2016年2月 系统下载:http://www.xitongma.com 系统概述 雨林木风ghost win7 64位旗舰装机版自动无人值守安装,采用 ...
- Win10系统64位快速专业安装版 V2016年
win10系统64位快速专业安装版 V2016年2月 系统下载:http://www.xitongma.com/ Ghost Win10 64位正式装机专业版2016 微软向Windows用户推送了w ...
- 系统妈Ghost Win10 64位快速安装版 V2016年2月
系统妈Ghost win10 64位快速安装版 V2016年2月,更新了最新系统补丁,升级系统版本号为2016年2月份.这款累积更新补丁会取代之前的版本.本系统还附带最常用的装机必备软件.QQ等. 系 ...
- 同步 Github fork 分支
/**************************************************************************** * 同步 Github fork 分支 * ...
- weblogic快速安装版的安装和使用
weblogic 12c提供了一个225MB大小的zip包, 我们下载下来之后解压后, 到jdk的bin目录下面, 执行java -jar ORACLE_HOME=[webloigc安装jar包绝对路 ...
- 从本地向 Github 上传项目步骤攻略(快速上手版)
最近想把之前自己做的一些好玩的项目共享到Github,网上找了一圈上传教程,都感觉写的太深奥.复杂,云里雾里,特把自己的方法纪录如下: PS:这种方式一般适用于:开始做项目时,没有直接在github上 ...
- 利用GitHub Pages + jekyll快速搭建个人博客
前言 想搭建自己博客很久了(虽然搭了也不见得能产出多频繁). 最初萌生想写自己博客的想法,想象中,是自己一行一行码出来的成品,对众多快速构建+模板式搭建不屑一顾,也是那段时间给闲的,从前后端选型.数据 ...
随机推荐
- Catalyst3560密码破解
1.关机:2.将设备MODE键按住,然后开机,进入switch:switch: flash_initInitializing Flash...flashfs[0]: 7 files, 2 direct ...
- 转专业后补修C语言的一些体会(4)
1.对于文件的打开和关闭操作:首先了解到,C语言将文件分成了两种类型:文本文件和二进制文件.针对这两种文件,各有不同的文件读写方式.在C语言中,文件的操作要借助一个文件指针 即FILE 类型,定义了一 ...
- 模块学习--random
1 随机一个0-1之间float >>> random.random() 0.82544262519395 >>> random.random() 0.114854 ...
- 攻防世界Web进阶-Upload1
进入题目 题目提示上传文件,准备好一句话木马. 发现只能上传图片文件,那么再准备一个图片的一句话木马.上传. 浏览器开代理,使用burpsuite拦截,修改文件后缀名为php,否则无法连接 使用蚁剑连 ...
- 简单描述MySQL常用引擎的特点及MySQL的逻辑架构
目录 表的分类数据库引擎? 首先得说说mysql的逻辑架构,它整体分为3层: 常用引擎: 补充知识点: 表的分类数据库引擎? 引擎是什么? 引擎就是一个系统最核心的部分,比如汽车的发动机,人的心脏 数 ...
- 洛谷P1198 [JSOI2008]最大数(线段树)
题目描述 现在请求你维护一个数列,要求提供以下两种操作: 1. 查询操作. 语法:Q L 功能:查询当前数列中末尾L个数中的最大的数,并输出这个数的值. 限制:LLL不超过当前数列的长度.(L> ...
- Linux命令:ifconfig命令
ifconfig功能:配置网络接口,CentOS7最小化安装不包含此命令,需要安装net-tools包. ifconfig常见的用法: ifconfig :显示所有活动接口的相关信息 ifconfig ...
- Shell Sort(希尔排序)
这个排序算法很厉害,我个人很喜欢这个算法,但算法的时间复杂度难计.算法对增量(这里也称作step(步长))的选择也需要注意,只记得个希尔增量的最坏情况为O(n^2).Hibbard增量的最坏情况为O( ...
- VS2013 ERROR MSB8020
error MSB8020: The build tools for Visual Studio 2013 (Platform Toolset = 'v120') cannot be found. T ...
- redhat 7.6 apache 服务简单安装-01
rpm -qa | grep httpd //该命令查看apache是否安装,下面图片是已安装,未安装不会显示任何内容 yum install httpd -y ...