(Legacy) Set up private connections
Private services access is a private connection between your Virtual Private Cloud (VPC) network and networks in VMware Engine. This page explains how to set up private services access to Google Cloud VMware Engine and connect your VPC network to your private cloud.
Private services access enables the following behavior:
- Exclusive communication by internal IP address for virtual machine (VM) instances in your VPC network and VMware VMs. VM instances don't need internet access or external IP addresses to reach services that are available through private services access.
- Communication between VMware VMs and Google Cloud-supported services, which support private services access using internal IP addresses.
- Use of existing on-premises connections to connect to your VMware Engine private cloud, if you have on-premises connectivity using Cloud VPN or Cloud Interconnect to your VPC network.
You can set up private services access independently of VMware Engine private cloud creation. The private connection can be created before or after creation of the private cloud to which you want to connect your VPC network.
Permissions
-
Make sure that you have the following role or roles on the project: Compute > Network Admin
Check for the roles
-
In the Google Cloud console, go to the IAM page.
Go to IAM - Select the project.
-
In the Principal column, find all rows that identify you or a group that you're included in. To learn which groups you're included in, contact your administrator.
- For all rows that specify or include you, check the Role column to see whether the list of roles includes the required roles.
Grant the roles
-
In the Google Cloud console, go to the IAM page.
Go to IAM - Select the project.
- Click Grant access.
-
In the New principals field, enter your user identifier. This is typically the email address for a Google Account.
- In the Select a role list, select a role.
- To grant additional roles, click Add another role and add each additional role.
- Click Save.
-
Before you begin
- You must have an existing VPC network.
- Activate the Service Networking API in your project.
Configure private services access in the VPC network you want to connect to.
Locate the Peered project ID of your VPC network by doing the following:
- In the Google Cloud console, go to VPC network peering. A VPC network peering connection with name servicenetworking-googleapis-com is listed in the peering table.
- Copy the Peered project ID so that you can use it while setting up a private connection in the Google Cloud console.
Multi-VPC connectivity
VMware Engine lets you access the same private cloud from different VPC networks without the need to change any existing VPC architectures deployed in Google Cloud. For example, multi-VPC connectivity is useful when you have separate VPC networks for testing and development.
This situation requires VPC networks to communicate with VMware VMs or other destination addresses in separate vSphere resource groups on the same private cloud or across multiple private clouds.
By default, you can peer 3 VPC networks per region. This peering limit includes the VPC peering used by the internet access network service. To increase this limit, contact Cloud Customer Care.
IP address uniqueness
When you connect your VPC network to a VMware Engine regional network, follow these guidelines to ensure IP address uniqueness:
VMware Engine IP ranges and subnets in your VPC network can't use the same IP address ranges.
VMware Engine IP ranges can't fit within a subnet IP address range in your VPC network. Subnet routes in your VPC network must have the most specific IP address ranges.
Carefully review the VPC network routes overview for details about how VPC network routes work.
If you need to connect two or more VMware Engine networks to the same VPC network, you must either use unique IP ranges for each VMware Engine network, or you must only enable NSX-T connectivity for one of the VMware Engine networks using the same IP ranges as another VMware Engine network.
Create a private connection
Create a private connection in the console, Google Cloud CLI, or the REST API.
In your request, set the connection type to PRIVATE_SERVICE_ACCESS
and
the routing mode to GLOBAL
routing mode.
Console
In the Google Cloud console, go to the Private connections page.
Click Create.
Provide a Name and Description for the connection.
Select the VMware Engine network to connect to.
In the Peered project ID field, paste the Peered project ID that you copied in the prerequisites.
In Private connection type, select Private services access.
Select the routing mode for this VPC network peering connection. In most cases, we recommend the global routing mode. If you don't want Google services peered with your VPC network to communicate across regions, select the
Regional
routing mode instead. This Selection overrides the existing routing mode.Click Submit.
When the connection is created, you can select the specific connection from the list of private connections. The details page for each private connection displays the routing mode of the private connection and any routes learned over VPC peering.
The Exported routes table shows private clouds learned from the region and exported over VPC peering. When multiple VPC networks are peered to the same VMware Engine regional network, routes received from one VPC network are not advertised to the other VPC network.
gcloud
Create a private connection by running the
gcloud vmware private-connections create
command:gcloud vmware private-connections create PRIVATE_CONNECTION_ID \ --location=REGION\ --description="" \ --vmware-engine-network=NETWORK_ID \ --service-project=SERVICE_NETWORKING_TENANT_PROJECT\ --type=PRIVATE_SERVICE_ACCESS \ --routing-mode=MODE
Replace the following:
PRIVATE_CONNECTION_ID
: the private connection name to createREGION
: the region to create this private connection in; this must match the VMware Engine network regionNETWORK_ID
: the VMware Engine network nameSERVICE_NETWORKING_TENANT_PROJECT
: the project name for this service networking tenant VPC. You can find the SNTP in the PEER_PROJECT column of the peering nameservicenetworking-googleapis-com
.MODE
: the routing mode, eitherGLOBAL
orREGIONAL
Optional: If you want to list your private connections, run the
gcloud vmware private-connections list
command:gcloud vmware private-connections list \ --location=REGION
Replace the following:
REGION
: the region of the network to list.
API
To create a Compute Engine VPC and a private service access connection using the VMware Engine API:
Create a private connection by making a
POST
request:POST "https://vmwareengine.googleapis.com/v1/projects/PROJECT_ID/locations/REGION/privateConnections?private_connection_id=PRIVATE_CONNECTION_ID" '{ "description": "My first private connection", "vmware_engine_network": "projects/PROJECT_ID/locations/REGION/vmwareEngineNetworks/NETWORK_ID "type": "PRIVATE_SERVICE_ACCESS", "routing_mode": "MODE", "service_network": "projects/SERVICE_NETWORKING_TENANT_PROJECT/global/networks/SERVICE_NETWORK" }'
Replace the following:
PRIVATE_CONNECTION_ID
: the private connection name for this requestREGION
: the region to create this private connection inNETWORK_ID
: the VMware Engine network for this requestSERVICE_NETWORKING_TENANT_PROJECT
: the project name for this service networking tenant VPC. You can find the SNTP in the PEER_PROJECT column of the peering nameservicenetworking-googleapis-com
SERVICE_NETWORK
: the network in the tenant project
Optional: If you want to list your private connections, make a
GET
request:GET "https://vmwareengine.googleapis.com/v1/projects/PROJECT_ID/locations/REGION/privateConnections"
Replace the following:
PROJECT_ID
: the project name for this request.REGION
: the region to list the private connections in.
Edit a private connection
You can edit a private connection after creating it. Once created, you can
change the routing mode between GLOBAL
and REGIONAL
. In Google Cloud CLI
or the API, you can also update the description of the private connection.`
Console
In the Google Cloud console, go to the Private connections page.
Click the name of the private connection you want to edit.
On the details page, click Edit.
Update the description or the routing mode of the connection.
Save your changes.
gcloud
Edit a private connection by running the
gcloud vmware private-connections update
command:
gcloud vmware private-connections update PRIVATE_CONNECTION_ID \ --location=REGION \ --description=DESCRIPTION \ --routing-mode=MODE
Replace the following:
PROJECT_ID
: the project name for this requestREGION
: the region to update this private connection inDESCRIPTION
: the new description to usePRIVATE_CONNECTION_ID
: the private connection ID for this requestMODE
: the routing mode, eitherGLOBAL
orREGIONAL
API
To edit a private connection using the VMware Engine API, make a PATCH
request:
PATCH "https://vmwareengine.googleapis.com/v1/projects/PROJECT_ID/locations/REGION/privateConnections/PRIVATE_CONNECTION_ID?update_mask=description, routing_mode" '{ "description": "Updated description for the private connection", "routing_mode": "MODE" }'
Replace the following:
PROJECT_ID
: the project name for this requestREGION
: the region to update this private connection inPRIVATE_CONNECTION_ID
: the private connection name for this requestMODE
: the routing mode, eitherGLOBAL
orREGIONAL
Describe a private connection
You can get the description of any private connection using the Google Cloud CLI or VMware Engine API.
gcloud
Get a description of a private connection by running the gcloud vmware private-connections describe
command:
gcloud vmware private-connections describe PRIVATE_CONNECTION_ID \ --location=REGION
Replace the following:
PRIVATE_CONNECTION_ID
: the private connection name for this requestREGION
: the region of the private connection.
API
To get a description of a private connection using the
VMware Engine API, make a GET
request:
GET "https://vmwareengine.googleapis.com/v1/projects/PROJECT_ID/locations/REGION/privateConnections/PRIVATE_CONNECTION_ID"
Replace the following:
PROJECT_ID
: the project name for this request.PRIVATE_CONNECTION_ID
: the private connection name for this request.REGION
: the region of the private connection.
After the private connections you deleted are no longer visible in the list of private connections, you can delete the private connection in the Google Cloud console. Performing this step out of order can result in stale DNS entries in both Google Cloud projects.
List peering routes for a private connection
To list peering routes exchanged for a private connection, do the following:
Console
In the Google Cloud console, go to the Private connections page.
Click the name of the private connection you want to view.
The details page describes imported and exported routes.
gcloud
List peering routes exchanged for a private connection by running the
gcloud vmware private-connections routes list
command:
gcloud vmware private-connections routes list \ --private-connection=PRIVATE_CONNECTION_ID \ --location=REGION
Replace the following:
PRIVATE_CONNECTION_ID
: the private connection name for this request.REGION
: the region of the private connection.
API
To list peering routes exchanged for a private connection using the
VMware Engine API, make a GET
request:
GET "https://vmwareengine.googleapis.com/v1/projects/PROJECT_ID/locations/REGION/privateConnections/PRIVATE_CONNECTION_ID/peeringRoutes"
Replace the following:
PROJECT_ID
: the project name for this request.REGION
: the region of the private connection.PRIVATE_CONNECTION_ID
: the private connection name for this request.
Routing limits
The maximum number of routes that a private cloud can receive is 200. For example, those routes can come from on-premises networks, peered VPC networks, and other private clouds in the same VPC network. This route limit corresponds to the Cloud Router maximum number of custom route advertisements per BGP session limit.
In a given region, you can advertise at most 100 unique routes from VMware Engine to your VPC network using private services access. For example, those unique routes include private cloud management IP address ranges, NSX-T workload network segments, and HCX internal IP address ranges. This route limit includes all private clouds in the region and corresponds to the Cloud Router learned route limit.
For information about routing limits, see Cloud Router Quotas and limits.
Troubleshooting
The following video will show you how to verify and troubleshoot peering connection issues between Google Cloud VPC and Google Cloud VMware Engine.