引自 http://en.wikipedia.org/wiki/Software_release_life_cycle
Pre-alpha[edit]
Pre-alpha refers to all activities performed during the software project before testing. These activities can include requirements analysis,software design, software development, and unit testing. In typical open source development, there are several types of pre-alpha versions.Milestone versions include specific sets of functions and are released as soon as the functionality is complete.
Alpha[edit]
The alpha phase of the release life cycle is the first phase to begin software testing (alpha is the first letter of the Greek alphabet, used as the number 1). In this phase, developers generally test the software using white box techniques. Additional validation is then performed usingblack box or gray box techniques, by another testing team. Moving to black box testing inside the organization is known as alpha release.[2]
Alpha software can be unstable and could cause crashes or data loss. External availability of alpha software is uncommon in proprietary software. However, open source software, in particular, often have publicly available alpha versions, often distributed as the raw source codeof the software. The alpha phase usually ends with a feature freeze, indicating that no more features will be added to the software. At this time, the software is said to be feature complete.
Beta[edit]
Beta, named after the second letter of the Greek alphabet, is the software development phase following alpha. It generally begins when the software is feature complete. Software in the beta phase will generally have many more bugs in it than completed software, as well as speed/performance issues and may still cause crashes or data loss. The focus of beta testing is reducing impacts to users, often incorporating usability testing. The process of delivering a beta version to the users is called beta release and this is typically the first time that the software is available outside of the organization that developed it.
The users of a beta version are called beta testers. They are usually customers or prospective customers of the organization that develops the software, willing to test the software without charge, often receiving the final software free of charge or for a reduced price. Beta version software is often useful for demonstrations and previews within an organization and to prospective customers. Some developers refer to this stage as a preview, prototype, technical preview (TP), or early access. Some software is kept in perpetual beta—where new features and functionality are continually added to the software without establishing a firm "final" release.
Open and closed beta[edit]
Developers release either a closed beta or an open beta; closed beta versions are released to a restricted group of individuals for a user test by invitation, while open beta testers are from a larger group, or anyone interested. The testers report any bugs that they find, and sometimes suggest additional features they think should be available in the final version. Examples of a major public beta test are:
- In September 2000 a boxed version of Apple's Mac OS X Public Beta operating system was released.[3]
- Microsoft's release of community technology previews (CTPs) for Windows Vista in January 2005.[4]
Open betas serve the dual purpose of demonstrating a product to potential consumers, and testing among an extremely wide user base likely to bring to light obscure errors that a much smaller testing team might not find.
Impact of the World Wide Web[edit]
As the Internet has facilitated rapid and inexpensive distribution of software, companies have begun to take a looser approach to use of the word "beta".[5] In February 2005 ZDNet published an article about the recent phenomenon of a beta version often staying for years and being used as if it were in production level, disparagingly called "perpetual beta". It noted that Gmail and Google News, for example, had been in beta for a long period of time and were not expected to drop the beta status despite the fact that they were widely used; however, Google News did leave beta in January 2006, followed by Google Apps, including Gmail, in July 2009.[6] This technique may allow a developer to delay offering full support and responsibility for remaining issues. In the context of Web 2.0, people even talk of perpetual betas to signify that some software is meant to stay in beta state. Also, "beta" is sometimes used to indicate something more like a release candidate, or as a form of time-limited demo, or marketing technique .[7]
Release candidate[edit]
A release candidate (RC) is a beta version with potential to be a final product, which is ready to release unless significant bugs emerge. In this stage of product stabilization, all product features have been designed, coded and tested through one or more beta cycles with no known showstopper-class bug. A release is called code complete when the development team agrees that no entirely new source code will be added to this release. There could still be source code changes to fix defects, changes to documentation and data files, and peripheral code for test cases or utilities. Beta testers, if privately selected, will often be credited for using the release candidate as though it were a finished product. Beta testing is conducted in a client's or customer's location and to test the software from a user's perspective.
Release[edit]
Release to manufacturing (RTM)[edit]
The term "release to manufacturing", also known as "going gold", is a term used when a software product is ready to be delivered or provided to the customer. This build may be digitally signed, allowing the end user to verify the integrity and authenticity of the software purchase. A copy of the RTM build known as the "gold master" or GM is sent for mass duplication. RTM precedes general availability (GA), when the product is released to the public.
It is typically used in certain retail mass-production software contexts—as opposed to a specialized software production or project in a commercial or government production and distribution—where the software is sold as part of a bundle in a related computer hardware sale and typically where the software and related hardware is ultimately to be available and sold on mass/public basis at retail stores to indicate that the software has met a defined quality level and is ready for mass retail distribution. RTM could also mean in other contexts that the software has been delivered or released to a client or customer for installation or distribution to the related hardware end user computers or machines. The term does not define the delivery mechanism or volume; it only states that the quality is sufficient for mass distribution. The deliverable from the engineering organization is frequently in the form of a golden master media used for duplication or to produce the image for the web.
General availability (GA)[edit]
General availability (GA) is the marketing stage at which all necessary commercialization activities have been completed and a software product is available for purchase, depending, however, on language, region, electronic vs. media availability.[8] Commercialization activities could include security and compliance tests, as well as localization and world wide availability. The time between RTM and GA can be from a week to months in some cases before a generally available release can be declared because of the time needed to complete all commercialization activities required by GA. At this stage, the software has "gone live".
Release to web[edit]
Release to web (RTW) or web release is a means of software delivery that utilizes the Internet for distribution. No physical media are produced in this type of release mechanism by the manufacturer. Web releases are becoming more common as Internet usage grows.
相关推荐
这是软件生命周期中的最终阶段,也是用户可以直接购买和使用的版本。 **特点:** - **正式发布:** 软件已经完成了所有必要的测试和调整,达到了可以商业发布的标准。 - **用户支持:** 提供完整的用户手册和技术...
这些标记不仅有助于开发者内部管理软件生命周期,同时也为外部用户提供了一个清晰的版本成熟度指示。下面将详细介绍这三个标记的含义、使用场景及它们在软件开发中的作用。 ### Alpha 版本 Alpha 版本,简称 α ...
在IT行业中,软件的开发和发布过程涉及到多个不同...了解这些版本类型有助于用户和开发者更好地理解和管理软件的生命周期,确保软件的质量和稳定性。在选择和使用软件时,根据自己的需求和条件选择相应的版本至关重要。
了解这些版本的分类及其在软件开发生命周期中的作用,对于软件开发者、项目经理乃至终端用户来说,都至关重要。本文将深入探讨软件从开发到发布的各阶段版本,帮助读者全面理解软件开发的完整流程。 ### 1. 概念...
GA(General Availability)是软件生命周期中的一个阶段,表示该软件已经经过了Beta测试阶段,达到了正式发布的要求,可以供广大用户使用。MyEclipse 7.0 GA版是MyEclipse的一个重要版本,相较于之前的版本,7.0 GA...
GA(General Availability)是软件生命周期中的一个阶段,表示该版本已经稳定发布,可供用户广泛使用。相比于之前的Beta版或RC版,GA版具有更高的稳定性与兼容性,适用于生产环境下的开发工作。 #### 三、注册码...
- **API 生命周期**:Kubernetes 通过 API 生命周期管理策略来控制新特性的引入和移除。新 API 版本首先作为 Alpha 特性,然后升级为 Beta 版本,最后成为 GA 版本。在升级过程中,社区会收集反馈并进行调整,以...
IPD(Integrated Product Development,集成产品开发)是一种集成的产品开发方法,它将产品开发的各个阶段贯穿整个生命周期,确保产品从概念到发布的整个过程都被关注和跟踪。以下是IPD主流程框架的详细知识点: 一...
- **实体监听器**:这个版本引入了实体监听器,允许用户在特定的生命周期事件(如加载、保存、更新和删除)上注册回调方法,增强了业务逻辑的灵活性。 - **更好的元数据API**:为了解析和处理实体的元数据,4.1.8....
本文将介绍如何使用 Docker 容器技术来建立起一个多节点 Fabric 集群,并且描述在集群上如何进行基本的操作,如 chaincode 的生命周期维护等。文中采用 Fabric 1.0 beta 的端到端(e2e_cli)示例作为基础来说明原理...
#### 五、支持状态与生命周期 - **V5.3 或 V5.3.1 用户**:建议所有使用 V5.3 或 V5.3.1 的用户考虑升级到 V6。 - **V5.2 支持情况**:V5.2 的支持已于 2004 年初停止。 - **V5.3 分布式支持结束日期**:标记为...
- **API 稳定性合约**:Kubernetes 社区设定了 API 稳定性合约,确保 API 特性的生命周期管理。例如,一旦 API 进入 GA 阶段,就不能随意移除或更改,只能添加非破坏性的新功能。 - **API 注解(Annotations)和...
2. **spring-context-4.3.2.RELEASE.jar**:这是Spring框架的核心组件之一,提供了上下文相关的功能,如bean的生命周期管理、依赖注入、事件传播以及国际化支持。它扩展了`spring-core`,增加了对应用上下文和XML...
Spring的IoC容器管理对象的生命周期,而Spring MVC是Spring提供的Web MVC框架,可以与Struts2协同工作。 3. **Hibernate3**: Hibernate是一个流行的Java ORM(对象关系映射)工具,用于简化数据库操作。它允许...
- **POM 文件**: 在项目根目录下创建 `pom.xml` 文件,用于管理依赖关系、构建生命周期等。 ```xml xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation=...