GCP Private Service Connect
This page is part of MariaDB's Documentation.
The parent of this page is: Private Connections
Topics on this page:
Overview
By default, client traffic to SkySQL services may transit the public internet and is protected with TLS and a firewall configured by IP allowlist.
Some customers may have regulatory requirements or information security policies that prohibit the default database connections over the public internet.
Options are available to enable private connections between VPC (Virtual Private Clouds) and supported cloud provider services.
For SkySQL services on GCP, Private Service Connect (PSC) is supported.
For detailed information about Private Service Connect (PSC), see "Private Service Connect" (Google documentation).
Requirements
GCP, Private Service Connect is used for private connections within the same GCP region.
Endpoint Choices
The default endpoint mechanism is "nlb
", which supports accessing the SkySQL service via the public internet.
Use of Private Service Connect occurs when the endpoint mechanism is changed to "privateconnect
".
Private Service Connect can be enabled using the SkySQL Portal, SkySQL DBaaS API, or SkySQL Terraform Provider.
Implementation Steps
Review the details of this page, including Requirements, Controls, and Connectivity
Enable GCP Private Service Connect on your SkySQL service using one of the available interfaces for your use case:
Use Case
Method
Launch a new service
Modify an existing service
Perform GCP Endpoint Setup
Portal
GCP Private Service Connect can be enabled with a web browser using the SkySQL Portal:
Enable GCP Private Service Connect on Service Launch
To enable GCP Private Service Connect when launching a new service via the SkySQL Portal:
Initiate service launch using the procedure at "Service Launch".
When you get to the final "Security" section, select "Enable Private Service Connect".
For the next step, see the Connectivity, Controls, & GCP Endpoint Setup sections on this page.
Enable GCP Private Service Connect on Existing SkySQL Service
To enable GCP Private Service Connect for an existing service via the SkySQL Portal:
Log in to the Portal.
Click the "MANAGE" button (at right) for the desired service.
In the context menu, choose the "Set up Private Service Connect" menu item.
In the popup window, add one or more GCP project IDs.
Click the "OK" button to confirm this operation.
For the next step, see the Connectivity, Controls, & GCP Endpoint Setup sections on this page.
Disable GCP Private Service Connect
To disable GCP Private Service Connect via the SkySQL Portal:
Visit the SkySQL Portal
Find the service that you would like to modify.
Click "MANAGE" on the far right side of the service listing.
In the context menu, select "Manage Private Service Connect".
In the popup window, click "I want to disconnect my Private Service Connect".
In the popup window, select "Disconnect".
After the service restarts, Private Service Connect is disabled.
Since the service's allowlist was cleared when GCP Private Service Connect was previously enabled, you will need to update the allowlist to allow clients to connect after disabling Private Service Connect.
SkySQL DBaaS API
GCP Private Service Connect can be enabled with a REST client using the SkySQL DBaaS API:
For general instructions on using the SkySQL DBaaS API, see "DBaaS API Launch Walkthrough".
Enable GCP Private Service Connect on Service Launch
To enable GCP Private Service Connect when launching a new service via the SkySQL DBaaS API:
Initiate service launch using the procedure at "DBaaS API Launch Walkthrough".
When you are creating the request, add the
"endpoint_mechanism"
and"endpoint_allowed_accounts"
attributes to the JSON payload:"endpoint_mechanism": "privateconnect", "endpoint_allowed_accounts": [ "GCP-PROJECT-ID-1", "GCP-PROJECT-ID-2" ]
Set
"endpoint_mechanism"
to"privateconnect"
Set
"endpoint_allowed_accounts"
to a JSON array of one or more customer project IDs in GCP that will be allowed to establish a private connection to the SkySQL service
For the next step, see the Connectivity, Controls, & GCP Endpoint Setup sections on this page.
Enable GCP Private Service Connect on Existing SkySQL Service
To enable GCP Private Service Connect on an existing service via the SkySQL DBaaS API, create a JSON payload such as:
[
{
"mechanism": "privateconnect",
"allowed_accounts": [
"GCP-PROJECT-ID-1",
"GCP-PROJECT-ID-2"
]
}
]
Set
"mechanism"
to"privateconnect"
Set
"allowed_accounts"
to a JSON array of one or more customer project IDs in GCP that will be allowed to establish a private connection to the SkySQL service
And then use the API to update the endpoints
information of the service. The following example of using curl
expects the above payload to be in a file named data.json
and also expects the variables API_KEY
and SERVICE_ID
to be set:
$ curl -H "Authorization: Bearer ${API_KEY}" \
-X PATCH -d @data.json \
https://api.mariadb.com/provisioning/v1/services/${SERVICE_ID}/endpoints \
| jq .
We will need the endpoint's service name later on in the setup, so use the API to query the endpoint once the service has finished its modifications and is back to "ready":
$ curl -H "Authorization: Bearer ${API_KEY}" -X GET \
https://api.mariadb.com/provisioning/v1/services/${SERVICE_ID} \
| jq '.status,.endpoints[0].ports,.endpoints[0].endpoint_service'
Note that the jq
command is filtering the returned JSON data to extract three things (which are separated by commas in the command above):
The status of the service, which must be "ready" for the other values to be available.
The "
ready
" status means that the Private Service Connect endpoint setup is complete.A status of "
pending_upgrade
" is reflected while Private Service Connect endpoint setup is in-progress.
The "ports" data for the first item in the
endpoints
array.Some topologies include multiple port options, including ports for read/write and read-only connections, or for connections to the NoSQL listener.
Choose the desired port, such as "
readwrite
".
The
endpoint_service
value for the first item in theendpoints
array.
The output will look something like this, though your values will vary:
"ready"
[
{
"name": "readwrite",
"port": 3306,
"purpose": "readwrite"
}
]
"GCP_ENDPOINT_HOSTNAME"
If you are not using jq
, scan (or parse) the full returned JSON data to ensure the service status is "ready" and find the associated values described above.
For the next step, see the Connectivity, Controls, & GCP Endpoint Setup sections on this page.
Disable GCP Private Service Connect
To disable GCP Private Service Connect via the SkySQL DBaaS API, create a JSON payload such as:
[
{
"mechanism": "nlb"
}
]
Set
"mechanism"
to"nlb"
And then use the API to update the endpoints
information of the service. The following example of using curl
expects the above payload to be in a file named data.json
and also expects the variables API_KEY
and SERVICE_ID
to be set:
$ curl -H "Authorization: Bearer ${API_KEY}" \
-X PATCH -d @data.json \
https://api.mariadb.com/provisioning/v1/services/${SERVICE_ID}/endpoints \
| jq .
We will need the endpoint's service name later on in the setup, so use the API to query the endpoint once the service has finished its modifications and is back to "ready":
$ curl -H "Authorization: Bearer ${API_KEY}" -X GET \
https://api.mariadb.com/provisioning/v1/services/${SERVICE_ID} \
| jq '.status,.endpoints[0].ports,.endpoints[0].endpoint_service'
Note that the jq
command is filtering the returned JSON data to extract three things (which are separated by commas in the command above):
The status of the service, which must be "ready" for the other values to be available.
The "
ready
" status means that the endpoint modification is complete.A status of "
pending_upgrade
" is reflected while Private Service Connect is being disabled.
The "ports" data for the first item in the
endpoints
array.Some topologies include multiple port options, including ports for read/write and read-only connections, or for connections to the NoSQL listener.
Choose the desired port, such as "
readwrite
".
The
endpoint_service
value for the first item in theendpoints
array.
The output will look something like this, though your values will vary:
"ready"
[
{
"name": "readwrite",
"port": 3306,
"purpose": "readwrite"
}
]
"GCP_ENDPOINT_HOSTNAME"
If you are not using jq
, scan (or parse) the full returned JSON data to ensure the service status is "ready" and find the associated values described above.
Since the service's allowlist was cleared when GCP Private Service Connect was previously enabled, you will need to update the allowlist to allow clients to connect after disabling Private Service Connect.
To add an address to the allowlist via the SkySQL DBaaS API, create a JSON payload such as:
{
"ip_address": "192.0.2.10/32"
}
And then use the API to update the allowlist
information of the service. The following example of using curl
expects the above payload to be in a file named data.json
and also expects the variables API_KEY
and SERVICE_ID
to be set:
$ curl -H "Authorization: Bearer ${API_KEY}" \
-X POST -d @data.json \
https://api.mariadb.com/provisioning/v1/services/${SERVICE_ID}/security/allowlist \
| jq .
Terraform Provider
GCP Private Service Connect can be enabled with Terraform using the SkySQL Terraform provider:
For general instructions on using the SkySQL Terraform Provider, see "Terraform Launch Walkthrough".
For an example Terraform configuration that enables GCP Private Service Connect, see "https://github.com/mariadb-corporation/terraform-provider-skysql/tree/main/examples/private-service-connect".
Enable GCP Private Service Connect on Service Launch
To enable GCP Private Service Connect when launching a new service via the SkySQL Terraform provider:
Initiate service launch using the procedure at "Terraform Launch Walkthrough".
When you are configuring the
skysql_service
resource, add theendpoint_mechanism
andendpoint_allowed_accounts
attributes:For example, the attributes can be placed after
ssl_enabled
:ssl_enabled = var.ssl_enabled endpoint_mechanism = "privateconnect" endpoint_allowed_accounts = ["GCP-PROJECT-ID-1","GCP-PROJECT-ID-2"]
Set
endpoint_mechanism
to"privateconnect"
Set
endpoint_allowed_accounts
to a comma-separated list of one or more customer project IDs in GCP that will be allowed to establish a private connection to the SkySQL service
Continue the rest of the procedure.
For the next step, see the Connectivity, Controls, & GCP Endpoint Setup sections on this page.
Enable GCP Private Service Connect on Existing SkySQL Service
To enable GCP Private Service Connect for an existing service via the SkySQL Terraform provider:
Alter the
skysql_service
resource configuration by adding theendpoint_mechanism
andendpoint_allowed_accounts
attributes.For example, the attributes can be placed after
ssl_enabled
:ssl_enabled = var.ssl_enabled endpoint_mechanism = "privateconnect" endpoint_allowed_accounts = ["GCP-PROJECT-ID-1","GCP-PROJECT-ID-2"]
Set
endpoint_mechanism
to"privateconnect"
Set
endpoint_allowed_accounts
to a comma-separated list of one or more customer project IDs in GCP that will be allowed to establish a private connection to the SkySQL service
Execute the
terraform apply
command:$ terraform apply -var-file="skysql-nr-quickstart.tfvars"
For the next step, see the Connectivity, Controls, & GCP Endpoint Setup sections on this page.
Disable GCP Private Service Connect
To disable GCP Private Service Connect via the SkySQL Terraform provider:
Alter the
skysql_service
resource configuration by doing the following:Changing the
endpoint_mechanism
attribute to"nlb"
Removing the
endpoint_allowed_accounts
attributeAdding the
allow_list
attribute
For example, if you started with the following attributes after
ssl_enabled
:ssl_enabled = var.ssl_enabled endpoint_mechanism = "privateconnect" endpoint_allowed_accounts = ["GCP-PROJECT-ID-1","GCP-PROJECT-ID-2"]
You could disable GCP Private Service Connect by changing the attributes to the following:
ssl_enabled = var.ssl_enabled endpoint_mechanism = "nlb" allow_list = [ { "ip" : var.ip_address, "comment" : var.ip_address_comment } ]
Execute the
terraform apply
command:$ terraform apply -var-file="skysql-nr-quickstart.tfvars"
Connectivity
When a SkySQL service has the privateconnect
endpoint mechanism, public endpoints are disabled and connections can only occur through private endpoints.
Client connections can originate from private IP addresses in the linked VPC.
For topologies with MariaDB MaxScale, client connections occur through MaxScale.
Replication can be configured with private IP addresses in the linked VPC.
Private Service Connect does not currently support automatic DNS propagation. To use DNS names, private DNS must be configured within the VPC.
Controls
The SkySQL IP Allowlist is not used with the privateconnect
endpoint mechanism.
With Private Service Connect, projects are allowlisted and auto-accept of connections from any account is disabled.
Access restrictions are controlled through the customer's GCP account. VPC firewall rules apply. For detailed information, see "Cloud Firewall overview" (Google documentation).
Some customers using Private Service Connect may choose to disable TLS, but MariaDB recommends keeping TLS enabled for extra security.
Database connection limits are independent from PSC connection limits. The limit for PSC connections is 10.
Endpoint changes can be destructive, resulting in downtime. When you change the connection type from private to public, or public to private, the endpoint must be destroyed and recreated. Changing the SkySQL endpoint between nlb
and privateconnect
will result in a service interruption.
Connections to SkySQL services by features such as SkySQL backups, and monitoring do not depend on Private Service Connect.
Query Editor is not supported when Private Service Connect is enabled.
GCP Endpoint Setup
Endpoint setup is performed using the customer's GCP account.
Create a Subnet (optional)
We recommend use of a subnet dedicated to Private Service Connect endpoints in the same VPC where the application is running.
In the GCP console, navigate VPC network → VPC networks → <application VPC> → SUBNETS → ADD SUBNET.
Replace <application VPC> with the name of the VPC where the application is running.
Configure the subnet:
Name
Region: select the same region as the one where the application runs
Purpose: None
IP address range: Set a CIDR block that doesn't overlap with the CIDR blocks of the existing subnets in the same VPC.
Optionally configure Private Google Access
Optionally configure Flow logs
Click "ADD".
Create a Static Internal IP Address
In the GCP console, navigate VPC network → VPC networks → <application VPC> → STATIC INTERNAL IP ADDRESSES → RESERVE STATIC ADDRESS.
Replace <application VPC> with the name of the VPC where the application is running.
Configure the static internal IP address:
Name: set to the Database ID (dbxxxxxxxx) from SkySQL.
Subnet: select the subnet where to reserve the static IP address.
Static IP address: optionally choose the address.
Purpose: Non-shared
Click "RESERVE".
Connect to the Published Service
In the GCP console, navigate Network services → Private Service Connect → CONNECTED ENDPOINTS → CONNECT ENDPOINT.
Configure the endpoint connection:
Target: Published service
Target service: the
endpoint_service
value from the SkySQL DBaaS APIEndpoint name: set to the Database ID from SkySQL (dbxxxxxxxx)
Network: select the VPC network where the application is running
Subnetwork: select the subnet where the static internal IP address is reserved
IP address: select the reserved internal IP address from the prior step
Click "ADD ENDPOINT".