<\/span><\/h5>\nThe principal idea behind the rolling strategy is to wait for the new pods to become ready. The preparedness of pods is evaluated by a readiness check before taking down the old version. During this period if any serious issue occurs, the rolling deployment can be put on hold.
\nThere is a common practice of employing canary deployments for OpenShift Container Platform. All the new instances are thoroughly tested before replacing them with old versions. If the readiness check does not signal okay, then the deployment is aborted by the team. The check is not an external mechanism; it is inbuilt in the code. The team can always make more stringent checks as per requirement.<\/p>\n
When to use<\/strong>
\n\u2219\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 The canary technique carried out when the team is not sure of overall steadiness of the application. To ensure that the new version is working well with the platform it is rolled out in iteration.
\nPros<\/strong>
\n1. Convenient for performance testing.
\n2. Fast retraction is possible in case of a major issues.<\/p>\nCons<\/strong>
\n1. The application rollout is time-consuming.<\/p>\n<\/span>2. Recreate Strategy<\/span><\/span><\/h5>\nAs the name suggests the strategy works on the idea to deploy a dummy version. The new version is deployed when the old version has been closed down. This approach results in significant downtime as both the instances of applications cannot run simultaneously. Let\u2019s look at the situations which are best suited for, pros and cons.
\nWhen to use<\/strong>
\n\u2219\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 The approach is ideal for situations before starting a new development task.
\n\u2219\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 When you do not support having version A and version B of your program code operating at the same time.
\nPros<\/strong>
\n1. Easy to put applications together.
\n2. Application gets revamped.
\nCons<\/strong>
\n1. Downtime of the application is a major drawback.<\/p>\n<\/span>3. Custom Strategy (A\/B testing)<\/span><\/span><\/h5>\nThe approach is a little different than the above two strategies discussed above. Instead of rolling out a new version directly a part of the application is introduced to the users. This move is considered more of a business strategy rather than a deployment technique. To make this strategy successful a part of the new application version is rolled out first. Based on the data, statistics, and usage by the end users that part is taken into consideration for final deployment. But for this, we need to make some additional changes in order to distribute the traffic from old to new. Some of them are:
\n\u2219\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 By using browser cookies
\n\u2219\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 Query parameters
\n\u2219\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 Using GPS and IP to get the location of the devices\/users.<\/p>\n
Pros<\/strong>
\n1. Negligible downtime as the new version is tested in conjunction with the old version.
\n2. Traffic among new and old can be efficiently managed.<\/p>\nCons<\/strong>
\n1. Requires a strong load balancing mechanism.
\n2. Troubleshooting can become tricky due to double version management.<\/p>\n<\/span>4. Shadow Deployment<\/span><\/span><\/h5>\nA shadow deployment principally revolves around the idea of keeping both versions. The old version is not discarded instead the traffic of the old version is diverted to the new version. This way the production is not hampered and the job also gets done. This is particularly effective to test the production load on the new version. Final deployment is done when the\u00a0application meets all the stability and performance factors.
\nThis approach requires some arrangements to be performed for successful implementation. Let\u2019s consider an example of a payment gateway, one challenge that you can face while implementing is that user might end up paying twice for the same order. This is fairly simple to solve by creating a mocking service you can create a dummy service that replicates the response from the provider.
\nPros<\/strong>
\n1. No separate performance testing required to be done.
\n2. Minimal impact on the user and production.<\/p>\nCons<\/strong>
\n1.\u00a0 The setup can be quite expensive.
\n2.\u00a0 Additional arrangements like mocking services are required.<\/p>\n<\/span>5. Blue Green Deployments<\/span><\/span><\/h5>\nBlue-green deployment uses two versions of an application simultaneously. The old version is used is called the green version and the new version is called the blue version. This arrangement requires two configurations. If the testing version clears all the checks then traffic is redirected to a new version. If required, there is also a facility to roll back to the green, version by switching the production back to the previous version.
\nPros<\/strong>
\n1. Switching back and forth between the versions is easy.
\n2. No versioning issue.<\/p>\nCons<\/strong>
\n1. Expensive as it requires managing dual versions.
\n2. Managing both applications can be tedious task.<\/p>\n<\/span>Conclusion<\/span><\/span><\/h6>\nThere are multiple ways to manage the deployment strategy but it totally depends on the business requirement. So, it is advisable to have in-depth knowledge of your applications, available resources, the end-user requirements, and the cost that it is going to incur on the organization. Considering these options you can go for any of the choices listed above.<\/p>\n","protected":false},"excerpt":{"rendered":"
Table of Contents Different Devops Deployment strategies to consider in 20211. Rolling Strategy and Canary Deployments2. Recreate Strategy3. Custom Strategy (A\/B testing)4. Shadow Deployment5. Blue Green DeploymentsConclusion Different Devops Deployment strategies to consider in 2021 One of the phases of Software Development Lifecycle (SDLC) is Deployment. Like any other stage this holds a very important […]<\/p>\n","protected":false},"author":5,"featured_media":8639,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_monsterinsights_skip_tracking":false,"_monsterinsights_sitenote_active":false,"_monsterinsights_sitenote_note":"","_monsterinsights_sitenote_category":0,"footnotes":""},"categories":[440,441,444,443,442],"tags":[579,578,577,458,576,465],"class_list":["post-8633","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-articles","category-cloud","category-devops","category-enterprise-devops","category-latest","tag-a-b-deployment","tag-blue-green","tag-canary","tag-cloud","tag-deployment","tag-devops"],"aioseo_notices":[],"amp_enabled":true,"_links":{"self":[{"href":"https:\/\/devopscurry.com\/wp-json\/wp\/v2\/posts\/8633","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/devopscurry.com\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/devopscurry.com\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/devopscurry.com\/wp-json\/wp\/v2\/users\/5"}],"replies":[{"embeddable":true,"href":"https:\/\/devopscurry.com\/wp-json\/wp\/v2\/comments?post=8633"}],"version-history":[{"count":11,"href":"https:\/\/devopscurry.com\/wp-json\/wp\/v2\/posts\/8633\/revisions"}],"predecessor-version":[{"id":10875,"href":"https:\/\/devopscurry.com\/wp-json\/wp\/v2\/posts\/8633\/revisions\/10875"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/devopscurry.com\/wp-json\/wp\/v2\/media\/8639"}],"wp:attachment":[{"href":"https:\/\/devopscurry.com\/wp-json\/wp\/v2\/media?parent=8633"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/devopscurry.com\/wp-json\/wp\/v2\/categories?post=8633"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/devopscurry.com\/wp-json\/wp\/v2\/tags?post=8633"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}