Deploy to production

Overview

Deployments to production environments differ from non-production environments in that the production cluster is separate from the non-production clusters and the Solution Designer's UI for creating the Deploy pipeline is not available because typically only the Solution Hub is installed.

To deploy a project developed with IBM Industry Solutions Workbench to a production-like environment you therefore need to consider at least the following additional requirements:

  • The image of the project must be copied between different OpenShift Container Platform registries, from a non-production cluster to a production cluster

  • The Deploy pipeline in the production environment must be created once by calling the REST API directly instead of using the Solution Designer's UI

  • The project configuration must be transferred and modified once for the production environment

This guide explains the basic workflow for this deployment and shows examples of how these requirements can be implemented. However, it does not provide a production-ready workflow, but is a useful example that you can adapt to your specific security and automation requirements.

For this explanation, the following deployment scenario is assumed:

You have an OpenShift project (k5-project) in your non-production cluster that is used as a deployment target for the projects you developed. Your project is already built and deployed into this k5-project. The container image of this project (that is ready for promotion to production) is tagged with source tag and stored in the internal * OpenShift Docker Registry* in your non-production cluster.

You have an OpenShift project (k5-project) in your production cluster, which is used as a deployment target for your production-ready projects. Your project should be deployed to this project and the container image should be tagged with destination tag and stored in the internal OpenShift Docker Registry in your production cluster.

The following steps outline the process:

  • Check Prerequisites

  • Copy the project image to the production image registry

  • Create the pipeline for project deployment via REST API call

  • Create the solution-specific configuration for production

Check prerequisites

Before you begin, ensure that the following tasks are complete:

Install skopeo

The command line tool skopeo is used to copy the project image between different OpenShift Container Platform registries. It is preferable to use Docker because it can copy an image from one registry to another without first downloading it locally and without running a daemon to work.

Obtain OpenShift account

To copy the project image to the production image registry, an account in the role of Cluster Administrator is required on the non-production and production cluster. Creating the pipeline for project deployment via a REST API call requires the Project Administrator role for the project for which you are creating the pipeline.

Provide access to OpenShift docker registries

This guide assumes that you have external access to the internal OpenShift Image Registry of the non-production and the production cluster. You can find out the external address for each registry by viewing the route image-registry in the openshift-image-registry namespace.

Check if these addresses are accessible from your network, for example as follows:

oc login -u={Username} -p={Password} -s={Source Cluster}
SRC_IMAGE_REGISTRY=$(oc get route image-registry -n openshift-image-registry --template='{{ .spec.host }}')
curl -v <https://$SRC_IMAGE_REGISTRY/healthz>

Step 1: Copy project image to production image registry

Use the copy command of the skopeo tool as shown here to copy the project image from the non-production registry to the production registry.

oc login -u={Username} -p={Password} -s={Source Cluster}
SRC_CREDS="openshift:$(oc whoami -t)"
SRC_REGISTRY=$(oc get route image-registry -n openshift-image-registry --template='{{ .spec.host }}')
oc login -u={Username} -p={Password} -s={Destination Cluster}
DEST_CREDS="openshift:$(oc whoami -t)"
DEST_REGISTRY=$(oc get route image-registry -n openshift-image-registry --template='{{ .spec.host }}')
skopeo copy --dest-creds ${DEST_CREDS} --dest-tls-verify=false \
--src-creds ${SRC_CREDS} --src-tls-verify=false \
docker://${SRC_REGISTRY}/{Source Project}/{Solution Image}:{Source Tag}
docker://${DEST_REGISTRY}/{Destination Project}/{Solution Image}:{Source Tag}
Note: In this example, replace the placeholder variables {..} as follows:
  • {Username} and {Password} : OpenShift account in the role of Cluster Administrator

  • {Source Cluster} : Host name of the non-production OpenShift cluster

  • {Destination Cluster}: Host name of the production OpenShift cluster

  • {Solution Image}: Name of the image that should be copied

  • {Source Tag} : Tag of the image that should be copied

  • {Source Project} : Name of the k5-project in which the project is already deployed

  • {Destination Project} : Name of the k5-project to which the project should be deployed

The --src-tls-verify=false and --dest-tls-verify=false options for the copy command can be used if the default cluster certificate for routes is untrusted.

The source-image and destination-image parameters of the copy command use the form docker:://{External Address of Image Registy}/{project}/{image}:{tag}.

Step 2: Create pipeline for project deployment

The project will be deployed by executing a Deploy pipeline on the production cluster. The Deploy pipeline configuration must once be created using the Pipeline Manager API.

You can find the URL of the Swagger UI for this API on the Solution Envoy Dashboard for your target project under * Infrastructure* on the production cluster. If the destination domain denotes the cluster domain, the URL is usually as follows:

https://{Destination Project}.{Destination Domain}/swagger/-/swagger-ui.html?urls.primaryName=pipeline-manager#/pipeline-controller

The pipeline configuration is set to use the existing image that was previously copied to the production registry, deploy it into the target project and set the image tag. The Deploy pipeline is triggered immediately by creation, but also automatically every time the image has changed in the production registry.

