This page describes how to enable, configure, and monitor Managed Connection Pooling in your Cloud SQL instances.
Managed Connection Pooling lets you scale your workloads by optimizing resource utilization and connection latency for your instances using pooling. For detailed information about Managed Connection Pooling and how to use it for your instances, see Managed Connection Pooling overview.
Before you begin
- Confirm that your instance meets all requirements to use Managed Connection Pooling.
- If you're using gcloud CLI, then confirm that your gcloud CLI
version is
515.0.0
or later. - Confirm that your instance is using the new Cloud SQL network architecture. If your instance is still using the old network architecture, then upgrade to the new network architecture.
- Confirm that your instance has the required server connections per vCPU
allocated in the
max_connections
flag for your database's configuration settings. For more information, see Server connections used by Managed Connection Pooling.
Enable Managed Connection Pooling
You can enable Managed Connection Pooling for an instance at time of creation, or edit an existing instance to enable it.
Enable Managed Connection Pooling for a new instance
To create a new instance with Managed Connection Pooling enabled, see Create instances. You can enable Managed Connection Pooling for a new instance using gcloud CLI or the Cloud SQL API only.
Enable Managed Connection Pooling for an existing instance
To enable Managed Connection Pooling for an existing instance, do the following:
Console
In the Cloud de Confiance console, go to the Cloud SQL Instances page.
Find the instance you want to enable Managed Connection Pooling for. To open the Overview page of the instance, click the instance name.
Click Edit.
Under Customize your instance, expand Connections.
To enable Managed Connection Pooling, check the box for Enable Managed Connection Pool.
Click Save.
gcloud
Use the gcloud sql instances
command to enable Managed Connection Pooling.
gcloud sql instances patch INSTANCE_NAME \
--enable-connection-pooling
Replace the following:
INSTANCE_NAME
: the name of the Cloud SQL instance.
REST v1
Use the following command and set connectionPoolingEnabled
:
Before using any of the request data, make the following replacements:
- PROJECT_ID: the project ID
- INSTANCE_ID: the instance ID
HTTP method and URL:
PATCH https://sqladmin.googleapis.com/v1/projects/PROJECT_ID/instances/INSTANCE_ID
Request JSON body:
{ "settings": { "connectionPoolConfig": { "connectionPoolingEnabled": true } } }
To send your request, expand one of these options:
You should receive a JSON response similar to the following:
{ "kind": "sql#operation", "targetLink": "https://sqladmin.googleapis.com/v1/projects/%3Cvar%20translate="no">PROJECT_ID/instances/INSTANCE_ID", "status": "PENDING", "user": "[email protected]", "insertTime": "2020-01-16T02:32:12.281Z", "operationType": "UPDATE", "name": "OPERATION_ID", "targetId": "INSTANCE_ID", "selfLink": "https://sqladmin.googleapis.com/v1/projects/%3Cvar%20translate="no">PROJECT_ID/operations/OPERATION_ID", "targetProject": "PROJECT_ID" }
REST v1beta4
Use the following command and set connectionPoolingEnabled
:
Before using any of the request data, make the following replacements:
- PROJECT_ID: the project ID
- INSTANCE_ID: the instance ID
HTTP method and URL:
PATCH https://sqladmin.googleapis.com/sql/v1beta4/projects/PROJECT_ID/instances/INSTANCE_ID
Request JSON body:
{ "settings": { "connectionPoolConfig": { "connectionPoolingEnabled": true } } }
To send your request, expand one of these options:
You should receive a JSON response similar to the following:
{ "kind": "sql#operation", "targetLink": "https://sqladmin.googleapis.com/sql/v1/projects/%3Cvar%20translate="no">PROJECT_ID/instances/INSTANCE_ID", "status": "PENDING", "user": "[email protected]", "insertTime": "2020-01-16T02:32:12.281Z", "operationType": "UPDATE", "name": "OPERATION_ID", "targetId": "INSTANCE_ID", "selfLink": "https://sqladmin.googleapis.com/sql/v1/projects/%3Cvar%20translate="no">PROJECT_ID/operations/OPERATION_ID", "targetProject": "PROJECT_ID" }
Terraform
Use the following Terraform resource:
Modify Managed Connection Pooling for an instance
After you enable Managed Connection Pooling, you can customize Managed Connection Pooling to meet the needs of your instance using advanced configuration options. These configuration options are called Managed Connection Pooling pool flags. Configurations added to Managed Connection Pooling are applied to all connection poolers used by the instance. For more information on the advanced configuration options, their default values, and ranges, see Advanced configurations options.
To modify the advanced Managed Connection Pooling configuration options for an instance, do the following:
Console
In the Cloud de Confiance console, go to the Cloud SQL Instances page.
Find the instance you want to enable Managed Connection Pooling for. To open the Overview page of the instance, click the instance name.
Click Edit.
Under Customize your instance, expand Connections.
Under Managed connection pool, expand Advanced pooling options.
Modify the advanced pooling options that you want to update.
Click Save.
gcloud
Use the gcloud sql instances
command to modify configuration options.
gcloud sql instances patch INSTANCE_NAME \
--connection-pool-flags=CONFIGURATION_NAME=CONFIGURATION_VALUE
Replace the following:
INSTANCE_NAME
: the name of the Cloud SQL instance.CONFIGURATION_NAME
: the name of the configuration option. For a list of all advanced configuration options, see Advanced configurations options.CONFIGURATION_VALUE
: the new value for the selected configuration option.
REST v1
To modify Managed Connection Pooling
Advanced configurations,
use the following command and set ConnectionPoolConfig
:
Before using any of the request data, make the following replacements:
- PROJECT_ID: the project ID
- INSTANCE_ID: the instance ID
HTTP method and URL:
PATCH https://sqladmin.googleapis.com/v1/projects/PROJECT_ID/instances/INSTANCE_ID
Request JSON body:
{ "settings": { "connectionPoolConfig": { "flags": [ { "name": "CONFIGURATION_NAME", "value":"CONFIGURATION_VALUE" } ] } } }
To send your request, expand one of these options:
You should receive a JSON response similar to the following:
{ "kind": "sql#operation", "targetLink": "https://sqladmin.googleapis.com/v1/projects/%3Cvar%20translate="no">PROJECT_ID/instances/INSTANCE_ID", "status": "PENDING", "user": "[email protected]", "insertTime": "2020-01-16T02:32:12.281Z", "operationType": "UPDATE", "name": "OPERATION_ID", "targetId": "INSTANCE_ID", "selfLink": "https://sqladmin.googleapis.com/v1/projects/%3Cvar%20translate="no">PROJECT_ID/operations/OPERATION_ID", "targetProject": "PROJECT_ID" }
REST v1beta4
To modify Managed Connection Pooling
Advanced configurations,
use the following command and set ConnectionPoolConfig
:
Before using any of the request data, make the following replacements:
- PROJECT_ID: the project ID
- INSTANCE_ID: the instance ID
HTTP method and URL:
PATCH https://sqladmin.googleapis.com/sql/v1beta4/projects/PROJECT_ID/instances/INSTANCE_ID
Request JSON body:
{ "settings": { "connectionPoolConfig": { "flags": [ { "name": "CONFIGURATION_NAME", "value":"CONFIGURATION_VALUE" } ] } } }
To send your request, expand one of these options:
You should receive a JSON response similar to the following:
{ "kind": "sql#operation", "targetLink": "https://sqladmin.googleapis.com/sql/v1/projects/%3Cvar%20translate="no">PROJECT_ID/instances/INSTANCE_ID", "status": "PENDING", "user": "[email protected]", "insertTime": "2020-01-16T02:32:12.281Z", "operationType": "UPDATE", "name": "OPERATION_ID", "targetId": "INSTANCE_ID", "selfLink": "https://sqladmin.googleapis.com/sql/v1/projects/%3Cvar%20translate="no">PROJECT_ID/operations/OPERATION_ID", "targetProject": "PROJECT_ID" }
Terraform
To modify Managed Connection Pooling Advanced configurations, use the following Terraform resource:
Disable Managed Connection Pooling for an instance
You can disable Managed Connection Pooling for an existing instance using the Cloud de Confiance console, gcloud CLI, or the Cloud SQL API.
To disable Managed Connection Pooling for an instance, do the following:
Console
In the Cloud de Confiance console, go to the Cloud SQL Instances page.
Find the instance you want to disable Managed Connection Pooling for. To open the Overview page of the instance, click the instance name.
Click Edit.
Under Customize your instance, expand Connections.
To disable Managed Connection Pooling, clear the box for Enable Managed Connection Pool.
Click Save.
gcloud
Use the gcloud sql instances
command to disable Managed Connection Pooling.
gcloud sql instances patch INSTANCE_NAME \
--no-enable-connection-pooling
Replace the following:
PROJECT_ID
: the name of the Cloud SQL instance.
REST v1
To disable Managed Connection Pooling for an instance, use the following
command and set connectionPoolingEnabled
:
Before using any of the request data, make the following replacements:
- PROJECT_ID: the project ID
- INSTANCE_ID: the instance ID
HTTP method and URL:
PATCH https://sqladmin.googleapis.com/v1/projects/PROJECT_ID/instances/INSTANCE_ID
Request JSON body:
{ "settings": { "connectionPoolConfig": { "connectionPoolingEnabled": false } } }
To send your request, expand one of these options:
You should receive a JSON response similar to the following:
{ "kind": "sql#operation", "targetLink": "https://sqladmin.googleapis.com/v1/projects/%3Cvar%20translate="no">PROJECT_ID/instances/INSTANCE_ID", "status": "PENDING", "user": "[email protected]", "insertTime": "2020-01-16T02:32:12.281Z", "operationType": "UPDATE", "name": "OPERATION_ID", "targetId": "INSTANCE_ID", "selfLink": "https://sqladmin.googleapis.com/v1/projects/%3Cvar%20translate="no">PROJECT_ID/operations/OPERATION_ID", "targetProject": "PROJECT_ID" }
REST v1beta4
To disable Managed Connection Pooling for an instance, use the following
command and set connectionPoolingEnabled
:
Before using any of the request data, make the following replacements:
- PROJECT_ID: the project ID
- INSTANCE_ID: the instance ID
HTTP method and URL:
PATCH https://sqladmin.googleapis.com/sql/v1beta4/projects/PROJECT_ID/instances/INSTANCE_ID
Request JSON body:
{ "settings": { "connectionPoolConfig": { "connectionPoolingEnabled": false } } }
To send your request, expand one of these options:
You should receive a JSON response similar to the following:
{ "kind": "sql#operation", "targetLink": "https://sqladmin.googleapis.com/sql/v1/projects/%3Cvar%20translate="no">PROJECT_ID/instances/INSTANCE_ID", "status": "PENDING", "user": "[email protected]", "insertTime": "2020-01-16T02:32:12.281Z", "operationType": "UPDATE", "name": "OPERATION_ID", "targetId": "INSTANCE_ID", "selfLink": "https://sqladmin.googleapis.com/sql/v1/projects/%3Cvar%20translate="no">PROJECT_ID/operations/OPERATION_ID", "targetProject": "PROJECT_ID" }
Terraform
To disable Managed Connection Pooling for an instance, use the following Terraform resource:
View Managed Connection Pooling status for an instance
You can view the status of Managed Connection Pooling for an instance using the Cloud de Confiance console, gcloud CLI, or the Cloud SQL API.
To view the status of Managed Connection Pooling for a Cloud SQL Enterprise Plus edition instance, do the following:
Console
In the Cloud de Confiance console, go to the Cloud SQL Instances page.
Find the instance you want to view the Managed Connection Pooling status for. To open the Overview page of the instance, click the instance name.
The Connections section shows whether Managed Connection Pooling is enabled or disabled.
gcloud
Use the gcloud sql instances describe command to view Managed Connection Pooling status for an instance:
gcloud sql instances describe INSTANCE_NAME
--format="value(settings.connectionPoolConfig.connectionPoolingEnabled)"
Replace the following:
PROJECT_ID
: the name of the Cloud SQL instance.If Managed Connection Pooling is enabled, the following response is returned:
connectionPoolingEnabled: true
REST v1
To view the status of Managed Connection Pooling for your Cloud SQL
instance, use the following command and look for connectionPoolingEnabled
:
Before using any of the request data, make the following replacements:
- PROJECT_ID: the ID or project number of the Cloud de Confiance project that contains the instance.
- INSTANCE_NAME: the name of the Cloud SQL instance. If this instance has Private Service Connect enabled for it, then Private Service Connect endpoints in VPC networks can connect to it.
HTTP method and URL:
GET https://sqladmin.googleapis.com/v1/projects/PROJECT_ID/instances/INSTANCE_NAME
To send your request, expand one of these options:
You should receive a JSON response similar to the following:
{ "kind": "sql#instance", "state": "RUNNABLE", "databaseVersion": "POSTGRES_13", "settings": { "authorizedGaeApplications": [], "tier": "db-custom-2-7680", "kind": "sql#settings", "availabilityType": "REGIONAL", "pricingPlan": "PER_USE", "replicationType": "SYNCHRONOUS", "activationPolicy": "ALWAYS", "ipConfiguration": { "authorizedNetworks": [], "pscConfig": { "allowedConsumerProjects": [ "ALLOWED_PROJECTS" ], "pscEnabled": true }, "ipv4Enabled": false }, ... "createTime": "2023-06-14T18:48:34.975Z", "sqlNetworkArchitecture": "NEW_NETWORK_ARCHITECTURE", "pscServiceAttachmentLink": "projects/PROJECT_ID/regions/REGION_NAME/serviceAttachments/SERVICE_ATTACHMENT_ID", "dnsName": "DNS_NAME" }
REST v1beta4
To view the status of Managed Connection Pooling for your Cloud SQL
instance, use the following command and look for connectionPoolingEnabled
:
Before using any of the request data, make the following replacements:
- PROJECT_ID: the ID or project number of the Cloud de Confiance project that contains the instance.
- INSTANCE_NAME: the name of the Cloud SQL instance. If this instance has Private Service Connect enabled for it, then Private Service Connect endpoints in VPC networks can connect to it.
HTTP method and URL:
GET https://sqladmin.googleapis.com/sql/v1beta4/projects/PROJECT_ID/instances/INSTANCE_NAME
To send your request, expand one of these options:
You should receive a JSON response similar to the following:
{ "kind": "sql#instance", "state": "RUNNABLE", "databaseVersion": "POSTGRES_13", "settings": { "authorizedGaeApplications": [], "tier": "db-custom-2-7680", "kind": "sql#settings", "availabilityType": "REGIONAL", "pricingPlan": "PER_USE", "replicationType": "SYNCHRONOUS", "activationPolicy": "ALWAYS", "ipConfiguration": { "authorizedNetworks": [], "pscConfig": { "allowedConsumerProjects": [ "ALLOWED_PROJECTS" ], "pscEnabled": true }, "ipv4Enabled": false }, ... "createTime": "2023-06-14T18:48:34.975Z", "sqlNetworkArchitecture": "NEW_NETWORK_ARCHITECTURE", "pscServiceAttachmentLink": "projects/PROJECT_ID/regions/REGION_NAME/serviceAttachments/SERVICE_ATTACHMENT_ID", "dnsName": "DNS_NAME" }
Monitor Managed Connection Pooling
You can monitor how Managed Connection Pooling is running on your Cloud SQL instances using the following Cloud SQL Managed Connection Pooling metrics:
Metric name | Description |
---|---|
num_pools | The total number of connection pools per database. |
client_connection | Tracks the connection count by the status of the client
connection. The statuses included in this metric are:
|
server_connections | Tracks the server connections count by the status of the
server connection. The statuses included in this metric
are:
|
client_connections_avg_wait_time | The average time spent by all clients in waiting state for a server. |
For more information about these metrics, see Cloud SQL metrics. To view these metrics using the Cloud de Confiance console, see View metrics on the Cloud SQL instance overview page.