Pivotal/Cloud Foundry/Tasks
Cloud Foundry | Cloud Foundry CLI | Apps | Tasks | Logs
Contents |
Blue/Green App Deployment
https://docs.cloudfoundry.org/devguide/deploy-apps/blue-green.html
Push an app
start by pushing the app and defining the subdomain (hostname) and domain.
~$ cf push web-app -n daring-wildebeest -d cfapps.io
Update the app and push a new version
This will be done along side the old version and given a new subdomain. The old version will retain its existing route and traffic to it will still go to the old app version.
~$ cf push web-app-2 -n responsive-aligator -d cfapps.io
Map original route to new app
Now that we have (2) separate instances of the web-app running, one of the old version and one of the new version, we can map the old route to the new app. This will not replace the old app, instead both the old and new apps will be accessible from the old route (quasi load balanced).
~$ cf map-route web-app-2 cfapps.io --hostname web-app-daring-wildebeest
Unmap old app from old route
Next we can unmap the old app from the old route, leaving only the new app accessible from the old route.
~$ cf unmap-route web-app cfapps.io --hostname web-app-daring-wildebeest
Unmap new app from new route
With the new app deployed on the old route, we can remove the new route that we initially setup during the app deployment. Once the new app has been vested, you can delete the new route altogether.
~$ cf unmap-route web-app-2 cfapps.io --hostname web-app-2-responsive-aligator ~$ cf delete-route cfapps.io --hostname web-app-2-responsive-aligator