Top Qs
Timeline
Chat
Perspective
Continuous deployment
Software-engineering approach From Wikipedia, the free encyclopedia
Remove ads
Continuous deployment (CD) is a software engineering approach in which software functionalities are delivered frequently and through automated deployments.[1][2][3]
Continuous deployment contrasts with continuous delivery (also abbreviated CD), a similar approach in which software functionalities are also frequently delivered and deemed to be potentially capable of being deployed, but are actually not deployed.[4] As such, continuous deployment can be viewed as a more complete form of automation than continuous delivery.[5]
Continuous deployment has been adopted by software companies such as Meta, Microsoft, Atlassian, IBM, Adobe, and Tesla.[6]
Remove ads
Principles

Continuous deployment extends the principles of continuous integration and delivery by including fully automated production deployment without the need for manual approval, instead relying on rigorous automated testing.[7] Reviews may still take place in the form developer-developer code reviews, but the need for intermediary reviewers such as a change-advisory board is minimized.[8]
Because code changes are deployed automatically, continuous deployment requires a much higher standard of automated testing, as test quality determines the reliability of releases.[9] Without this, the risk of introducing production failures outweighs the benefits of deployment automation.
In addition, continuous deployment emphasizes small incremental changes and dark launches through the use of feature toggles. Developers can deploy code into production months before a public release by gradually adding functionality in small chunks, verifying stability, and then enabling the feature for users when it is considered ready.[10][9]
Remove ads
Motivation
Release speed
Continuous deployment removes the need to wait for releases, as once a change passes internal testing it is automatically deployed to production.[11] This allows for shorter time-to-market and more frequent releases[12], which in turn increases customer satisfaction and provides companies with more marketing opportunities.[13]
Faster bug detection
A major motivation for continuous deployment is that deploying software into the field more often makes it easier to find, catch, and fix bugs.[14] Deploying small, incremental changes makes it easier to trace the origin of bugs, since issues will be isolated to a recent and relatively small code change.[15][13]
Customer experience and involvement
Under this methodology, new software features can be released to customers more quickly and frequently after their development, accelerating the delivery of value to customers and enhancing customer satisfaction. Teams can begin to collect customer feedback almost immediately, driving rapid innovation of relevant features.[13][12]
Remove ads
Challenges
Continuous delivery requires a significant investment in adequate test coverage, real-time monitoring, and strong continuous integration pipelines to prevent bugs from reaching production.[16][17][18][19] Customers may also find software that is constantly changing creates a learning curve which can negatively affect their experience.[19]
Moving to continuous delivery is also a culture shift for developers who are accustomed to traditional release cycles, often requiring a proven DevOps process[20]. Adopting this process requires collaboration among multiple stakeholders, including development teams, leadership, operations, and quality assurance. A 2007 study recorded one company manager's reaction to continuous delivery: "When the release team and I confronted the developers with our new process - releasing a story as soon as it is signed off - it scared the hell out of them."[21]
Example
In an environment in which data-centric microservices provide the functionality, and where the microservices can have multiple instances, continuous deployment consists of instantiating the new version of a microservice and retiring the old version once it has drained all the requests in flight.[22][23][24]
See also
- CI/CD, the combined practices of either (more often) continuous integration and continuous delivery, or (less often) continuous integration and continuous deployment
- Canary release
- Blue–green deployment
References
Wikiwand - on
Seamless Wikipedia browsing. On steroids.
Remove ads