文档章节

看完给跪了:技术大牛总结的Github与华为软件开发云完整对比

 透明的鱼
发布于 2017/08/09 13:51
字数 2022
阅读 34
收藏 0

华为软件开发云配置管理 服务和Github是国内外比较有代表性的代码托管平台,它们以git作为版本管理工具,使项目中身处各地的人员可以协同工作,主要操作涉及仓库、分支、提交、pull request等知识。本文将讲述它们的操作和区别。

Github介绍

一.注册

填写个人资料,邮箱激活。

二.仓库

1.仓库类型

私有仓库:每月缴纳7美元,后期可以随时调整成其它免费的公共仓。

公有仓库:免费,所有人可见。

2.新建仓库

一个仓库通常用于单个工程,仓库可以包含文件夹,文件,图片,视频,表格等任何项目所需资料。Github在新建项目时可以选择同时创建README文件或license文件。

(1)在网页的右上角,点击头像旁边的加号,选择“New repository”。

(2)给仓库命名为“hello word”

(3)可以写一个简短的项目描述

(4)选择“Initialize this repository with a README”

(5)点击“Create repository”

优点:

a)创建时可以选择gitignore类型,因为在工程编译过程中,会生成一些中间文件,或者项目中的一些文件是不需要进行版本管理的,这些文件对Github来讲是透明的,若gitignore选择了C项目,.lib .so .exe等都被忽略了。

b)Settings中可以对仓库重新命名

三.分支

分支是在同一仓库不同版本上工作的方法。仓库默认有一个master分支,一般用作生产环境。当从master分支新建一个分支,意味着在这个时间点对master分支做了一个拷贝或者说快照,其他人对master分支做的改动不会影响到新分支。

在Github上,开发者,设计者使用多个分支去修正bug和需求开发,验证OK后,最后合并到master生产分支。

1.新建分支

(1)进入仓库

(2)单击文件列表顶部的下拉框“branch: master”

(3)在文本框中敲入新分支名字feature

(4)选择“Create branch”或者直接回车

2.在线编辑

每个提交都有关联的提交信息,用来解释为什么要做这样一个修改。提交信息记录的这些历史,可以使其他开发人员了解这次提交做了什么和为什么要这样做。

(1)点击README.md文件。

(2)点击要编辑文件右上角的“铅笔”图标

(3)在编辑器中,随便写点什么

(4)写点提交信息描述你的更改

(5)点击“Commit changes”按钮

优点:

a)Preview changes可以边修改边查看差异

3.pull request申请

pull request是github协作的核心,可以申请一个pull request,请求别人review自己的修改。Pull request会显示两个分支内容的不同,这些变更,增加和删除的行数会用绿色和红色显示出来。不但在提交代码后可以申请一个pull request,甚至可以在代码完成前提出,讨论代码如何修改。

(1)点击顶部的pull request项,然后在点击绿色的“New pull request”按钮。

(2)选择你修改的base分支feature和原始分支master进行比较。

(3)在对比页面,仔细检查这些差异,确保是要提交的内容。

(4)确认OK之后,点击绿色的“Create Pull Request”按钮。

(5)给pull request写上题目和简短的描述

优点:

a)可以在pull request消息中使用github的“@”功能,请求特定的人或者小组反馈信息,无论他们在哪里都可以收到。

4.合并pull request

最后这一步,就是在feature分支上的修改合并到master分支

(1)点击绿色的“Merge pull request”按钮将修改合并到master分支

(2)点击“Confirm merge”

(3)点击pull request成功提示右边的“Delete Branch”

优点:

a)merge有三种方法

b)可以在线修改冲突

c)合并后删除的branch可以修复

四.github工作流

Github工作流是轻量级的,只有一个长期master分支的工作流。

来个图表显示:

·Master分支

·一个新的feature分支(因为我们要在这个分支上做特性开发)

·Feature合并到master之前的轨迹如下

1.创建一个分支

在做一个项目时,可能会在某个特定的时间有一大堆特性或想法——有已经准备好开始干的,有没想好的。分支的存在就是来帮助管理这些工作流。

创建好一个分支以后,就可以随意按照自己的想法来修改,因为这个分支不会影响主分支,可以随意提交修改测试,直到做好验证才合入主分支。

分支是Git的核心概念,整个Github工作流都是基于它的,一条原则就是:主分支的任何东西都是可部署的。因此,在开发某个需求或者解决某个bug的时候,必须是从主分支拉取的分支,并且分支名是描述性的,以便其他人知道你在干什么。

2.做提交

提交可以让别人清晰的看到分支的修改和为什么这么改,每次提交也都需要有提交信息。此外,每次提交应该是一个独立的单元,这样,可以在发现问题或者方案改变时进行回滚。

3.提一个pull request

提一个pull request开始对提交修改进行讨论,大家都能清晰的看到接受这次请求之后有哪些修改将被合并。

如果工作陷入了困境,即使没有代码也可以提一个pull request,放一些截图或者想法,让大家给一些建议。

Pull request方式对开源代码的合并是非常有意义的,它可以让代码在合入master分支前有一个充分的review

