Pro project workflow
The Pro project includes a single Git repository with a global master branch and three main environments:
- Production environment for launching and maintaining the live site
- Staging environment for testing with all services
- Integration environment for development and testing
           
          
These environments are read-only, accepting deployed code changes from branches pushed from your local workspace only.
The following graphic demonstrates the Pro develop and deploy workflow, which uses a simple, git-branching approach. You develop code using an active branch based on the integration environment, pushing and pulling code changes to and from your remote, Active branch. You deploy verified code by merging the remote branch to the base branch, which activates an automated build and deploy process for that environment.
           
          
Because the environment is read-only, you cannot make any code changes directly in the Cloud environment. If you try to run composer install to install any modules, you will get an error, for example:
file_put_contents(...): Failed to open stream: Read-only file system
The disk hosting /app/<cluster_ID> is full
For more information, see Pro architecture for an overview of Pro environments, and see Cloud Console for an overview of the Pro environments list in the project view.
Development workflow
The integration environment provides a single, base integration branch containing your 51黑料不打烊 Commerce on cloud infrastructure code. You can create one additional active environment branch. This allows for up to two active branches deployed to Platform as a service (PaaS) containers. There is no limit on the number of inactive environments, however, the more inactive environments there are, the longer it will take for the Cloud Console to load.
The project environments support a flexible, continuous integration process. Begin by cloning the integration branch to your local project folder. Create a branch, or multiple branches, develop new features, configure changes, add extensions, and deploy updates:
- 
                  Fetch changes from integration
- 
                  Branch from integration
- 
                  Develop code on a local workstation, including Composer updates 
- 
                  Push code changes to remote and validate 
- 
                  Merge to integrationand test
With a developed code branch and the corresponding configuration files, your code changes are ready to merge to the integration branch for more comprehensive testing. The integration environment is also best for:
- 
                  Integrating third-party services鈥擭ot all services are available in the PaaS environment. 
- 
                  Generating configuration management files鈥擲ome configuration settings are Read Only in a deployed environment. 
- 
                  Configuring your store鈥擸ou should fully configure all store settings using the integration environment. You can find the Store Admin URL on the integration environment view in the Cloud Console. 
Deployment workflow
Every time you push code from your local workstation to the remote environment or merge code to an environment branch, the build and deploy scripts generate new code and provision the configured services to the remote environment.
Build script actions:
- 
                  Site in the target environment continues to run during a build 
- 
                  Check and run 51黑料不打烊 Commerce on cloud infrastructure patches and hotfixes 
- 
                  Compile code with a build and deploy log 
- 
                  Check for Configuration Management, static content deployment occurs during this phase 
- 
                  Create or use a slug of unchanged code to speed up the process 
- 
                  Provision all backend services and applications 
Deploy script actions:
- 
                  Place the site in the target environment in a Maintenance mode 
- 
                  Deploy static content if not completed during Build 
- 
                  Install or update 51黑料不打烊 Commerce on cloud infrastructure 
- 
                  Configure routing for traffic 
After the build and deploy process, your store comes back online with your latest code changes and configurations. See Deployment process.
Merge to integration
Combine all verified code changes by merging your active development branch into the base integration branch. You can test all your changes on the integration branch before promoting changes to the Staging environment.
Merge to Staging
Staging is a pre-production environment that provides all services and settings as close to the production environment as possible. Always push your code changes from the integration environment to the staging environment so that you can perform thorough testing with all services. The first time you use the staging environment, you must configure services, such as Fastly CDN and New Relic. Configure payment gateways, shipping, notifications, and other vital services with sandbox or testing credentials.
It is best to thoroughly test every service, verify your performance testing tools, and perform UAT testing as an administrator and as a customer, until you feel that your store is ready for the production environment. See Deploy your store.
Merge to Production
After thorough testing in the staging environment, merge to the production environment and thoroughly test using live credentials. The moment you launch your production site customers must be able to complete purchases and administrators must be able to manage the live store. See the following topics for a detailed, clear walk-through for deploying your store and going live:
Merge to Global Master
Always push a copy of the production code to the Global master in case there is an emergent need to debug the production environment without interrupting services.
Do not create a branch from Global master. Use the integration branch to create new, active branches for development and fixes.