概述

这是产品研发管理系列文章的第二篇:使用SubVersion进行代码管理。

介绍如何使用SubVersion的资料已经许多,这里不准备介绍如何使用SubVersion。

这篇文章主要介绍如何进行代码版本号管理。

使用SubVersion进行代码管理

  • 时间区间(1)

    • (1)的起始时间是3.0开发的開始。
    • 在(1)期间。没有不论什么用户使用3.0(由于它还没有公布)。所以全部开发者直接在3.0Trunk上开发。
    • (1)的结束时间是3.0开发的结束时间。结束时公布3.0产品,在SVN上创建3.0 Tag。同一时候创建3.1 F000 Branch。这时3.0 Trunk自己主动变成3.1 Trunk。

  • 时间区间(2)
    • (2)的起始时间是3.1开发的開始。
    • 在(2)期间,由于開始实用户安装使用3.0,所以3.1全部开发者的开发工作在3.1 F000 Branch上进行。
    • 假设在(2)期间,用户报告3.0的Bug。而且须要立即修复。那么:
      • 在3.1 Trunk上对问题进行修复,而且公布补丁包。

      • 将此修改合并到3.1 F000 Branch上。

    • (2)的结束时间是3.1 F000开发的结束时间。

      结束时公布3.1 F000产品。此时做下面事情:

      • 合并代码之前,在3.1 Trunk上建立Tag。如:3.0 20150601。用来表示将3.1 F000合并进来之前的代码。
      • 将3.1 F000 Branch的代码合并到3.1 Trunk上。而且锁定3.1 F000代码避免不论什么进一步的修改。

      • 从3.1 Trunk上创建3.1 M010 Branch。用于进行3.1 M010的开发。
  • 时间区间(3)。(4),(5)和(6)
    • 基本和时间区间(2)一样。

    • (5)是3.2的開始。

注:

1. (5)是3.2的開始。它和(3),(4)的操作方式没有根本的差别,但有些细小的区分,主要是安排不同类型的修改。

一般我们把相对大的功能/修改放到一个新的版本号里边。(3)和(4)作为(2)的升级,主要负责修复3.1的Bug和小功能的改进。把相对大一点的功能或者相对底层的修改放在3.2里边,也就是(5)里边。

2. 究竟有多少个M0X0,由产品经理依据用户反馈的问题和待开发的需求列表决定。

3. 在一个迭代周期開始前,需求都搜集到位。我们使用的迭代周期是2个月。包含需求讨论、设计开发、測试。

注意事项

依据我们使用下来的情况。有下面注意事项:

  • 假设修复Bug。能够在Trunk或者Branch上做,可是一定要使用SubVersion的合并功能,而不是在Trunk和Branch上分别改两遍。假设改两遍。造成的结果是在要将Branch合并到Trunk上出现冲突。
  • 不是不论什么时候都适合进行不论什么类型的修改。

    比方有些核心数据结构的变动,将它放在小版本号升级后的第一个迭代进行。这样的大的修改得找时机,避免对用户造成升级困难。或者用户须要又一次装载全部数据。

  • 在迭代开发结束是在Branch上做公布的;可是维护是将Branch的代码合并到Trunk后,在Trunk上维护。合并代码的时候须要很小心。保证Branch上的代码和合并以后Trunk的代码一样很关键。假设不一样会造成这样的情况:第一个从Branch上公布的产品没有问题;后来为了修复一个Bug,从Trunk上公布一个补丁包后。出现了第一个公布没有出现的问题。

