Misplaced Pages

Continuous delivery: Difference between revisions

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
Browse history interactively← Previous editContent deleted Content addedVisualWikitext
Revision as of 17:41, 25 September 2024 editNaruyoko (talk | contribs)496 edits See also: Remove non-internal linksTag: Visual edit← Previous edit Latest revision as of 06:48, 4 December 2024 edit undoAzarboon (talk | contribs)Extended confirmed users517 edits PrinciplesTag: Visual edit 
(3 intermediate revisions by 2 users not shown)
Line 5: Line 5:


== Principles == == Principles ==
According to Neal Ford, continuous delivery adopts "Bring the pain forward," tackling tough tasks early, fostering automation and swift issue detection. <ref name=":0">{{Cite book |title=Building Evolutionary Architectures: Automated Software Governance |isbn=978-1492097549}}</ref>

Continuous delivery treats the commonplace notion of a ''deployment pipeline''<ref>{{Cite book |doi = 10.1109/AGILE.2006.53|chapter = The Deployment Production Line|title = Agile 2006 (Agile'06)|pages = 113–118|year = 2006|last1 = Humble|first1 = J.|last2 = Read|first2 = C.|last3 = North|first3 = D.|isbn = 0-7695-2562-8|s2cid = 16572138}}</ref> as a ] ]:<ref>{{cite conference |url=http://staff.lero.ie/stol/files/2014/03/rcose2014_fitzgerald.pdf |title=Continuous Software Engineering and Beyond: Trends and Challenges |first=Brian |last=Fitzgerald |date=2014-06-03 |conference=1st International Workshop on Rapid Continuous Software Engineering |conference-url=http://continuous-se.org/ |publisher=Association for Computing Machinery |location=New York, NY |pages=1–9 |isbn=978-1-4503-2856-2 |doi=10.1145/2593812.2593813 |access-date=2014-10-24 |archive-url=https://web.archive.org/web/20141025021033/http://staff.lero.ie/stol/files/2014/03/rcose2014_fitzgerald.pdf |archive-date=2014-10-25 |url-status=dead |hdl=10344/3896 |hdl-access=free }}</ref> a set of validations through which a piece of software must pass on its way to ]. Code is compiled if necessary and then packaged by a build server every time a change is committed to a ], then tested by a number of different techniques (possibly including manual testing) before it can be marked as releasable. Continuous delivery treats the commonplace notion of a ''deployment pipeline''<ref>{{Cite book |doi = 10.1109/AGILE.2006.53|chapter = The Deployment Production Line|title = Agile 2006 (Agile'06)|pages = 113–118|year = 2006|last1 = Humble|first1 = J.|last2 = Read|first2 = C.|last3 = North|first3 = D.|isbn = 0-7695-2562-8|s2cid = 16572138}}</ref> as a ] ]:<ref>{{cite conference |url=http://staff.lero.ie/stol/files/2014/03/rcose2014_fitzgerald.pdf |title=Continuous Software Engineering and Beyond: Trends and Challenges |first=Brian |last=Fitzgerald |date=2014-06-03 |conference=1st International Workshop on Rapid Continuous Software Engineering |conference-url=http://continuous-se.org/ |publisher=Association for Computing Machinery |location=New York, NY |pages=1–9 |isbn=978-1-4503-2856-2 |doi=10.1145/2593812.2593813 |access-date=2014-10-24 |archive-url=https://web.archive.org/web/20141025021033/http://staff.lero.ie/stol/files/2014/03/rcose2014_fitzgerald.pdf |archive-date=2014-10-25 |url-status=dead |hdl=10344/3896 |hdl-access=free }}</ref> a set of validations through which a piece of software must pass on its way to ]. Code is compiled if necessary and then packaged by a build server every time a change is committed to a ], then tested by a number of different techniques (possibly including manual testing) before it can be marked as releasable.


Line 15: Line 17:
*'''Feedback''' – Team members learn of problems as soon as possible when they occur so that they are able to fix them as quickly as possible. *'''Feedback''' – Team members learn of problems as soon as possible when they occur so that they are able to fix them as quickly as possible.
*'''Continually deploy''' – Through a fully automated process, you can deploy and release any version of the software to any environment. *'''Continually deploy''' – Through a fully automated process, you can deploy and release any version of the software to any environment.


According to Yan Cui, when it comes to ], ephemeral resources should be kept together and have their own deployment pipeline to achieve a high ]. However, shared resources that have a long spin-up time and landing zone should have their own separate ], ] and stack. <ref name=":02">{{Cite book |last=Cui |first=Yan |title=Serverless Architectures on AWS |publisher=Manning |year=2020 |isbn=978-1617295423 |edition=2nd}}</ref>