4.讨论和review代码

一旦pull request被提出,reviewer将提出问题或者给出评语,比如:编码风格和项目风格不一致,缺少单元测试等等,pull request设计的初衷就是鼓励这些交流。

5.部署

当pull request通过review和测试,就可以部署到生产环境中。如果分支引起了问题,可以通过重新部署master分支到生产环境来回滚版本。

6.合并

现在,提交已经在生产环境上验证过了,可以合入master分支了。

华为软件开发云配置管理服务VSgithub

1.收费标准

Github私仓每月缴纳7美元。

华为软件开发云 配置管理服务5人以下,500M仓库免费。存储空间收费标准为0.000442(元/GB/小时),一个月1G代码约0.318元。

2.页面友好度

Github需要在Your profile中查看仓库,各项操作堆叠在一个页面。

华为软件开发云配置管理服务,左侧分类显示内容,主页选项清晰。

3.工具集成

Github仅仅是一个代码托管平台。

华为软件开发云配置管理服务是这个Devops平台其中的一项服务,既可以作为代码托管平台单独使用,又可以作为整个研发工具链的一部分来使用,所有数据在工具间拉通,平台代码可以直接构建、部署,看到产品效果。

4.使用群体

Github历史悠久,在开源社区广受环境,个人使用者较多。

华为软件开发云 配置管理服务拥有更多的企业用户,企业使用这个平台用于整个研发周期。目前,个人使用者由于其指导详细,中文页面的优点,使用数量也在呈增长趋势。

© 著作权归作者所有

共有 人打赏支持
粉丝 0
博文 72
码字总数 113797
作品 0
私信 提问
一站式云端创新平台:华为云软件开发云

  【IT168 评论】企业数字化转型,软件正扮演着重要角色。有预测数据显示,2020年中国软件及信息服务产业规模将达到8万亿人民币。软件能力正成为一个国家、城市、企业最核心的竞争力之一。...

it168网站
2017/11/24
0
0
上线一周年 华为云软件开发云为何如此受欢迎?

软件开发云之于软件工程,就如同机床之于制造业。华为云软件开发云正在努力成为软件业的“工作母机”。 去年12月,华为云在大连正式上线发布了软件开发云平台(DevCloud),平台刚一上线就受到...

m59ht9d0j
2017/11/29
0
0
【极客人生】华为全联接大会之前,我在电话中跟恒少聊了聊……

点击上方“程序人生”,选择“置顶公众号” 第一时间关注程序猿(媛)身边的故事 通常,我们眼中的软件开发是这个样子的…… 工作高端、大气、上档次,这是一件化腐朽为神奇的事儿,更是一股...

CSDN程序人生
09/11
0
0
华为开发云、当当网,加入 Skywalking 生态系统

Skywalking作为国内最活跃的分布式追踪和APM开源软件,随着功能的逐步强大,Skywalking社区也在越来越开放,生态体系正在逐步完善。10月OpenSkywalking组织的成立,转向Apache 2.0开源协议,...

wu-sheng
2017/10/19
3K
9
嗨翻,华为云社区年度盛典嘉年华火热进行中!十大分会场,抢万元豪礼!

2018年伊始,由华为云社区与华为云十大产品联合策划的“云启2018——华为云社区年度盛典嘉年华”活动,火热拉开了新年序幕,吸引了不少关注。 华为云社区作为华为云官方技术交流社区,依托博...

宋庆离
01/23
1K
0

没有更多内容

加载失败,请刷新页面

加载更多

新手也能看懂,消息队列其实很简单

该文已加入开源项目:JavaGuide(一份涵盖大部分Java程序员所需要掌握的核心知识的文档类项目,Star 数接近 16k)。地址:https://github.com/Snailclimb/JavaGuide. 本文内容思维导图: 消息...

阿里云官方博客
13分钟前
0
0
如何在Chrome浏览器中启动deviceready事件(尝试调试phonegap项目)?

我正在开发PhoneGap应用程序,我希望能够在Chrome中调试它,而不是在电话上调试。但是,我在onGetReady()函数中初始化我的代码,该函数在PhoneGap触发“deviceready”事件时触发。由于Chr...

kisshua
今天
9
0
nginx中部署vue打包后的静态文件

如何在nginx中部署静态资源就不描述了, 请看我的这篇博客 将vue脚手架项目打包后的静态文件放到nginx上, 发现有个问题, 即url上有#, 怎么去掉这个#呢. 1 项目中router的mode 路由的mode要为h...

克虏伯
今天
13
0
JS容易理解错误的地方

在这端代码执行的末尾,你会不会hi变量回事函数中的hi了?你会不会认为这不是按引用传递了? 对值传递和引用传递产生质疑了? 1 var hi = {};2 function sayHello(hi) { ...

器石_
今天
9
0
Java开发学习--MongoDB

之前只学过sql,第一次使用非关系型数据库。以前对于关系型数据库与非关系型数据库的概念很模糊,通过这次的学习对这两者有了一个清晰的概念。 主键 在MongoDB中,主键名叫"_id",如果在生成...

微笑向暖wx
今天
6
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部