Provision a Databases for MongoDB Enterprise Edition instance with Terraform
In this tutorial, you learn how to use Terraform to provision a Databases for MongoDB Enterprise Edition instance that includes the Databases for MongoDB Enterprise Edition Analytics Add-On. The Databases for MongoDB EE Analytics Add-On allows you to run long-running analytical queries and/or provision a MongoDB Connector for business intelligence(BI) to make your query data compatible with BI tools, such as Tableau.
Overview of the available tools
Before beginning the process of provisioning a database with Terraform, you need to have an IBM Cloud account.
In this tutorial, you provision your database by using Terraform, a service that enables you to safely and predictably create, change, and improve infrastructure. It is an open source tool that codifies APIs into declarative configuration files that can be shared among team members, which are treated as code, edited, reviewed, and versioned. It is infrastructure as code. You write down what your infrastructure should look like and Terraform will create, update, and remove cloud resources as needed. For more information, see Understand the basics of Terraform.
To support a multi-cloud approach, Terraform works with providers. A provider is responsible for understanding API interactions and exposing resources. IBM Cloud® has its provider for Terraform, enabling users of IBM Cloud® to manage resources with Terraform. Although Terraform is categorized as infrastructure as code, it is not limited to Infrastructure-As-A-Service resources. For more information, see ibm_database.
Step 1: Install Terraform
Follow the steps at Install Terraform to install Terraform.
Step 2: Configure the IBM Cloud® Provider plug-in
-
Create or retrieve an IBM Cloud® API key. The API key is used to authenticate with the IBM Cloud® platform and to determine your permissions for IBM Cloud® services.
-
Create a Terraform on IBM Cloud Databases project directory. The directory holds all your configuration files that you create as part of this tutorial. The directory in this tutorial is named
tf-mongodbee
, but you can use any name for the directory.mkdir tf-mongodbee && cd tf-mongodbee
-
In your project directory, create a variable definition file that is named
terraform.tfvars
and specify the IBM Cloud API key that you retrieved. In addition, you specify the region where you want your IBM Cloud resources to be created. If no region is specified, the IBM Cloud® Provider plug-in automatically creates your resources in the us-south region. Variables that are defined in theterraform.tfvars
file are automatically loaded by Terraform when the IBM Cloud Provider plug-in is initialized and you can reference them in every Terraform configuration file that you use.Because the variable definitions file contains confidential information, do not push this file to a version control system. This file is meant to be on your local system only.
Example
terraform.tfvars
fileibmcloud_api_key = "<IBMCLOUD_API_KEY>" region = "us-east"
The
us-east
region is provided as an example, not a requirement. Use the region that works best for your instance deployment. -
Create a provider configuration file that is named
provider.tf
. Use this file to configure the IBM Cloud Provider plug-in with the IBM Cloud API key from yourterraform.tfvars
file. The plug-in uses this key to access IBM Cloud and to work with your IBM Cloud service. To access a variable value from theterraform.tfvars
file, you must first declare the variable in theprovider.tf
file and then reference the variable by using thevar.<variable_name>
syntax.Example
provider.tf
fileterraform { required_providers { ibm = { source = "IBM-Cloud/ibm" version = ">= 1.28.0" } } } variable "ibmcloud_api_key" {} variable "region" {} provider "ibm" { ibmcloud_api_key = var.ibmcloud_api_key region = var.region }
Step 3: Provision a Databases for MongoDB instance
In the same project directory, create a Terraform configuration file named mongodbee.tf
.
Example mongodbee.tf
file
data "ibm_resource_group" "mongodbee_tutorial" {
is_default = true
}
resource "ibm_database" "mongodbee_db" {
resource_group_id = data.ibm_resource_group.mongodbee_tutorial.id
name = "terraform_mongodbee"
service = "databases-for-mongodb"
plan = "enterprise"
location = "us-east"
service_endpoints = "public"
adminpassword = "password123changeme"
group {
group_id = "member"
host_flavor {
id = "b3c.4x16.encrypted"
}
disk {
allocation_mb = 20480
}
}
group {
group_id = "analytics"
members {
allocation_count = 1
}
}
group {
group_id = "bi_connector"
members {
allocation_count = 1
}
}
timeouts {
create = "120m"
update = "120m"
delete = "15m"
}
}
data "ibm_database_connection" "mongodbee_conn" {
deployment_id = resource.ibm_database.mongodbee_db.id
user_id = resource.ibm_database.mongodbee_db.adminuser
user_type = "database"
endpoint_type = "public"
}
output "bi_connector_connection" {
description = "BI Connector connection string"
value = data.ibm_database_connection.mongodbee_conn.bi_connector.0.composed.0
}
output "analytics_connection" {
description = "Analytics Node connection string"
value = data.ibm_database_connection.mongodbee_conn.analytics.0.composed.0
}
- Resource group - the Resource Group value you declare.
- Name - The service name can be any string and is the name that is used on the web and in the CLI to identify the new deployment.
- Service - For Databases for MongoDB, the service ID is
databases-for-mongodb
. Choose the correct Service ID for your deployment. - Plan - This tutorial uses a Standard plan. For more information, see IBM Cloud® Pricing.
- Location - Choose a suitable region for your deployment instance.
- Service endpoints - Choose the service endpoints for your deployment instance. "private" is recommended for production use.
- Admin password - You must set the admin password before you can use it to connect. For more information, see Setting the Admin password.
- Group Scaling groups represent the various resources that are allocated to a deployment. To see an example for configuring and deploying a database that uses
group
attributes, seSample database instance by using group attributes.{external} - Group values - Memory, disk, and CPU values are all based on minimum requirements for provisioning a Databases for MongoDB instance.
- Timeouts - Create, update, and delete values for this resource. Cloud Databases
create
typically takes between 30-45 minutes.delete
andupdate
typically take 1 minute. Provisioning times are unpredictable. If the deployment fails due to a timeout, import the database resource once thecreate
is complete.
Step 4: Test your configuration
Now that you configured the IBM Cloud® Provider plug-in for your resource, you can use Terraform to initialize, run, plan, and apply commands to provision the resource. You need the following commands:
Command Description | Command |
---|---|
terraform init |
The terraform init command is used to initialize a working directory containing Terraform configuration files. |
terraform fmt |
The terraform fmt command is used to rewrite Terraform configuration files to a canonical format and style. |
terraform validate |
The terraform validate command validates the configuration files in a directory |
terraform apply |
The terraform apply command runs the actions that are proposed in a Terraform plan. |
For more information, see Provisioning IBM Cloud® resources.
To view sample Terraform templates with the complete Terraform configuration files to test, see Sample templates.
For an overview of Terraform resources and data sources, see Index of Terraform on IBM Cloud® resources and data sources.