To create the Deploy pipeline configuration, make a POST request on the production cluster using, for example, the * curl* command line tool as shown in the following example:

$ TOKEN=$(oc whoami -t)
$ URL="<https://{Destination> Project}.{Destination Domain}/-/pipelines/v1/-/deploy"
$ curl -k \
    -X POST \
    -d @- \
    -H "Authorization: Bearer $TOKEN" \
    -H 'Accept: application/json' \
    -H 'Content-Type: application/json' \
     $URL <<'EOF'
{
    "pipelineName": "{Pipeline Name}",
    "application": "{Application Group}",
    "autoDeploy": true,
    "inputImageNamespace": "{Destination Project}",
    "inputImageTag": "{Source Tag}",
    "resultImageTag": "{Destination Tag}",
    "skipSolutionTest": true,
    "solutionAcronym": "{Solution Acronym}",
    "solutionType": "ddd"
}
EOF
Note: In this example, replace the placeholder variables {..} as follows:
  • {Destination Project} : The k5-project to which the project should be deployed

  • {Destination Domain} : The domain URL of the production cluster

  • {Pipeline Name} : Name of the Deploy pipeline to be created

  • {Application Tag} : Tag to label a group of projects

  • {Source Tag} : Tag of the image that should be deployed

  • {Destination Tag} : Tag that should be set for the deployed image

  • {Solution Acronym} : project's acronym in capital letters

Expect an HTTP 200/OK message returning the pipeline name.

You can also call the following API methods as needed:

  • Get a pipeline configuration with a GET request

URL="https://{Destination Project}.{Destination Domain}/-/pipelines/v1/{Pipeline Name}"

Expect an HTTP 200/OK message returning the pipeline configuration.

  • Trigger a pipeline with a POST request

URL="https://{Destination Project}.{Destination Domain}/-/pipelines/v1/{Pipeline Name}"

Expect an HTTP 200/OK message returning the pipeline name run.

  • Delete a pipeline with a DELETE request

URL="https://{Destination Project}.{Destination Domain}/-/pipelines/v1/{Pipeline Name}"

Expect an HTTP 204/No content message.

Step 3: Create configuration for production

The need to create a solution-specific configuration for a project arises when the configuration parameters differ across stages and must be adjusted in production and this parameter configuration differs from the default project configuration in production.

This situation is common when the project refers to an API Dependency that was not developed with the IBM Industry Solutions Workbench . For example, to customize this API Dependency in terms of URL and authentication data, you can create an API Binding that contains these parameters by creating a solution-specific configuration for production.

Attention: You might not need a specific API Binding if the named dependency was also developed with IBM Industry Solutions Workbench and you selected Local Lookup in your project when adding the API Dependency. The created configuration must be applied to the project by redeploying the project. To do this, you must trigger the deployment pipeline with a POST request as described in step 2 after you create the configuration.

The solution-specific configuration can be created using the Configuration Management API. You can find the host name of this API by viewing the {configuration_management} route in the {FSW Project} project where you have installed IBM Industry Solutions Workbench on the production cluster. The URL of the Swagger UI is usually as follows:

https://{Config Management Host}/swagger-ui.html#/configuration-controller

To create the solution-specific configuration, make a POST request on the production cluster using, for example, the * curl* command line tool as shown in the following example:

$ TOKEN=$(oc whoami -t)
$ URL="<https://{Config> Management Host}/api/cfg/v1/runtimes/{Destination Project}/solutions/{Solution Acronym}/configurations/{Solution Configuration}"
$ curl -k \
    -X POST \
    -d @- \
    -H "Authorization: Bearer $TOKEN" \
    -H 'Accept: application/json' \
    -H 'Content-Type: application/json' \
     $URL <<'EOF'
{
    "url": "{External API URL}",
    "user": "{API Username}",
    "password": "{API Password}"
}
EOF
Note: In this example, replace the placeholder variables {..} as follows:
  • {Config Management Host} : Host name of the Configuration Management API

  • {External API URL} : URL of the external API

  • {API Username} and {API Password} : Credentials for external API access

Expect an HTTP 201/No content message.

The project had to be deployed already by step 2, since a solution-specific configuration can be created only for an already existing project. You can also call the following API methods as needed:

  • Get a solution-specific configuration with a GET request

URL="https://{Config Management Host}/api/cfg/v1/runtimes/{Destination Project}/solutions/{Solution Acronym}/configurations/{Solution Configuration}"

Expect an HTTP 200/OK message returning the configuration.

  • Get all solution-specific configurations for a project with a GET request

URL="https://{Config Management Host}/api/cfg/v1/runtimes/{Destination Project}/solutions/{Solution Acronym}/configurations"

Expect an HTTP 200/OK message returning the configurations.

  • Delete a solution-specific configuration with a DELETE request

URL="https://{Config Management Host}/api/cfg/v1/runtimes/{Destination Project}/solutions/{Solution Acronym}/configurations/{Solution Configuration}"

Expect an HTTP 204/No content message.