Github提交PullRequest
Github提交PullRequest工作流程:
以Kubernetes为例
1. Fork Kubernetes到自己的Github目录
访问:https://github.com/kubernetes/kubernetes
点击Fork,就可以在自己的Github目录下找到kubernetes这个项目了。
这里以https://github.com/edisonxiang/kubernetes为例。
2. 下载代码到本地工作目录
git clone https://github.com/edisonxiang/kubernetes.git
3. 设置代码的UpStream原始目录
cd kubernetes
git remote add upstream https://github.com/kubernetes/kubernetes.git
# Never push to upstream master
git remote set-url --push upstream no_push
# Confirm that your remotes make sense
git remote -v
4. 在本地获取最新的UpStream版本
cd kubernetes
git fetch upstream
git checkout master
git rebase upstream/master
5. 分支新branch并提交修改(类似OpenStack社区)
cd kubernetes
# Add new branch myfeature
git checkout -b myfeature
# Add Commit Message File
vi .git/message
# Add User Email and User Name
git config --global user.email "xiang.edison@gmail.com"
git config --global user.name "edisonxiang"
# Add or Modify files in kubernetes
......
# 提交到Git本地
git add .
# 完成Commit
添加:git commit -a -F .git/message
修改:git commit --amend -a -F .git/message
修改:git commit -m "Modify some thing"
# 输入Github用户名和密码提交本地的修改到自己的Github项目中
git push -f https://github.com/edisonxiang/kubernetes myfeature
# 更新本地代码到个人仓库
git push origin master
# 删除个人仓库的分支
git push origin :myfeature
# Rebase未合入的PR到个人仓库
git fetch upstream pull/56136/head:BRANCHNAME
# 有时需要将琐碎的多个commit结合起来形成这一个需求的完整commit。
git log 查看下日志,并判断需要将多少个日志合并
git rebase -i HEAD~6 把顶部的六个版本聚到一起进入编辑页面
把需要压缩的日志前面的pick都改为s(squash的缩写)
注意必须保留一个pick,如果将所有的pick都改为了s那就没有合并的载体了就会报如下错误
依次输入CTRL+X Y ENTER三个命令完成编辑。
最后Git Push orgin branchname
# Cancel current local changes
git checkout .
git checkout localfile
6. 访问自己的Github项目创建Pull Request
访问自己的Github地址:https://github.com/edisonxiang/kubernetes
在新上传的Branch上,点击Compare & Pull Request按钮创建一个Pull Requst
最后在https://github.com/kubernetes/kubernetes/pulls就可以找到刚刚提交的Pull Request。
Github提交PullRequest的更多相关文章
- github提交代码时,报permission denied publickey
在像github提交代码时,报permission denied publickey. 查找了一下,可能是因为github的key失效了. 按照以下步骤,重新生成key. ssh-keygen 一路默 ...
- 代码规范、GitHub提交源码的标准 答题人-杨宇杰
1.格式与命名规范1.1 缩进 使用Tab缩进,而不是空格键1.2 换行 每行120字符 if,for,while语句只有单句时,如果该句可能引起阅读混淆,需要用" {"和&quo ...
- 详细介绍如何在win7下首次实现通过Git bash向Github提交项目
详细介绍如何在win7下首次实现通过Git bash向Github提交项目 引自:http://jingpin.jikexueyuan.com/article/35944.html 作者: wddoe ...
- github 提交报403 forbidden的错误解决
github 提交报403 forbidden的错误解决 $ git push error: The requested URL returned error: 403 Forbidden while ...
- 向GitHub 提交你的源代码
之前的这篇文章「Git入门篇」相信大家都已经对 Git 的基本操作熟悉了,但是这篇文章只介绍了对本地 Git 仓库的基本操作,今天我就来介绍下如何跟远程仓库一起协作,教你们向 GitHub 上提交你们 ...
- 使用Android Studio向GitHub提交代码
使用Android Studio向GitHub提交代码 在GitHub上创建一个仓库 填写仓库名称.描述.类型(公有.私有)等信息,点击创建 到此,成功创建了我们的仓库,并且初始化创建了README. ...
- 向Github提交代码时遇到的一些问题
今天分享一下我的一些小经验,那就是向github提交我们的代码.之前一直是直接使用的浏览器完成的代码的下载任务,没有使用过客户端,为了让自己在工作之前熟练使用GitHub,所以就有了下面的这篇博文了. ...
- GitHub 系列之「向GitHub 提交代码」
1.SSH 你拥有了一个 GitHub 账号之后,就可以自由的 clone 或者下载其他项目,也可以创建自己的项目,但是你没法提交代码.仔细想想也知道,肯定不可能随意就能提交代码的,如果随意可以提交代 ...
- Vue.js示例:GitHub提交(watch数据,created钩子,filters过滤); 网格组件(功能:1.检索,2排序);
GitHub提交 codePen: https://codepen.io/chentianwei411/pen/wEVPZo 注意:频繁看案例,可能会被限制. 重点: 表单输入绑定, 单选按钮的使 ...
随机推荐
- 【图解HTTP】第二章 简单的http协议
简单的HTTP协议 针对HTTP协议结构进行讲解,主要使用HTTP/1.1版本. HTTP协议用于客户端和服务器端之间的通信 通过请求和响应的交换达成通信(从客户端开始建立通信,服务器端在没有接收到请 ...
- select,poll,epoll用法
http://blog.csdn.net/sunboy_2050/article/details/6126712 select用法 #include <sys/time.h> ...
- 【小梅哥FPGA进阶教程】MC8051软核在FPGA上的使用
十.MC8051软核在FPGA上的使用 本教程内容力求以详细的步骤和讲解让读者以最快的方式学会 MC8051 IP core 的应用以及相关设计软件的使用,并激起读者对 SOPC 技术的兴趣.本实验重 ...
- android app启动就闪退怎么办?
开发过程中,如遇到android app启动就闪退,不要急,直接进入调试模式运行app,就会取得出错的原因. http://blog.sina.com.cn/s/blog_44fa172f0102wg ...
- Android-ListView-ArrayAdapter
我在上一篇博客中Android-动态添加控件到ScrollView,写到可以用Java动态添加控件到Scrollview的孩子LinearLayout里面去,这种方式是不合理的,因为这种方式是一次性把 ...
- spark 编译命令
mvn -Pyarn -Phadoop-2.4 -Dhadoop.version=2.4.0 -DskipTests clean package
- 使用pycharm专业版创建虚拟环境
Location为工程地址 D:\My_python 第二个Location为 虚拟环境放在这个工程下 Base interpreter:基于那个解释器来创建虚拟环境 Create后进入到目录查看下
- mongodb 连接字符串
mongodb 连接字符串 <!--连接字符串--> <add key="ts.students" value="mongodb://192.168.0 ...
- 【QTP专题】03_Add-in Manager插件
1.什么是Add-in Manager Add-in Manager,故名思议这是一个QTP插件管理器,每次启动前需要选择对应的插件才能进行测试. 打开QTP之后,我们可以看到有如下的一个Add-in ...
- mongodb工具类
pom.xml文件增加Mongodb jar包 <dependency> <groupId>org.mongodb</groupId> <artifactId ...