IBM Cloud Docs
Using projects to deploy a deployable architecture to multiple regions

Using projects to deploy a deployable architecture to multiple regions

This tutorial walks you through how to use projectsA collection of artifacts that define and manage resources and Infrastructure as Code deployments. to deploy two slightly different configurations of the same deployable architecture to two different regions.

Imagine you are a software developer for Example Corp enterprise. Your infrastructure architect discovered the Cloud automation for Code Engine deployable architecture, and your cloud automation engineering professional customized it to fully meet your business needs. The customized deployable architecture is used to automate the deployment of a containerized application on IBM Cloud Code Engine. The existing container image at icr.io/codeengine/helloworld is used as an example application. Now, you need to deploy the deployable architecture to multiple regions for local data storage and performance or high availability reasons to best support your application.

This tutorial uses a fictitious scenario to help you learn and understand how to use projects to deploy to multiple regions. As you complete the tutorial, adapt each step to match your organization's needs.

Before you begin

  1. Set up your IBM Cloud account.

  2. Create a customized deployable architecture called Example Corp's infrastructure and onboard it to a private catalog called Example Corp catalog.

  3. Understand that completing this tutorial might result in costs to your account. Cloud automation for Code Engine was customized to create Example Corp's infrastructure. For more information about associated costs for using Code Engine, go to Pricing for Code Engine.

  4. Make sure that you have the following access roles to create a project and permission to create the project tooling resources within the account:

    • The Editor role on the IBM Cloud Projects service.
    • The Editor and Manager role on the IBM Cloud® Schematics service
    • The Viewer role on the resource group for the project
    • Other roles that are required for specific resources in your deployable architecture. Cloud automation for Code Engine requires the Writer service access role that is scoped to all resources for the Code Engine service.

    For more information about access and permissions, see Assigning users access to projects.

  5. Set up an authentication method. You can use an API key that is stored in Secrets Manager or a trusted profile to authorize a deployment to your target account.

    Deploying a proof of concept for testing purposes? You can create an API key later on, as you edit a configuration in your project. Doing so authorizes the project to deploy to the currently selected account.

Create a project

Create a project where you can configure and deploy Example Corp's infrastructure.

  1. In the IBM Cloud console, click the Navigation menu icon Navigation Menu icon > Projects.
  2. Click Create.
  3. Name your project Example Corp infrastructure.
  4. Add the following description to your project: Project to manage the different configurations and deployments of Example Corp's infrastructure.
  5. Select Dallas as the region where the project data is stored.
  6. Keep Default for the resource group.
  7. Click Create.

Create an environment in your project

Now that your project is created, you're ready to create an environment to share values across configurations for easier deployments. The properties that you add to an environment are automatically added to configurations that are using that environment. For more information, see the benefits to using environments. In this tutorial, you add the authentication method to the environment so it can be reused in your project.

  1. In the Example Corp infrastructure project, select Manage > Environments.
  2. Click Create.
  3. Name your environment Example Corp infrastructure dev.
  4. Click Add > Add manually...
  5. Select Authentication for the category.
  6. Specify the authentication method that you set up in the before you begin steps. You can use an API key or a trusted profile.
  7. Depending on which method you choose, either select the secret that contains your API key or provide the trusted profile ID.
  8. Click Add to add the authentication method to the environment.
  9. Click Save to save the environment.

Add a deployable architecture to a project

Before you can configure Example Corp's infrastructure, you need to find the deployable architecture in Example Corp catalog and add it to the Example Corp infrastructure project.

  1. In the Example Corp infrastructure project, select Configurations > Create.
  2. Use the catalog menu to open the private catalog called Example Corp catalog.
  3. From the Type section, select Private products to filter the list of products.
  4. Select Example Corp's infrastructure from the list of remaining products.
  5. Select Configure and deploy.
  6. Change the configuration name to example-corp-us-south to indicate that you want to deploy the configuration in the US southern region.
  7. Select Example Corp infrastructure dev as the environment.
  8. Click Add.

You successfully added the deployable architecture to a project and are ready to define the configuration.

