51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

查看: 6198|回复: 3
打印 上一主题 下一主题

[转贴] 三库(开发库、受控库、静态库)的概念及个人的理解

[复制链接]
  • TA的每日心情
    开心
    2015-2-26 08:31
  • 签到天数: 2 天

    连续签到: 2 天

    [LV.1]测试小兵

    跳转到指定楼层
    1#
    发表于 2009-11-5 16:52:59 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
    三库(开发库、受控库、静态库)的概念及个人的理解
    记得第一次在国内的坛子里看到三库的讨论的时候,登时就晕了……
    三库的概念被弄得挺严重,甚至被实现为物理上的多个库……

    这里,首先贴一下三库定义的原文、翻译,然后再谈谈个人的理解……

    ==原文位置==
    (中国国家标准也有三库的定义。这里就不再给出了。这里给出的是CMMI的定义,若有其它国际上比较权威的定义,烦请熟悉的同志贴一下,谢!)

    CMMI V1.0
    => level 2
    => Configuration Management
    => SG 1 Estabish Baselines
    => SP 1.2 Establish a Configuration Management System
    => Subpractices 2. Store and retrieve configuration items in the configuration management system.

    ==原文==

    Examples of configuration management systems include the following:

    Dynamic (or developer's) systems contain components currently being created or revised.
    They are in the developer's workspace and are controlled by the developer.
    Configuration items in a dynamic system are under version control.

    Master (or controlled) systems contain current baselines and changes to them.
    Configuration items in a master system are under full configuration management as described int ths process area.

    Static systems contain archives of various baselines released for use.
    Static systems are under full configuration management as described in this process area.

    ==翻译==

    (感谢cmmi_cn@163.com等同志对CMMI的翻译工作!)

    CMMI V1.0
    => 第二级
    => 配置管理
    => SG 1 建立基线
    => SP 1.2 建立配置管理系统
    => 子实践 2. 在配置管理系统中存取配置项

    配置管理系统举例如下:

    动态(或开发者)系统,包含当前正在产生或修订的组件。
    它们在开发者的工作区,而且由开发者所控制。
    属于动态系统的配置项,在版本控制之下。

    主(或受控)系统,包含当前的基线和基线的变更。
    属于主要系统的配置项,在本过程域所描述的完全的配置管理之下。

    稳定的系统,包含已分发使用的各种基线的保存档。
    稳定的系统,在本过程域所描述的完全的配置管理之下。


    ==个人理解==

    首先,三库仅仅是举例,在实践中,并不是一定要弄出三个库来。
    其次,三库是逻辑上的概念,在实践中,并不是要对应到物理上的三个库。
    根据定义,开发库可以大致映射为开发工程师的个人工作空间,在开发工程师本机上,个人目录下。当然,对于稍大的任务,也可以映射为存储库里的一个任务分支。
    而受控库,则是开发工程师相互协作、交流最新工作成果的地方。大致上,可以映射为版本控制工具(svn/cvs/cc……)的repository(存储库)。这里,可能有不同的分支/目录做不同的用途,可能会打标签、基线。
    静态库,又称基线库,指的是那些重要的基线,这些基线标志着项目的重要里程碑,或者这些基线被Release(发布)给了“外界”。在比较简单的版本控制工具里,一般可以用特定标签命名规范来把它们从其他标签、基线中区别出来;在SVN中,可以设置一个特别的Tag目录。而在比较复杂的版本控制工具里,也可以用基线/标签的某种属性(质量级别)来表达。例如,当某条基线通过了系统测试后,就把它的质量级别promote(提升)到“通过系统测试”。
    对于静态库,再补充一点:对于这些基线,我们通常不仅要记录源代码,最好也保存一下编译结果/安装包。这样将来用起来会比较方便。编译结果/安装包一般就不要放到版本控制工具里去了,除非你受了商业宣传的蛊惑…… 在合适的机器上建个共享目录,设置合适的权限,来存储编译结果/安装包,一般就可以了。
    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

  • TA的每日心情
    开心
    2015-2-26 08:31
  • 签到天数: 2 天

    连续签到: 2 天

    [LV.1]测试小兵

    2#
     楼主| 发表于 2009-11-5 16:55:23 | 只看该作者
    正在迷惑于三库概念之际,看到此贴,真是开心。说道我心坎里去了,希望大家能发表下建议,看看大家都是如何理解的~
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    3#
    发表于 2009-11-6 14:21:53 | 只看该作者
    晕,太理论了,受不了
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    4#
    发表于 2009-11-10 17:46:09 | 只看该作者
    感觉自己的理解跟楼主的个人理解差不多。
    在vss里我是这样理解的:
    开发库就是开发人员签出的本地工作目录;
    受控库就是签入提交到vss上;
    静态库就是我在vss上项目级打的标签,必要时可以从历史中获取label所在的版本横切面
    回复 支持 反对

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-4-25 07:55 , Processed in 0.073737 second(s), 27 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表