$(function () {
$('pre.prettyprint code').each(function () {
var lines = $(this).text().split('\n').length;
var $numbering = $('

    ').addClass('pre-numbering').hide();
    $(this).addClass('has-numbering').parent().append($numbering);
    for (i = 1; i ').text(i));
    };
    $numbering.fadeIn(1700);
    });
    });

产品研发管理(二):使用SubVersion进行代码管理的更多相关文章

  1. redmine一键安装(项目管理、Bug管理、任务跟踪、代码管理、日报等等)

    1,下载一键安装包(64位系统) https://bitnami.com/stack/redmine 2,帮助文档(安装引导) http://www.360doc.com/content/15/033 ...

  2. svn(subversion)代码管理

    想必大家现在都比较喜欢使用svn(subversion)完成代码管理了,因为它的开源,轻巧,易用.但是这样一个宝贝如果不知道其正确的用法,也会让我们百思不得其解,甚至耽误项目进度,浪费程序员的心血和结 ...

  3. 小团队产品研发管理V0.0.1

    序言 之前做研发的时候非常鄙视管理,觉得管理的那些人就知道搞政治,后来做了开发主管,以及到部门经理之后,管的人多了发现管理真是门大学问,真的应该每个人都要学习一些基本管理知识,特别是刚入社会的打工人. ...

  4. 代码管理工具 --- git的学习笔记二《git的工作原理》

    通过几个问题来学习代码管理工具之git 一.git是什么?为什么要用它?使用它的好处?它与svn的区别,在Mac上,比较好用的git图形界面客户端有 git 是分布式的代码管理工具,使用它是因为,它便 ...

  5. 使用Subversion进行源代码管理(二):创建和发布版本库[转]

    原文出处: http://www.blogjava.net/youxia/archive/2007/10/23/155372.html 我的上一篇随笔讲了怎么使用Subversion客户端去连接服务器 ...

  6. Python核心技术与实战——二一|巧用上下文管理器和with语句精简代码

    我们在Python中对于with的语句应该是不陌生的,特别是在文件的输入输出操作中,那在具体的使用过程中,是有什么引伸的含义呢?与之密切相关的上下文管理器(context manager)又是什么呢? ...

  7. 产品研发团队如何融合OKR与Scrum敏捷开发?

    「 OKR 」现在非常的火爆,很多公司都在使用,不仅国外的 Google.英特尔等大公司在用,国内的一线知名互联网企业今日头条和一些创业团队也都在使用. 那为什么「 OKR 」这么受欢迎呢,因为把它可 ...

  8. IOS-源代码管理工具(SVN)

    一.使用环境 要想利用SVN管理源代码,必须得有2套环境 服务器 用于存储客户端上传的源代码 可以在Windows上安装Visual SVN Server 大部分情况下,公司的开发人员不必亲自搭建SV ...

  9. 代码管理工具 Git

    之前一直使用微软的代码管理工具TFS(Team Foundation Server)..NET CORE 2.0的发布后,考虑到.NET CORE项目可以跨平台,准备把项目迁移到.NET CORE 环 ...

随机推荐

  1. JavaScript系列----事件机制

    1.事件流 1.1.标准事件流 所谓的标准事件流指的的:EMCAScript标准规定事件流包含三个阶段,分别为事件捕获阶段,处于目标阶段,事件冒泡阶段. 下面是一段html代码,根据代码来说明标准事件 ...

  2. 动态创建 script 实现跨域请求数据

    动态创建script标签 (由事件触发) 在我们需要请求数据的时候我们就可以动态的创建 script 标签 src设置为我们需要请求数据的地址 另外我们可以附加参数 ?后面附加参数 例如 :?参数=1 ...

  3. maven学习之二

    三 profile介绍 可以有多个地方定义profile.定义的地方不同,它的作用范围也不同. (1)    针对于特定项目的profile配置我们可以定义在该项目的pom.xml中. (2)     ...

  4. 【手记】让Fiddler抓取入站请求,或者叫用Fiddler做反向代理

    注意:本文不涉及HTTPS的场景 最近在弄公众号开发,除了主动去调公众号接口,还存在公众号后台要反过来调你的情形,攻受转换一线间.对于回调的情况,想要知道对方是怎样来请求的很有必要.此前经常用Fidd ...

  5. Nginx 搭建图片服务器

    Nginx 搭建图片服务器 本章内容通过Nginx 和 FTP 搭建图片服务器.在学习本章内容前,请确保您的Linux 系统已经安装了Nginx和Vsftpd. Nginx 安装:http://www ...

  6. [最短路]P1119 灾后重建

    题目背景 B地区在地震过后,所有村庄都造成了一定的损毁,而这场地震却没对公路造成什么影响.但是在村庄重建好之前,所有与未重建完成的村庄的公路均无法通车.换句话说,只有连接着两个重建完成的村庄的公路才能 ...

  7. AIO5销售发货单numeric算数溢出报错:将numeric转换成数据类型numeric时出现算数溢出错误

    问题描述: 销售发货单报错算数溢出:将numeric转换成数据类型numeric时出现算数溢出错误.具体如下图: 当销售发货单的数量为>7万时,报错 当销售发货单的数量为<7万时,单据正常 ...

  8. jq获取被选中的option的值。jq获取被选中的单选按钮radio的值。

    温故而知新,一起复习下jq的知识点. (1) jq获取被选中的option的值 <select id="select_id"> <option value=&qu ...

  9. Spring框架——AOP代理

    我们知道AOP代理指的就是设计模式中的代理模式.一种是静态代理,高效,但是代码量偏大:另一种就是动态代理,动态代理又分为SDK下的动态代理,还有CGLIB的动态代理.Spring AOP说是实现了AO ...

  10. 4. 跟踪标记 (Trace Flag) 610 对索引组织表(IOT)最小化日志

    跟踪标记:610 功能: 用批量导入操作(Bulk Import Operations)加载数据时,对于索引组织表(即有聚集索引的表) 最小化日志: 上图为simple/bulk-logged恢复模式 ...