Release engineering: Difference between revisions
No edit summary |
Lightblade (talk | contribs) listify |
||
Line 1: | Line 1: | ||
'''Release engineering''', frequently abbreviated as "releng", is a sub-discipline in [[software engineering]] concerned with the [[compiler|compilation]], assembly, and delivery of [[source code]] into finished products or other software components. An associated term is [[software release life cycle]]. It is often said that release engineering is the difference between software engineering as a manufacture and an industrial process. While it is a non-goal of release engineering to encumber software development with a process overlay, it is often seen as a sign of organizational and developmental maturity. Modern release engineering is concerned with several aspects of software production |
'''Release engineering''', frequently abbreviated as "releng", is a sub-discipline in [[software engineering]] concerned with the [[compiler|compilation]], assembly, and delivery of [[source code]] into finished products or other software components. An associated term is [[software release life cycle]]. It is often said that release engineering is the difference between software engineering as a manufacture and an industrial process. While it is a non-goal of release engineering to encumber software development with a process overlay, it is often seen as a sign of organizational and developmental maturity. |
||
Modern release engineering is concerned with several aspects of software production: |
|||
* Reproducibility: the ability to integrate source, third party components, data, and deployment externals of a software system in order to guarantee operational stability. |
|||
* Consistency: the mission to provide a stable framework for development, deployment, audit and accountability for software components. |
|||
* Agility: the ongoing research into what are the repercussions of modern software engineering practices on the productivity in the software cycle, i.e. continuos integration and push on green initiatives. |
|||
Release engineering is often the integration hub for more complex software developments teams, sitting at the cross between development, product management, quality assurance and other engineering efforts. Release engineering teams are often cast in the role of gatekeepers (i.e. at Facebook, Google, Microsoft) for certain critical products where their judgement forms a parallel line of responsibility and authority in relation to production releases (pushes). |
|||
Frequently, tracking of changes in a [[configuration management]] system or [[revision control]] system is part of the domain of the release engineer. The responsibility for creating and applying a version numbering scheme into software--and tracking that number back to the specific source files to which it applies--often falls onto the release engineer. Producing or improving automation in software production is usually a goal of the release engineer. Gathering, tracking, and supplying all the tools that are required to develop and build a particular piece of software may be a release engineering task, in order to reliably reproduce or maintain software years after its initial release to customers. |
Frequently, tracking of changes in a [[configuration management]] system or [[revision control]] system is part of the domain of the release engineer. The responsibility for creating and applying a version numbering scheme into software--and tracking that number back to the specific source files to which it applies--often falls onto the release engineer. Producing or improving automation in software production is usually a goal of the release engineer. Gathering, tracking, and supplying all the tools that are required to develop and build a particular piece of software may be a release engineering task, in order to reliably reproduce or maintain software years after its initial release to customers. |
Revision as of 23:10, 11 March 2010
Release engineering, frequently abbreviated as "releng", is a sub-discipline in software engineering concerned with the compilation, assembly, and delivery of source code into finished products or other software components. An associated term is software release life cycle. It is often said that release engineering is the difference between software engineering as a manufacture and an industrial process. While it is a non-goal of release engineering to encumber software development with a process overlay, it is often seen as a sign of organizational and developmental maturity.
Modern release engineering is concerned with several aspects of software production:
- Reproducibility: the ability to integrate source, third party components, data, and deployment externals of a software system in order to guarantee operational stability.
- Consistency: the mission to provide a stable framework for development, deployment, audit and accountability for software components.
- Agility: the ongoing research into what are the repercussions of modern software engineering practices on the productivity in the software cycle, i.e. continuos integration and push on green initiatives.
Release engineering is often the integration hub for more complex software developments teams, sitting at the cross between development, product management, quality assurance and other engineering efforts. Release engineering teams are often cast in the role of gatekeepers (i.e. at Facebook, Google, Microsoft) for certain critical products where their judgement forms a parallel line of responsibility and authority in relation to production releases (pushes).
Frequently, tracking of changes in a configuration management system or revision control system is part of the domain of the release engineer. The responsibility for creating and applying a version numbering scheme into software--and tracking that number back to the specific source files to which it applies--often falls onto the release engineer. Producing or improving automation in software production is usually a goal of the release engineer. Gathering, tracking, and supplying all the tools that are required to develop and build a particular piece of software may be a release engineering task, in order to reliably reproduce or maintain software years after its initial release to customers.
While most software engineers, or software developers, do many or all of the above as a course of their work, in larger organizations the specialty of the release engineer can be applied to coordinate disparate source trees, projects, teams, and components. This frees the developers to implement features in the software and also frees the quality assurance engineers to more broadly and deeply test the produced software.
The release engineer may provide software, services, or both to software engineering and software quality assurance teams. The software provided may be build tools, assembly, or other reorganization scripts which take compilation output and place them into a pre-defined tree structure, and even to the authoring and creation of installers for use by test teams or by the ultimate consumer of the software. The services provided may include software build (compilation) automation, automated test integration, results reporting, and production of or preparation for software delivery systems--e.g., in the form of electronic media (CDs, DVDs) or electronic software distribution mechanisms.
Related disciplines
- Build automation
- Porting - Product Line Engineering includes porting of a software product from one platform to other.
- Software configuration management - Although release engineering is sometimes considered part of Software Configuration Management, the latter, being a tool or a process used by the Release Engineer, is actually more of a subset of the roles and responsibilities of the typical Release Engineer.
- Continuous integration
- Change management
- Release Management
- Packaging & Deployment
References
Further reading
- "Software Release Methodology" by Michael E. Bays; ISBN 0-13-636564-7.
- "Software Configuration Management" by H. Ronald Berlack; ISBN 0-471-53049-2.
- "Design of a Methodology to Support Software Release Decisions" by H. Sassenburg; ISBN 90-367-2424-4.