Continuous delivery, or CD, is the practice of automating the manual steps involved in preparing software for release to production.
Continuous delivery (CD) builds on continuous integration (CI) by automating the steps involved in preparing software for release to production.
Each time you merge code changes into a designated branch, your continuous integration process runs a series of checks, including automated unit tests, and creates a build. Continuous delivery extends that process by automatically deploying each build to a series of testing and staging environments and running further automated tests.
These tests can include integration tests, UI tests, performance tests (such as load, soak, and stress tests), and end-to-end tests. Depending on your industry, you might also use continuous delivery to run security tests, accessibility tests, and manual user acceptance or exploratory testing. Once a build has passed each stage successfully, it’s considered ready for release to production.
As with continuous integration, the key to an effective continuous delivery practice is to automate as much of the process as possible. This includes providing feedback on each stage and alerting the team whenever the build fails to pass a stage so you can address the issue quickly.
Both continuous delivery and continuous deployment involve automatically deploying builds to environments and running automated tests. As a result, the two terms are sometimes used interchangeably. However, there is a useful distinction between continuous delivery and continuous deployment.
With continuous deployment, a code change is automatically deployed to production every time it successfully passes each testing stage. In contrast, continuous delivery involves a manual step for the final stage – releasing your software to production.
While continuous deployment might sound like the ideal goal for any software development team, there are good reasons why many teams choose to practice continuous delivery.
Read more about continuous delivery vs. continuous deployment.
The final stage of a CI/CD process involves deploying your code changes to production. With continuous delivery, the decision to release to production is a manual step, even though the release process itself is automated.
Some teams practice continuous delivery as a stepping stone towards continuous deployment. Triggering the final deployment to production manually provides a safety net while you build confidence in your automated tests and checks. In this case, you might choose to practice continuous delivery for several months before making the jump to deploying every successful code change to production automatically.
However, deploying updates to your software several times a day or hour is not always the best choice. For versioned software – including mobile apps, APIs, embedded software, or desktop products – it often makes sense to group changes into larger releases. Users of installed products don’t expect to have to update their apps every few hours, while upgrading to a new API version can significantly impact your customers. Choosing between continuous delivery and deployment is about making the right decision for your business and your users.
Although the exact build steps, environments, and tests will depend on your product and organization, the following general principles will help you build your continuous delivery process:
Continuous delivery enables teams to release software faster and more frequently while reducing the number of bugs that make it into production. The key to achieving this is ensuring that your code is always ready to release by continuously testing your changes and addressing issues as soon as they are discovered.
Beyond that, continuous delivery offers multiple additional benefits:
Implementing a continuous delivery process can come with a few challenges:
Building a continuous delivery process might seem daunting, but when done right, it can dramatically speed up software releases while minimizing bugs.
Central to effective implementation of continuous delivery is adopting the DevOps mindset. Rather than viewing the software development process as a one-way conveyor belt – with requirements, code, and reports handed off from one team to the next – DevOps champions collaboration and rapid feedback from short, iterative cycles.
Changing your “definition of done” can help you adopt this mentality. Instead of considering the task complete when you hand your code over for testing, your new feature or code change is only done once it’s released live. If an issue is found at any stage in the pipeline, communicating that feedback promptly and collaborating on a fix makes for a quicker resolution than lengthy reports that must go through a change board for approval. That’s what continuous delivery is all about.
For more tips to help you get started with continuous delivery, read our guide to CI/CD best practices.
Continuous delivery makes it easier and quicker to release software, enabling frequent deployments to production. Instead of a large quarterly or annual release, smaller updates are delivered frequently. This not only means users get new functionality and bug fixes sooner, but it also allows you to see how your software is used in the wild and adjust plans accordingly.
While some organizations prefer to maintain control over the final step in the release process, for others, the logical conclusion of a CI/CD pipeline is to automate the release to live, using a practice known as continuous deployment. You can learn more about this in the next section of our CI/CD guide.
TeamCity is a CI/CD platform with extensive support for a wide range of build tools, testing frameworks, containers, and cloud infrastructure providers. Whether you want to host your build machines on-site, in the cloud, or use a combination of both, TeamCity will coordinate build tasks for maximum efficiency.
TeamCity’s customizable pipeline logic means you can choose when to run processes in parallel – such as tests on different platforms – and when to require successful completion before moving to the next stage. Configurable notifications provide you with the information you need wherever you’re working, helping you avoid unnecessary interruptions. Finally, detailed results help you ensure your path to production remains clear.
Understanding the philosophy behind Agile can help you get more out of CI/CD.
A canary release is a deployment strategy whereby changes are initially released to a small subset of users.
Using JetBrains TeamCity for their daily CI/CD operations, Playrix runs over 10,000 builds per day for several platforms.