This page describes how to create an AlloyDB cluster and its primary instance.
Before you begin
- The Google Cloud project you are using must have been enabled to access AlloyDB.
- A VPC network in the Google Cloud project that you are using must already be configured for private services access to AlloyDB.
- You must have one of these IAM roles in the Google Cloud project you are using:
roles/alloydb.admin
(the AlloyDB Admin predefined IAM role)roles/owner
(the Owner basic IAM role)roles/editor
(the Editor basic IAM role)
If you don't have any of these roles, contact your Organization Administrator to request access.
- You must also have the
compute.networks.list
permission in the Google Cloud project you are using. To gain this permission while following the principle of least privilege, ask your administrator to grant you theroles/compute.networkUser
(Compute Network User) role.
Create a new cluster
Console
Go to the Clusters page.
Click Create cluster.
Choose a cluster configuration. For more information about the difference between highly available and basic configurations, see Nodes and instances.
If you're not sure whether your new cluster needs read pool instances, choose one of the configurations with no read pools. You can add read pool instances to the cluster later, whenever needed.
Click Continue.
In the Configure your cluster section, in the Cluster ID field, enter an ID for your cluster.
In the Password field, enter an initial password for the new cluster. AlloyDB assigns the provided password to the
postgres
database user while creating the cluster.In the Database version field, select the major version of PostgreSQL that you want the cluster's database servers to be compatible with.
Select a region.
Select a network path.
Optional: To apply a specific IP address range to this cluster, instead of allowing AlloyDB to choose an IP address range, follow these steps:
Click Show allocated IP range option.
From the Allocated IP range list, select an IP address range.
For more information about this option, see Create a cluster with a specific IP address range.
Optional: To encrypt this cluster using a customer-managed encryption key (CMEK) instead of Google-managed encryption, follow these additional steps:
Click Advanced encryption options.
Select Customer-managed encryption key (CMEK).
In the menu that appears, select a customer-managed key.
The Google Cloud console limits this list to keys within the same Google Cloud project and region as the new cluster. To use a key that is not on this list, click Don't see your key? Enter key resource name, and then type the key's resource name into the resulting dialog.
Note that using CMEK with AlloyDB requires some additional setup. For more information, see Using CMEK with AlloyDB.
Click Continue.
Configure your primary instance:
- In the Instance ID field, enter an ID for your primary instance.
- Select a machine type.
- Optional: Set custom flags for your instance. For each flag,
follow these steps:
- Click Add flag.
- In the New database flag list, select a flag.
- Provide a value for the flag.
- Click Done.
If you chose a cluster type without read pools, click Create cluster. Otherwise, continue to the next step.
If you chose a cluster type with read pools, complete the following steps:
- Click Continue to add one or more read pool instances.
To add a read pool instance:
Click Add read pool.
In the Read pool instance ID field, enter an ID for the read pool instance.
In the Node count field, enter a node count.
The number of nodes in a read pool instance determines the instance's overall computing capacity.
Select a machine type.
Optional: Set custom flags to your instance. For each flag:
- Click Add flag.
- Select a flag from the New database flag list.
- Provide a value for the flag.
- Click Done.
Click Add read pool.
Click Create cluster.
gcloud
To use the gcloud CLI, you can install and initialize the Google Cloud CLI, or you can use Cloud Shell.
To create the cluster with either private service access or Private Service Connect enabled, use the
gcloud alloydb clusters create
command.Private services access
gcloud alloydb clusters create CLUSTER_ID \ --database-version=POSTGRES_VERSION \ --password=PASSWORD \ --region=REGION_ID \ --project=PROJECT_ID \ --network=NETWORK
Private Service Connect
gcloud alloydb clusters create CLUSTER_ID \ --database-version=POSTGRES_VERSION \ --password=PASSWORD \ --region=REGION_ID \ --project=PROJECT_ID \ --enable-private-service-connect
Replace the following:
CLUSTER_ID
: the ID of the cluster that you are creating. It must begin with a lowercase letter and can contain lowercase letters, numbers, and hyphens.VERSION
: the major version of PostgreSQL that you want the cluster's database servers to be compatible with. Choose one of the following:14
, for compatibility with PostgreSQL 1415
, for compatibility with PostgreSQL 15, which is the default PostgreSQL version supported16
, for compatibility with PostgreSQL 16
PASSWORD
: the password to use for the defaultpostgres
user.NETWORK
(Optional): the name of the VPC network that you configured for private services access to AlloyDB. If you omit the--network
flag, AlloyDB uses thedefault
network.--enable-private-service-connect
(Optional): set to enable Private Service Connect as the connectivity method for the cluster and its instances.REGION_ID
: the region where you want the cluster placed.PROJECT_ID
: the ID of the project where you want the cluster placed.
This command initiates a long-running operation, returning an operation ID.
Optional: To apply a specific IP address range to this cluster, instead of allowing AlloyDB to choose an IP address range, provide the following argument:
--allocated-ip-range-name=RANGE
Replace
RANGE
with the name of the IP address range that you want this cluster to use for private services access.For more information about this option, see Create a cluster with a specific IP address range.
Optional: To encrypt this cluster using a customer-managed encryption key (CMEK) instead of the default Google-managed encryption, provide the following arguments:
--kms-key=KEY_ID \ --kms-keyring=KEYRING_ID \ --kms-location=LOCATION_ID \ --kms-project=PROJECT_ID
Replace the following:
KEY_ID
: the ID of the CMEK key to use.KEYRING_ID
: the ID of the key's key ring.LOCATION_ID
: the ID of the key ring's region, which must be the same as the cluster's region.PROJECT_ID
: the ID of the key ring's project.
Confirm that the operation was successful.
gcloud alloydb operations describe OPERATION_ID \ --region=REGION_ID \ --project=PROJECT_ID
Replace
OPERATION_ID
with the operation ID that was returned from the previous step.
After creating the primary cluster, you must create a primary instance.
Create a primary instance
To create a primary instance, use the gcloud alloydb
instances create
command.
gcloud alloydb instances create INSTANCE_ID \
--instance-type=PRIMARY \
--cpu-count=CPU_COUNT \
--region=REGION_ID \
--cluster=CLUSTER_ID \
--project=PROJECT_ID \
--allowed-psc-projects=ALLOWED_PROJECT_LIST
Replace the following:
INSTANCE_ID
: the ID of the instance you are creating. It must begin with a lowercase letter and can contain lowercase letters, numbers, and hyphens.CPU_COUNT
: the number of vCPUs you want for the instance. Valid values include the following:2
: 2 vCPUs, 16 GB RAM4
: 4 vCPUs, 32 GB RAM8
: 8 vCPUs, 64 GB RAM16
: 16 vCPUs, 128 GB RAM32
: 32 vCPUs, 256 GB RAM64
: 64 vCPUs, 512 GB RAM96
: 96 vCPUs, 768 GB RAM128
: 128 vCPUs, 864 GB RAM
REGION_ID
: the region where you want the instance placed.CLUSTER_ID
: the ID of the cluster you created earlier.PROJECT_ID
: the ID of the project where the clusterALLOWED_PROJECT_LIST
(Optional): the comma separated list of project IDs or project number that you want to allow access the instance, if using Private Service Connect.
Terraform
To create a cluster, use a Terraform resource.
The following is code snippet of creating a cluster based on the AlloyDB cluster full example:
resource "google_alloydb_cluster" "cluster_abc" {
cluster_id = "alloydb-cluster"
location = "us-central1"
network_config {
network = google_compute_network.default.id
}
database_version = "POSTGRES_15"
initial_user {
user = "postgres"
password = "postgres"
}
continuous_backup_config {
enabled = true
recovery_window_days = 14
}
automated_backup_policy {
location = "us-central1"
backup_window = "1800s"
enabled = true
weekly_schedule {
days_of_week = ["MONDAY"]
start_times {
hours = 23
minutes = 0
seconds = 0
nanos = 0
}
}
quantity_based_retention {
count = 1
}
labels = {
test = "alloydb-cluster-backup-policy-labels"
}
}
labels = {
test = "alloydb-cluster-labels"
}
}
data "google_project" "project" {}
resource "google_compute_network" "default" {
name = "alloydb-cluster-network"
}
Prepare Cloud Shell
To apply your Terraform configuration in a Google Cloud project, prepare Cloud Shell as follows:
- Launch Cloud Shell.
Set the default Google Cloud project where you want to apply your Terraform configurations.
You only need to run this command once per project, and you can run it in any directory.
export GOOGLE_CLOUD_PROJECT=PROJECT_ID
Environment variables are overridden if you set explicit values in the Terraform configuration file.
Prepare the directory
Each Terraform configuration file must have its own directory, also called a root module.
- In Cloud Shell, create a directory and a new
file within that directory. The filename must be a
TF file—for example,
main.tf
. In this document, the file is referred to asmain.tf
.mkdir DIRECTORY && cd DIRECTORY && touch main.tf
- Copy the sample code into the newly created
main.tf
. Optionally, copy the code from GitHub. This is recommended when the Terraform snippet is part of an end-to-end solution. - Review the
main.tf
file and modify the sample parameters to apply to your environment. - Save your changes.
- Initialize Terraform. You only need to do this once per directory.
Optional: To use the latest Google provider version, include theterraform init
-upgrade
option:terraform init -upgrade
Apply the changes
- Review the configuration to confirm that the Terraform updates match your expectations:
Make corrections to the configuration as necessary.terraform plan
- Apply the Terraform configuration by running the following command and entering
yes
at the prompt: Wait until Terraform displays theterraform apply
Apply complete!
message. - Open your Google Cloud project to view the results. In the Google Cloud console, navigate to your resources in the UI to make sure that Terraform has created or updated them.
Clone an active cluster
To create a clone of an active cluster, containing a copy of all the source cluster's data and running in the same region, perform a point-in-time recovery on that cluster. You can specify a very recent point in time when doing so—for example, the first second of the current minute.
This process copies only the source cluster's data into the clone—not any of the source cluster's configuration. To encrypt the clone's data using CMEK, you need to specify CMEK details as part of the point-in-time recovery command, even if the source cluster's data is already CMEK-encrypted. After the new cluster is created, you need to add instances, database flags, backup schedules, and any other configuration necessary to suit your needs.
A cluster created this way exists independently of its source, with its data having no relationship to the source cluster's data after the initial duplication has completed. If you want to create secondary clusters that automatically track and replicate data changes made in their source clusters, see About cross-region replication.
Create a cluster with a specific IP address range
AlloyDB uses private services access to allow a cluster's internal resources to communicate with each other. Before you can create a cluster, your Virtual Private Cloud (VPC) network must contain at least one IP address range configured with a private services access connection.
If your VPC network contains more than one IP address range that has been configured with private services access, then you have the option to specify the range that AlloyDB assigns to a new cluster.
To specify an IP address range, see the optional steps in Create a cluster.
If you don't specify a range, then AlloyDB takes one of the following actions while creating a cluster:
If you have multiple IP address ranges with private services access available, then AlloyDB chooses one of those ranges.
If you have set up exactly one IP address range in your VPC with private services access, then AlloyDB applies that range to the new cluster.
For more information about creating IP address ranges for use with AlloyDB, see Enable private services access.