Provision a service instance

To deploy an IBM® Db2® as a Service service, you need to create a IBM Db2 SaaS service instance.

You can provision a deployment by visiting the service's catalog page or by specifying the service ID to the command line, or to the API. The deployment type is determined by the service ID, which you must specify when you create a IBM Db2 SaaS deployment by using the command line or API.

Deployment Type Catalog Page Service ID Plan IDs
IBM Db2 SaaS Link dashdb-for-transactions dashDBNebula, dashDBStandard

Using the catalog

When you create the deployment from the catalog, you need to specify the following parameters.

  1. Service name - The name can be any string and is the name that is used on the web and in the command line to identify the new deployment.

  2. Region - The region in which the deployment resides.

  3. Backup Location - The location of the deployment's backups. Users can choose Cross Regional or Regional backups. Cross Regional backups can be stored across multiple regions in one zone. Whereas, Regional backups can be stored in one region only.

  4. Resource group - If you are organizing your services into resource groups, you can specify the resource group in this field. Otherwise, you can leave it at default.

  5. KMS instance and disk encryption key - If you use Key Protect or Hyper Protect Crypto Services, an instance and key can be selected to encrypt the deployment's disk. If you do not use your own key, the deployment automatically creates and manages its own disk encryption key using the Key Protect service. If you would like to use HPCS for encryption, you must provision an HPCS instance and generate or import a key. Currently, HPCS is not EU-Cloud enabled.

  6. Backup Encryption Key - If you use Backup Encyrption Key, you can provide your own KMS instance and key in order to encrypt your backups. This is an optional parameter, and if not provided the default KMS instance and key will be used.

  7. CPU allocation - Choose dedicated compute resources for your deployment. With dedicated cores, your resource group is given a single-tenant host with a guaranteed minimum reserve of cpu shares. Your deployments are then allocated the number of CPUs you specify. This defaults to the standard plan if not specified in the provisioning request by using the API or CLI.

  8. Endpoints - You can configure the types Service Endpoints on your deployment. The default is that connections to your deployment can be made from the public network.

  9. High Availability - whether the services should be Highly Available

  10. Oracle compatibility - whether the service instance should have Oracle compatibility enabled

After selecting the appropriate settings, click Create to start the provisioning process.

Using the command line

The IBM Cloud CLI tool is what you use to communicate with IBM Cloud from your terminal or command line. For more information, see Download and install IBM Cloud CLI.

To create a Cloud Databases deployment, you use the CLI to request a service instance with the service ID of the database (or messaging queue) that you want to provision.

Run the following command template:

ibmcloud resource service-instance-create <service-name> <service-id> <service-plan-id> <region> --service-endpoints <SERVICE_ENDPOINTS_TYPE>

More general information about this command is available in the CLI reference for resource groups.

When the command is run, the database deployment begins. The database takes some time to deploy. You can check on its progress on your IBM Cloud dashboard or you can run the following command:

ibmcloud resource service-instance-create <service-name>

This command reports the current state of the service instance.

Additional flags and parameters

The --service-endpoints flag allows you to specify which types of service endpoints to include in your deployment. Its default is that connections to your deployment can be made from the public network. Possible values are public, private, public-and-private. If the flag is omitted, the default is a public endpoint.

The following example command specifies a service endpoint:

ibmcloud resource service-instance-create <service-name> --service-endpoints <endpoint-type>

The service-instance-create command supports a -p flag, which allows additional parameters to be passed to the provisioning process. The parameters are in JSON format. One such parameter value is the Cloud Resource Name (CRN), which uniquely identifies a resource in the cloud. All parameter names and values are passed as strings.

Provisioning through the Resource Controller API

You can provision new deployments by using the Resource Controller API. However, in order to use the Resource Controller API, you need some additional preparation.

  1. Obtain an IAM token from your API token.

  2. You must know the ID of the resource group to which you would like to deploy. This information is available through the IBM Cloud CLI. You can find a list of resource groups with ibmcloud resource groups and the ID of a resource group with ibmcloud resource group.

  3. You must know the region to which you would like to deploy.

After you have all of the information, the following create request is a POST to the https://resource-controller.cloud.ibm.com/v2/resource_instances endpoint:

curl -X POST \
  https://resource-controller.cloud.ibm.com/v2/resource_instances \
  -H 'Authorization: Bearer <>' \
  -H 'Content-Type: application/json' \
    -d '{
    "name": "my-instance",
    "target": "bluemix-us-south",
    "resource_group": "5g9f447903254bb58972a2f3f5a4c711",
    "resource_plan_id": "dash
  }'

The parameters name, target, resource_group, and resource_plan_id are all required. If needed, you can send additional parameters in the request body.

More information on the Resource Controller API is found in its API Reference.

List of additional parameters

  • backup_id - A CRN of a backup resource to restore from. The backup must have been created by a database deployment with the same service ID. The backup is loaded after provisioning and the new deployment starts up that uses that data. A backup CRN is in the format crn:v1:<...>:backup:<uuid>. If omitted, the database is provisioned empty.

  • backup_location - The location of the deployment's backups.

  • disk_encryption_key_crn - The CRN of a KMS key, which is then used for disk encryption. A KMS CRN is in the format crn:v1:<...>:key:<id>.

  • backup_encryption_key_crn - The CRN of a KMS key, which is then used for backup encryption. A KMS CRN is in the format crn:v1:<...>:key:<id>. To use a key for your backups, you must first enable the service-to-service delegation.

  • members_cpu_allocation_count - Enables and allocates the number of specified dedicated cores to your deployment. For example, to use two dedicated cores per member, use "members_cpu_allocation_count":"2". If omitted, the default value "Shared CPU" uses compute resources on shared hosts.

  • service-endpoints - Selects the types Service Endpoints supported on your deployment. Options are public, private, or public-and-private. If omitted, the default is public. Note that in the CLI, service-endpoints is a flag, and not a parameter.