Configure the deployable architecture

  1. In the Details section, review the information and make sure the Example Corp infrastructure dev environment is selected.

  2. From the Security section, confirm that the correct authentication method is selected based on what you added to the environment.

  3. During validation, a Code Risk Analyzer scan is run on your architecture, which includes a compliance scan based on a set of controls. Example Corp's infrastructure doesn't include any applicable controls, but you can set up your own attachment through Security and Compliance Center if you want to. For more information, see Configuring the architecture. Select Architecture default if you don't want to use your own attachment from Security and Compliance Center.

  4. From the Inputs section, enter values for the required input variables for the deployable architecture configuration:

    1. Enter us-south as the prefix to use for naming conventions.
    2. Select Default as the existing_resource_group_name.
    3. Select us-south as the region to deploy the resources.
  5. Click Save.

  6. Click Validate. The modal that is displayed provides more details about your in-progress validation.

    If the validation fails, you can troubleshoot the failure. Or, an administrator on the IBM Cloud Projects service can review the results through the Schematics service and override the failure and approve the configuration to deploy anyway. However, make sure that the pipeline failed due to the Code Risk Analyzer scan and not because of a validation or plan failure. It is not recommended to override a failure that is flagged due to a validation or plan failure as the configuration cannot deploy successfully. For more information about security and compliance in projects, see Achieving continuous compliance as an enterprise.

During the configuration and deployment process, monitor your Needs attention items. The widget reflects any issue that occurs in your configurations.

Approve and deploy your first configuration

As an Editor on the IBM Cloud® Projects service, you can approve the configuration changes and deploy the configuration. It can be beneficial to deploy your first configuration to make sure that your changes work as expected. Then, if the deployment is successful, you can continue to create your second configuration.

You must address any outstanding Needs attention items on the Overview tab before you can approve and deploy your configurations.

  1. From the Example Corp infrastructure project, select the Configurations tab.
  2. Click the Options icon Options icon for example-corp-us-south > View last validation.
  3. Add a comment with more details about the approval, and click Approve.
  4. Click Deploy and wait for the deployment to finish.

Add and configure the second deployable architecture

Now that you configured and deployed your architecture to one region, you can duplicate it to deploy the architecture to another region.

  1. From the Example Corp infrastructure project, select the Configurations tab.

  2. Click the Options icon Options icon for example-corp-us-south > Duplicate. example-corp-us-south-copy-01 is added to your project.

  3. Click the Options icon Options icon for example-corp-us-south-copy-01 > Edit.

  4. From the Details section, click Edit and change the name of the configuration to example-corp-us-east.

  5. From the Details section, make sure the Example Corp infrastructure dev environment is selected.

  6. From the Security section, review the information that was pulled in from the environment that you created.

  7. From the Inputs section, click Edit and enter values for the required input variables for the deployable architecture configuration:

    1. Enter us-east as the prefix to use for naming conventions.
    2. Select Default as the existing_resource_group_name.
    3. Select us-east as the region to deploy the resources.
  8. Click Save.

  9. Click Validate. The modal that is displayed provides more details about your in-progress validation.

    If the validation fails, you can troubleshoot the failure. Or, an administrator on the IBM Cloud Projects service can review the results through the Schematics service and override the failure and approve the configuration to deploy anyway. However, make sure that the pipeline failed due to the Code Risk Analyzer scan and not because of a validation or plan failure. It is not recommended to override a failure that is flagged due to a validation or plan failure as the configuration cannot deploy successfully. For more information about security and compliance in projects, see Achieving continuous compliance as an enterprise.

During the configuration and deployment process, monitor your Needs attention items. The widget reflects any issue that occurs in your configurations.

Approve and deploy your second configuration

After the validation completes, you can deploy your second configuration.

You must address any outstanding Needs attention items on the Overview tab before you can approve and deploy your configurations.

  1. From the Example Corp infrastructure project, select the Configurations tab.
  2. Click the Options icon Options icon for example-corp-us-east > Edit.
  3. Click View details to view the last validation and approve the changes.
  4. Add a comment with more details about the approval, and click Approve.
  5. Click Deploy and wait for the deployment to finish.

Next steps

After the deployment successfully completes, your application is deployed in two separate regions. The two slightly different configurations are based on the same deployable architecture. To find the applications, go to the IBM Cloud console, click the Navigation menu icon Navigation Menu icon > Containers > Severless Projects.

Check out the next tutorial on Adding customizable options to Example Corp's infrastructure.