==Tools/tool types== ==Tools/tool types==
Line 75: Line 80:
| Expert drop || Assign a CD expert to join tough projects as a senior member of the development team. Having the expert on the team helps to build the motivation and momentum to move to CD from inside the team. It also helps to maintain momentum when the migration requires a large effort and a long period of time. | Expert drop || Assign a CD expert to join tough projects as a senior member of the development team. Having the expert on the team helps to build the motivation and momentum to move to CD from inside the team. It also helps to maintain momentum when the migration requires a large effort and a long period of time.
|} |}

== Best practices for cloud systems ==
The following practices can enhance productivity of ], especially in systems hosted in the ]: <ref>{{Cite book |title=Serverless Architectures on AWS |date=29 March 2022 |publisher=Manning |isbn=978-1617295423}}</ref><ref>{{Cite book |title=Pipeline as Code Continuous Delivery with Jenkins, Kubernetes, and Terraform |publisher=Manning |isbn=9781638350378}}</ref><ref>{{Cite book |title=Continuous Delivery Reliable Software Releases Through Build, Test, and Deployment Automation |isbn=9780321670229 |last1=Humble |first1=Jez |last2=Farley |first2=David |date=27 July 2010 |publisher=Pearson Education }}</ref>

* '''Number of Pipelines''': Small teams can be more productive by having one ] and one pipeline. In contrast, larger organizations may have separate repositories and pipelines for each team or even separate repositories and pipelines for each service within a team.
* '''Permissions''': In the context of ] permissions, adhering to the ] can be challenging due to the dynamic nature of ]. Administrators may opt for more permissive permissions while implementing compensating ] to minimize the blast radius.


