I wanted to use pipelines to manage environments for production and staging so the app can be tested with all the changes made before push them to production, just like heroku does. I was wondering how can I achieve this?
This textbox defaults to using Markdown to format your answer.
You can type !ref in this text area to quickly search our full set of tutorials, documentation & marketplace offerings and insert the link!
These answers are provided by our Community. If you find them useful, show some love by clicking the heart. If you run into issues leave a comment, or add your own answer to help others.
Sign up for Infrastructure as a Newsletter.
Working on improving health and education, reducing inequality, and spurring economic growth? We'd like to help.
Get paid to write technical tutorials and select a tech-focused charity to receive a matching donation.
Hi there,
What you could do to achieve this is to create a separate app to act as your staging environment which will be separate from your production app.
Basically, create two separate apps on the App Platform, one for staging and one for production. That way you will ensure that any changes made in the staging environment do not affect the production environment until you’re ready.
Then you can set up a deployment from GitHub and for the staging app, you might want to deploy from a development or staging branch, while the production app deploys from the main branch.
Next, you can enable automatic deployments for the staging app, so every time you push changes to your development or staging branch, the staging app gets updated.
For the production app, you can choose to manually deploy when you’re confident about the changes. Alternatively, you can also set it to auto-deploy from the main branch if you prefer.
Once you’ve tested your changes in the staging environment and are satisfied, merge your changes from the development or staging branch into the main branch.
This process will mimic the pipeline structure you mentioned with Heroku. The key is maintaining separate environments for staging and production, ensuring you test all changes in a safe environment before deploying them to production.
I would also suggest having separate databases for the two environments so that the staging deployments would not affect your production environment.
Hope that this helps!
Best,
Bobby