In software engineering, CI/CD or CICD is the combined practices of continuous integration (CI) and continuous delivery (CD) or, less often, continuous deployment.[1] They are sometimes referred to collectively as continuous development or continuous software development.[2]
Components
edit- Continuous integration
- Frequent merging of several small changes into a main branch.
- Continuous delivery
- Producing software in short cycles with high speed and frequency so that reliable software can be released at any time, with a simple and repeatable deployment process when deciding to deploy.
- Continuous deployment
- Automatic rollout of new software functionality.
Motivation
editCI/CD bridges the gaps between development and operation activities and teams by enforcing automation in building, testing and deployment of applications. CI/CD services compile the incremental code changes made by developers, then link and package them into software deliverables.[3] Automated tests verify the software functionality, and automated deployment services deliver them to end users.[4] The aim is to increase early defect discovery, increase productivity, and provide faster release cycles. The process contrasts with traditional methods where a collection of software updates were integrated into one large batch before deploying the newer version.
Modern-day DevOps practices involve:
- continuous development,
- continuous testing,
- continuous integration,
- continuous deployment, and
- continuous monitoring
of software applications throughout its development life cycle. The CI/CD practice, or CI/CD pipeline, forms the backbone of modern day DevOps operations.
Best practices for cloud systems
editThe following practices can enhance productivity of CI/CD pipelines, especially in systems hosted in the cloud:[5][6][7]
- 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.
See also
edit- Continuous integration (CI)
- Continuous delivery (CD)
- Continuous deployment (CD)
References
edit- ^ Sacolick, Isaac (2020-01-17). "What is CI/CD? Continuous integration and continuous delivery explained". InfoWorld. Retrieved 2021-06-01.
- ^ "What is Continuous Development and How Does It Work? | Synopsys".
- ^ Rossel, Sander (October 2017). Continuous Integration, Delivery, and Deployment. Packt Publishing. ISBN 978-1-78728-661-0.
- ^ Gallaba, Keheliya (2019). "Improving the Robustness and Efficiency of Continuous Integration and Deployment". 2019 IEEE International Conference on Software Maintenance and Evolution (ICSME). pp. 619–623. doi:10.1109/ICSME.2019.00099. ISBN 978-1-7281-3094-1. S2CID 208879679.619-623&rft.date=2019&rft_id=https://api.semanticscholar.org/CorpusID:208879679#id-name=S2CID&rft_id=info:doi/10.1109/ICSME.2019.00099&rft.isbn=978-1-7281-3094-1&rft.aulast=Gallaba&rft.aufirst=Keheliya&rft_id=https://escholarship.mcgill.ca/concern/theses/wd376267t&rfr_id=info:sid/en.wikipedia.org:CI/CD" class="Z3988">
- ^ Serverless Architectures on AWS. Manning. ISBN 978-1617295423.
- ^ Pipeline as Code Continuous Delivery with Jenkins, Kubernetes, and Terraform. Manning. ISBN 9781638350378.
- ^ Continuous Delivery Reliable Software Releases Through Build, Test, and Deployment Automation. ISBN 9780321670229.
External links
edit- El Khalyly, B.; Belangour, A.; Banane, M.; Erraissi, A. (2020). "A new metamodel approach of CI/CD applied to Internet of Things Ecosystem". 2020 IEEE 2nd International Conference on Electronics, Control, Optimization and Computer Science (ICECOCS). pp. 1–6. doi:10.1109/ICECOCS50124.2020.9314485. ISBN 978-1-7281-6921-7. S2CID 231645681.1-6&rft.date=2020&rft_id=https://api.semanticscholar.org/CorpusID:231645681#id-name=S2CID&rft_id=info:doi/10.1109/ICECOCS50124.2020.9314485&rft.isbn=978-1-7281-6921-7&rft.aulast=El Khalyly&rft.aufirst=B.&rft.au=Belangour, A.&rft.au=Banane, M.&rft.au=Erraissi, A.&rft_id=https://ieeexplore.ieee.org/document/9314485&rfr_id=info:sid/en.wikipedia.org:CI/CD" class="Z3988">
- Sane, P. (2021). "A Brief Survey of Current Software Engineering Practices in Continuous Integration and Automated Accessibility Testing". 2021 Sixth International Conference on Wireless Communications, Signal Processing and Networking (WiSPNET). pp. 130–134. arXiv:2103.00097. doi:10.1109/WiSPNET51692.2021.9419464. ISBN 978-1-6654-4086-8. S2CID 232076320.130-134&rft.date=2021&rft_id=info:arxiv/2103.00097&rft_id=https://api.semanticscholar.org/CorpusID:232076320#id-name=S2CID&rft_id=info:doi/10.1109/WiSPNET51692.2021.9419464&rft.isbn=978-1-6654-4086-8&rft.aulast=Sane&rft.aufirst=P.&rft_id=https://ieeexplore.ieee.org/document/9419464&rfr_id=info:sid/en.wikipedia.org:CI/CD" class="Z3988">