==Relationship to DevOps== ==Relationship to DevOps==
Line 84: Line 95:
''Continuous deployment'' is a software engineering approach which uses automated software deployments.<ref name="Overcome-challenges">{{Cite journal |doi = 10.1016/j.jss.2017.02.013|title = Continuous Delivery: Overcoming adoption challenges|journal = Journal of Systems and Software|volume = 128|pages = 72–86|year = 2017|last1 = Chen|first1 = Lianping|doi-access = free}}</ref> ''Continuous deployment'' is a software engineering approach which uses automated software deployments.<ref name="Overcome-challenges">{{Cite journal |doi = 10.1016/j.jss.2017.02.013|title = Continuous Delivery: Overcoming adoption challenges|journal = Journal of Systems and Software|volume = 128|pages = 72–86|year = 2017|last1 = Chen|first1 = Lianping|doi-access = free}}</ref>
In it, software is produced in short cycles but through automated ]s even to production rather than requiring a "click of a button" for that last step.{{r|CD_LC|p=52|q=Deployment into production takes just the click of a button}} Therefore, continuous deployment can be considered a more sophisticated form of automation.<ref>{{cite web |url=https://www.ibm.com/cloud/learn/continuous-deployment |title=Continuous Deployment: An Essential Guide |author=<!--Not stated--> |date=2019-10-02 |publisher=] |access-date=2022-11-28 |quote=Continuous deployment is the natural outcome of continuous delivery done well. Eventually, the manual approval delivers little or no value and is merely slowly things down. At that point, it is done away with and continuous delivery becomes continuous deployment.}}</ref> In it, software is produced in short cycles but through automated ]s even to production rather than requiring a "click of a button" for that last step.{{r|CD_LC|p=52|q=Deployment into production takes just the click of a button}} Therefore, continuous deployment can be considered a more sophisticated form of automation.<ref>{{cite web |url=https://www.ibm.com/cloud/learn/continuous-deployment |title=Continuous Deployment: An Essential Guide |author=<!--Not stated--> |date=2019-10-02 |publisher=] |access-date=2022-11-28 |quote=Continuous deployment is the natural outcome of continuous delivery done well. Eventually, the manual approval delivers little or no value and is merely slowly things down. At that point, it is done away with and continuous delivery becomes continuous deployment.}}</ref>
Academic literature differentiates between ''continuous delivery'' and ''continuous deployment'' according to deployment method; manual vs. automated.<ref name="shahin-et-al-2017"/><ref>{{cite book |doi=10.1109/ESEM.2017.18 |isbn=978-1-5090-4039-1 |chapter=Beyond Continuous Delivery: An Empirical Investigation of Continuous Deployment Challenges |title=2017 ACM/IEEE International Symposium on Empirical Software Engineering and Measurement (ESEM) |pages=111–120 |year=2017 |last1=Shahin |first1=Mojtaba |last2=Babar |first2=Muhammad Ali |last3=Zahedi |first3=Mansooreh |last4=Zhu |first4=Liming |s2cid=3479812 }}</ref> Academic literature differentiates between ''continuous delivery'' and ''continuous deployment'' according to deployment method; manual vs. automated.<ref name="shahin-et-al-2017"/><ref>{{cite book |doi=10.1109/ESEM.2017.18 |isbn=978-1-5090-4039-1 |chapter=Beyond Continuous Delivery: An Empirical Investigation of Continuous Deployment Challenges |title=2017 ACM/IEEE International Symposium on Empirical Software Engineering and Measurement (ESEM) |pages=111–120 |year=2017 |last1=Shahin |first1=Mojtaba |last2=Babar |first2=Muhammad Ali |last3=Zahedi |first3=Mansooreh |last4=Zhu |first4=Liming |s2cid=3479812 |url=https://pure.itu.dk/portal/da/publications/0c0a34a9-1711-4305-917e-9718338df017 }}</ref>


==See also== ==See also==

Latest revision as of 06:48, 4 December 2024

Software engineering approach of short cycles
Part of a series on
Software development
Core activities
Paradigms and models
Methodologies and frameworks
Supporting disciplines
Practices
Tools
Standards and bodies of knowledge
Glossaries
Outlines

Continuous delivery (CD) is a software engineering approach in which teams produce software in short cycles, ensuring that the software can be reliably released at any time. It aims at building, testing, and releasing software with greater speed and frequency. The approach helps reduce the cost, time, and risk of delivering changes by allowing for more incremental updates to applications in production. A straightforward and repeatable deployment process is important for continuous delivery.

Principles

According to Neal Ford, continuous delivery adopts "Bring the pain forward," tackling tough tasks early, fostering automation and swift issue detection.

Continuous delivery treats the commonplace notion of a deployment pipeline as a lean Poka-Yoke: a set of validations through which a piece of software must pass on its way to release. Code is compiled if necessary and then packaged by a build server every time a change is committed to a source control repository, then tested by a number of different techniques (possibly including manual testing) before it can be marked as releasable.

Developers used to a long cycle time may need to change their mindset when working in a CD environment. Any code commit may be released to customers at any point. Patterns such as feature toggles can be very useful for committing code early which is not yet ready for use by end users. Using NoSQL can eliminate the step of data migrations and schema changes, often manual steps or exceptions to a continuous delivery workflow. Other useful techniques for developing code in isolation such as code branching are not obsolete in a CD world, but must be adapted to fit the principles of CD - for example, running multiple long-lived code branches can prove impractical, as a releasable artifact must be built early in the CD process from a single code branch if it is to pass through all phases of the pipeline.

Deployment pipeline

Continuous delivery is enabled through the deployment pipeline. The purpose of the deployment pipeline has three components: visibility, feedback, and continually deploy.

  • Visibility – All aspects of the delivery system including building, deploying, testing, and releasing are visible to every member of the team to promote collaboration.
  • Feedback – Team members learn of problems as soon as possible when they occur so that they are able to fix them as quickly as possible.
  • Continually deploy – Through a fully automated process, you can deploy and release any version of the software to any environment.


According to Yan Cui, when it comes to serverless environments, ephemeral resources should be kept together and have their own deployment pipeline to achieve a high cohesion. However, shared resources that have a long spin-up time and landing zone should have their own separate repository, deployment pipeline and stack.

Tools/tool types

Continuous delivery takes automation from source control all the way through production. There are various tools that help accomplish all or part of this process. These tools are part of the deployment pipeline which includes continuous delivery. The types of tools that execute various parts of the process include: continuous integration, application release automation, build automation, application lifecycle management.

Architecting for continuous delivery

To practice continuous delivery effectively, software applications have to meet a set of architecturally significant requirements (ASRs) such as deployability, modifiability, and testability. These ASRs require a high priority and cannot be traded off lightly.

Microservices are often used when architecting for continuous delivery. The use of Microservices can increase a software system's deployability and modifiability. The observed deployability improvements include: deployment independence, shorter deployment time, simpler deployment procedures, and zero downtime deployment. The observed modifiability improvements include: shorter cycle time for small incremental functional changes, easier technology selection changes, incremental quality attribute changes, and easier language and library upgrades.

Implementation and usage

The original CD book written by Jez Humble and David Farley (2010) popularized the term; however, since its creation the definition has continued to advance and now has a more developed meaning. Companies today are implementing these continuous delivery principles and best practices. The difference in domains, e.g. medical vs. web, is still significant and affects the implementation and usage. Well-known companies that have this approach include Yahoo!, Amazon, Facebook, Google, Paddy Power and Wells Fargo.

Benefits and obstacles

Several benefits of continuous delivery have been reported.

  • Accelerated time to market: Continuous delivery lets an organization deliver the business value inherent in new software releases to customers more quickly. This capability helps the company stay a step ahead of the competition.
  • Building the right product: Frequent releases let the application development teams obtain user feedback more quickly. This lets them work on only the useful features. If they find that a feature isn't useful, they spend no further effort on it. This helps them build the right product.
  • Improved productivity and efficiency: Significant time savings for developers, testers, operations engineers, etc. through automation.
  • Reliable releases: The risks associated with a release have significantly decreased, and the release process has become more reliable. With continuous delivery, the deployment process and scripts are tested repeatedly before deployment to production. So, most errors in the deployment process and scripts have already been discovered. With more frequent releases, the number of code changes in each release decreases. This makes finding and fixing any problems that do occur easier, reducing the time in which they have an impact.
  • Improved product quality: The number of open bugs and production incidents has decreased significantly.
  • Improved customer satisfaction: A higher level of customer satisfaction is achieved.

Obstacles have also been investigated.

  • Customer preferences: Some customers do not want frequent updates to their systems.
  • Domain restrictions: In some domains, such as telecom, medical, avionics, railway and heavy industries, regulations require customer-side or even on-site testing of new versions.
  • Lack of test automation: Lack of test automation leads to a lack of developer confidence and can prevent using continuous delivery.
  • Differences in environments: Different environments used in the development, testing and production can result in undetected issues slipping to the production environment.
  • Tests needing a human oracle: Not all quality attributes can be verified with automation. These attributes require humans in the loop, slowing down the delivery pipeline.

Eight further adoption challenges were raised and elaborated on by Chen. These challenges are in the areas of organizational structure, processes, tools, infrastructure, legacy systems, architecting for continuous delivery, continuous testing of non-functional requirements, and test execution optimization.

Strategies to overcome adoption challenges

This section contains instructions, advice, or how-to content. Please help rewrite the content so that it is more encyclopedic or move it to Wikiversity, Wikibooks, or Wikivoyage. (January 2022)

Several strategies to overcome continuous delivery adoption challenges have been reported.

Strategies to Overcome CD Adoption Challenges
Strategy Description
Selling CD as a painkiller Identify each stakeholder's pain points that CD can solve, and sell CD as a painkiller to that stakeholder. This strategy helps to achieve buy-in from the wide range of stakeholders that a CD implementation requires.
Dedicated team with multi-disciplinary members Without a dedicated team, it can be hard to progress because employees are often assigned to work on other value streams. A multi-disciplinary team not only provides the wide range of skills required for CD implementation but also smooths the communication with related teams.
Continuous delivery of continuous delivery Organize the implementation of CD in a way that delivers value to the company as early as possible, onboarding more projects gradually, in small increments and eventually rolling out CD across the whole organization. This strategy helps justify the investment required by making concrete benefits visible along the way. Visible benefits, in turn, help to achieve the sustained company support and investment required to survive the long and tough journey to CD.
Starting with easy but important applications When selecting the first few applications to migrate to CD, choose the ones that are easy to migrate but that are important to the business. Being easy to migrate helps to demonstrate the benefits of CD quickly, which can prevent the implementation initiative from being killed. Being important to the business helps to secure the required resources, demonstrates clear and unarguable value, and raises the visibility of CD in the organization.
Visual CD pipeline skeleton Give a team a visual CD pipeline skeleton that has the full CD pipeline view but with empty stages for those they cannot implement yet. This helps to build up a CD mindset and maintain the momentum for CD adoption. The pipeline skeleton is especially useful when the team's migration to CD requires a large effort and mindset changes over a long period of time.
Expert drop Assign a CD expert to join tough projects as a senior member of the development team. Having the expert on the team helps to build the motivation and momentum to move to CD from inside the team. It also helps to maintain momentum when the migration requires a large effort and a long period of time.

Best practices for cloud systems

The following practices can enhance productivity of pipelines, especially in systems hosted in the cloud:

  • Number of Pipelines: Small teams can be more productive by having one repository and one pipeline. In contrast, larger organizations may have separate repositories and pipelines for each team or even separate repositories and pipelines for each service within a team.
  • Permissions: In the context of pipeline-related permissions, adhering to the principle of least privilege can be challenging due to the dynamic nature of architecture. Administrators may opt for more permissive permissions while implementing compensating security controls to minimize the blast radius.

Relationship to DevOps

Main article: DevOps

DevOps is a software engineering approach that centers around cultural change, specifically the collaboration of the various teams involved in software delivery (developers, operations, quality assurance, management, etc.), as well as automating the processes in software delivery.

Relationship to Continuous Deployment

Main article: Continuous deployment

Continuous deployment is a software engineering approach which uses automated software deployments. In it, software is produced in short cycles but through automated software deployments even to production rather than requiring a "click of a button" for that last step. Therefore, continuous deployment can be considered a more sophisticated form of automation. Academic literature differentiates between continuous delivery and continuous deployment according to deployment method; manual vs. automated.

See also

Further reading

References

  1. ^ Chen, Lianping (2015). "Continuous Delivery: Huge Benefits, but Challenges Too". IEEE Software. 32 (2): 50–54. doi:10.1109/MS.2015.27. S2CID 1241241.
  2. ^ Shahin, Mojtaba; Ali Babara, Muhammad; Zhu, Liming (2017). "Continuous Integration, Delivery and Deployment: A Systematic Review on Approaches, Tools, Challenges and Practices". IEEE Access. 5: 3909–3943. arXiv:1703.07019. Bibcode:2017arXiv170307019S. doi:10.1109/ACCESS.2017.2685629. S2CID 11638909.
  3. Building Evolutionary Architectures: Automated Software Governance. ISBN 978-1492097549.
  4. Humble, J.; Read, C.; North, D. (2006). "The Deployment Production Line". Agile 2006 (Agile'06). pp. 113–118. doi:10.1109/AGILE.2006.53. ISBN 0-7695-2562-8. S2CID 16572138.
  5. Fitzgerald, Brian (2014-06-03). Continuous Software Engineering and Beyond: Trends and Challenges (PDF). 1st International Workshop on Rapid Continuous Software Engineering. New York, NY: Association for Computing Machinery. pp. 1–9. doi:10.1145/2593812.2593813. hdl:10344/3896. ISBN 978-1-4503-2856-2. Archived from the original (PDF) on 2014-10-25. Retrieved 2014-10-24.
  6. Kluge, Lars (12 September 2013). "Continuous Deployment with MongoDB at Kitchensurfing". slideshare.net. Retrieved 3 January 2014.
  7. Duvall, Paul (2012). "Continuous Delivery: Patterns and Anti-Patterns in Software Lifecycle" (PDF). Refcardz. Archived from the original (PDF) on June 19, 2018. Retrieved October 9, 2015.
  8. Cui, Yan (2020). Serverless Architectures on AWS (2nd ed.). Manning. ISBN 978-1617295423.
  9. Phillips, Andrew (29 July 2014). "The Continuous Delivery Pipeline – What it is and Why it's so important in Developing Software". DevOps.com. Archived from the original on 28 September 2015. Retrieved October 9, 2015.
  10. Binstock, Andrew (16 September 2014). "Continuous Delivery: The Agile SUccessor". Dr. Dobb's the World of Software Development. San Francisco: UBM.
  11. Chen, Lianping (2015). Towards Architecting for Continuous Delivery. The 12th Working IEEE/IFIP Conference on Software Architecture(WICSA 2015). Montréal, Canada: IEEE. doi:10.1109/WICSA.2015.23. Archived 2018-11-13 at the Wayback Machine
  12. ^ Chen, Lianping (2018). Microservices: Architecting for Continuous Delivery and DevOps. The IEEE International Conference on Software Architecture (ICSA 2018). IEEE.
  13. ^ Leppänen, M.; Mäkinen, S.; Pagels, M.; Eloranta, V. P.; Itkonen, J.; Mäntylä, M. V.; Männistö, T. (2015-03-01). "The Highways and Country Roads to Continuous Deployment". IEEE Software. 32 (2): 64–72. doi:10.1109/MS.2015.50. ISSN 0740-7459. S2CID 18719684.
  14. "Implementing Continuous Delivery at Yahoo!". confreaks.tv. 23 October 2013.
  15. "Velocity 2011: Jon Jenkins, "Velocity Culture"". youtube.com. 20 June 2011.
  16. "Rapid Release At Massive Scale". 2017-08-31.
  17. Humble, Jez (13 February 2014). "The Case for Continuous Delivery". thoughtworks.com. Retrieved 16 July 2014.
  18. jFrog (December 2014). "2014-year-continuous-integration-revolution".
  19. ^ Chen, Lianping (2017). "Continuous Delivery: Overcoming adoption challenges". Journal of Systems and Software. 128: 72–86. doi:10.1016/j.jss.2017.02.013.
  20. Serverless Architectures on AWS. Manning. 29 March 2022. ISBN 978-1617295423.
  21. Pipeline as Code Continuous Delivery with Jenkins, Kubernetes, and Terraform. Manning. ISBN 9781638350378.
  22. Humble, Jez; Farley, David (27 July 2010). Continuous Delivery Reliable Software Releases Through Build, Test, and Deployment Automation. Pearson Education. ISBN 9780321670229.
  23. Humble, Jez; Farley, David (2011). Continuous Delivery: reliable software releases through build, test, and deployment automation. Pearson Education Inc. ISBN 978-0-321-60191-9.
  24. Hammond, Jeffrey (9 September 2011). "The Relationship between DevOps and Continuous Delivery". Forrester Research. Forester.
  25. Swartout, Paul (2012). Continuous Delivery and DevOps: A Quickstart guide. Packt Publishing. ISBN 978-1849693684.
  26. "Continuous Deployment: An Essential Guide". IBM. 2019-10-02. Retrieved 2022-11-28. Continuous deployment is the natural outcome of continuous delivery done well. Eventually, the manual approval delivers little or no value and is merely slowly things down. At that point, it is done away with and continuous delivery becomes continuous deployment.
  27. Shahin, Mojtaba; Babar, Muhammad Ali; Zahedi, Mansooreh; Zhu, Liming (2017). "Beyond Continuous Delivery: An Empirical Investigation of Continuous Deployment Challenges". 2017 ACM/IEEE International Symposium on Empirical Software Engineering and Measurement (ESEM). pp. 111–120. doi:10.1109/ESEM.2017.18. ISBN 978-1-5090-4039-1. S2CID 3479812.

External links

  1. "Building Evolutionary Architecture".
Categories: