This tutorial describes how to use a Network Connectivity Center hub and Cloud VPN spokes to set up data transfer between two branch offices.
For more information about creating hubs and spokes, see Work with hubs and spokes.
Before you begin
Before you begin, review the following sections.
Create or select a project
To make it easier to configure Network Connectivity Center, start by identifying a valid project.
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Make sure that billing is enabled for your Google Cloud project.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
If you are using the Google Cloud CLI, set your project ID by using the
gcloud config set
command.gcloud config set project
PROJECT_ID Replace
PROJECT_ID
with your unique project ID.The gcloud CLI instructions on this page assume that you have set your project ID.
To confirm that you set the project ID correctly, use the
gcloud config list
command.gcloud config list --format='text(core.project)'
Conventions for identifying resources
When you reference resources by using the gcloud CLI or the API, use the conventions described in the following table.
Convention | Supported for | Notes | Example |
---|---|---|---|
Full URI | All resources | Use one of these methods to reference router appliance instances. |
"https://www.googleapis.com/compute/projects/ |
Relative resource name | All resources | "projects/ |
|
Name | Regional and global resources | Use this method for hubs, spokes, VPN tunnels, and VLAN attachments. | " |
Sample topology
The following diagram describes the sample resources used in this tutorial.
Configure data transfer connectivity
To set up data transfer connectivity, follow these steps:
- Create Google Cloud resources such as a Virtual Private Cloud (VPC) network, HA VPN gateways and tunnels, and Cloud Routers.
- Create a hub.
- Define a spoke for the first and second branch office. Each spoke should use a VPN tunnel as its underlying resource.
- Verify the configuration.
Create Google Cloud resources
This tutorial assumes that you have already created the following Google Cloud resources:
- A VPC network that has its
dynamic routing mode
set to
global
- In the region closest to
Office1
, a subnet, an HA VPN gateway, a Cloud Router, and a tunnel that connects the gateway interface toOffice1
- In the region closest to
Office2
, a subnet, an HA VPN gateway, a Cloud Router, and a tunnel that connects the gateway interface toOffice2
If you need to create these resources, see the following documents:
- To create a VPC network, see Creating
networks. Because this configuration
uses spokes in different regions, set the network's dynamic
routing mode to
global
. - To create subnets, see Adding subnets.
- To create HA VPN gateways, tunnels, and a Cloud Router, see Creating an HA VPN gateway to a peer VPN gateway.
After you identify existing Google Cloud resources or create new ones, continue to the next section.
Create the hub
First, you create a hub. Later, you attach spokes to this hub.
Permissions required for this task
To perform this task, you must have been granted the following permissions or the following IAM roles.
Permissions
networkconnectivity.hubs.create
- If you are working in the Google Cloud console:
networkconnectivity.hubs.get
networkconnectivity.hubs.list
networkconnectivity.spokes.list
compute.projects.get
Roles
- Hub & Spoke Admin (
roles/networkconnectivity.hubAdmin)
If you are working in the Google Cloud console: Compute Network Viewer (
roles/compute.networkViewer)
In the Google Cloud console, go to the Network Connectivity Center page.
In the project pull-down menu, select a project—in the example diagram, the project is
my-project
.Enter a Hub name—in this case,
my-hub
.Enter an optional Description.
Verify the Project ID. If the project ID is incorrect, select a different project by using the pull-down menu at the top of the screen.
Click Continue.
To add the
Office1
spoke to the hub, continue to Create the spoke for Office 1.
To create a hub, use the
gcloud network-connectivity hubs create
command.
gcloud network-connectivity hubs createHUB_NAME \ --description="DESCRIPTION " \ --labels="KEY "="VALUE "
Replace the following values:
HUB_NAME
: the name of the new hub—in this case,my-hub
DESCRIPTION
: optional text that describes the hubKEY
: the key in the key-value pair for the optional label textVALUE
: the value in the key-value pair for the optional label text
To add the Office1
spoke to the hub, continue to
Create the spoke for Office 1.
To create a hub, use the
networkconnectivity.hubs.create
method.
POST https://networkconnectivity.googleapis.com/v1/projects/PROJECT_ID /locations/global/hubs { "name":"HUB_NAME ", "description":"DESCRIPTION ", "labels": { "KEY ": "VALUE " } }
Replace the following values:
PROJECT_ID
: the project ID of the project that contains the new hub—for example,my-project
HUB_NAME
: the name of the new hub—for example,my-hub
DESCRIPTION
: optional text that describes the hubKEY
: the key in the key-value pair for the optional label textVALUE
: the value in the key-value pair for the optional label text
To add the Office1
spoke to the hub, continue to
Create the spoke for Office 1.
Create the spoke for Office 1
Create a spoke for Office1
. Use two HA VPN tunnels as
the spoke's underlying resources. Each tunnel should originate from a HA VPN gateway in the region closest to the office. In
the sample diagram, these tunnels are represented as vpn-tunnel1-office1
and
vpn-tunnel2-office1
.
Permissions required for this task
To perform this task, you must have been granted the following permissions or the following IAM roles.
Permissions
networkconnectivity.spokes.create
compute.routers.get
compute.vpnTunnels.get
- If you are working in the Google Cloud console, you need permission to view certain network resources. For details, see Roles and permissions.
Roles
- One of the following:
- Spoke Admin (
roles/networkconnectivity.spokeAdmin
) - Hub & Spoke Admin (
roles/networkconnectivity.hubAdmin
)
- Spoke Admin (
- A role—such as
Compute Network Viewer (
roles/compute.networkViewer)
—that grants you permission to read Cloud Router resources and your spoke's resource type (in this case, VPN tunnels) - If you are working in the Google Cloud console,
Compute Network Viewer (
roles/compute.networkViewer
)
The following steps are continued from Create the hub. They explain how to create a spoke immediately after specifying the hub name and description.
- In the New spoke form, set the Spoke type field to VPN tunnel.
- Enter a Spoke name—in this case,
office-1-spoke
. - Optionally, enter a Description of the spoke.
- Select the Region for the spoke— in the example diagram, the
spoke is located in
us-west1
. - Under Site-to-site data transfer, select On.
- Select the appropriate VPC network;in the example diagram, the
spoke is located in
network-a
. - Select a VPN tunnel. If appropriate, click Add tunnel to add
another VPN tunnel field. In the example diagram, two tunnels are
used:
vpn-tunnel1-office1
andvpn-tunnel2-office1
. When you are finished adding tunnels, click Done. - Click Create.
The Network Connectivity Center page updates to show details about
spokes you've created. To add the Office2
spoke to the hub,
continue to Create the spoke for Office 2.
To create the spoke, use the
gcloud network-connectivity spokes linked-vpn-tunnels create
command.
gcloud network-connectivity spokes linked-vpn-tunnels createSPOKE_NAME \ --hub=HUB_NAME \ --description="DESCRIPTION " \ --vpn-tunnels=TUNNEL_NAME ,TUNNEL_NAME_2 \ --region=REGION \ --labels="KEY "="VALUE " \ --site-to-site-data-transfer
Replace the following values:
SPOKE_NAME
: the name of the spoke—in this case,office-1-spoke
HUB_NAME
: the name of the hub that you are attaching the spoke to—in this case,my-hub
DESCRIPTION
: optional text that describes the spokeTUNNEL_NAME
: the name of the first HA VPN tunnel—in this case,vpn-tunnel1-office1
TUNNEL_NAME_2
: the name of the redundant tunnel—in this case,vpn-tunnel2-office1
; when including a second tunnel, do not use a space between the comma and the name of second tunnelREGION
: the Google Cloud region where the spoke is located— in this case,us-west1
KEY
: the key in the key-value pair for the optional label textVALUE
: the value in the key-value pair for the optional label text
To add the Office2
spoke to the hub, continue to
Create the spoke for Office 2.
To create the spoke, use the
networkconnectivity.spokes.create
method.
POST https://networkconnectivity.googleapis.com/v1/projects/PROJECT_ID /locations/REGION /spokes/SPOKE_NAME { "hub": "HUB_NAME ", "labels": {"KEY ": "VALUE "}, "linkedVpnTunnels": { "uris: [ "TUNNEL_NAME ", "TUNNEL_NAME_2 " ], "siteToSiteDataTransfer": true } }
Replace the following values:
PROJECT_ID
: the project ID of your projectREGION
: the Google Cloud region where you want to locate the spoke—in this case,us-west1
SPOKE_NAME
: the name for the spokeHUB_NAME
: the name of the hub that you are attaching the spoke toKEY
: the key in the key-value pair for the optional label textVALUE
: the value in the key-value pair for the optional label textTUNNEL_NAME
: the name of the first HA VPN tunnel—in this case,vpn-tunnel1-office1
TUNNEL_NAME_2
: the name of the redundant tunnel—in this case,vpn-tunnel2-office1
; when including a second tunnel, do not use a space between the comma and the name of second tunnel
Create the spoke for Office 2
Create a spoke for Office2
. Use two HA VPN tunnels as
the spoke's underlying resources. Each tunnel should originate from a HA VPN gateway in the region closest to the office. In
the sample diagram, these tunnels are represented as vpn-tunnel1-office2
and
vpn-tunnel2-office2
.
Permissions required for this task
To perform this task, you must have been granted the following permissions or the following IAM roles.
Permissions
networkconnectivity.spokes.create
compute.routers.get
compute.vpnTunnels.get
- If you are working in the Google Cloud console, you need permission to view certain network resources. For details, see Roles and permissions.
Roles
- One of the following:
- Spoke Admin (
roles/networkconnectivity.spokeAdmin
) - Hub & Spoke Admin (
roles/networkconnectivity.hubAdmin
)
- Spoke Admin (
- A role—such as
Compute Network Viewer (
roles/compute.networkViewer)
—that grants you permission to read Cloud Router resources and your spoke's resource type (in this case, VPN tunnels) - If you are working in the Google Cloud console,
Compute Network Viewer (
roles/compute.networkViewer
)
To create the second spoke, do the following:
Go to the Network Connectivity Center page.
In the project pull-down menu, select a project—in the example diagram, the project is
my-project
.Click the Spokes tab.
Click Add spokes to open the Add spokes page.
In the New spoke form, set the Spoke type field to VPN tunnel.
Enter a Spoke name—in this case,
office-2-spoke
.Optionally, enter a Description of the spoke.
Select the Region for the spoke— in the example diagram, the spoke is located in
us-east1
.Under Site-to-site data transfer, select On.
Verify that the VPC network field is set to the same network as the last spoke you created; in the example diagram, this is
network-a
.Select a VPN tunnel. If appropriate, click Add tunnel to add another VPN tunnel field. In the example diagram, two tunnels are used:
vpn-tunnel1-office2
andvpn-tunnel2-office2
. When you are finished adding tunnels, click Done.Click Create.
To create the spoke, use the
gcloud network-connectivity spokes linked-vpn-tunnels create
command.
gcloud network-connectivity spokes linked-vpn-tunnels createSPOKE_NAME \ --hub=HUB_NAME \ --description="DESCRIPTION " \ --vpn-tunnels=TUNNEL_NAME ,TUNNEL_NAME_2 \ --region=REGION \ --labels="KEY "="VALUE " \ --site-to-site-data-transfer
Replace the following values:
SPOKE_NAME
: the name of the spoke—in this case,office-2-spoke
HUB_NAME
: the name of the hub that you are attaching the spoke to—in this case,my-hub
DESCRIPTION
: optional text that describes the spokeTUNNEL_NAME
: the name of the first HA VPN tunnel—in this case,vpn-tunnel1-office2
TUNNEL_NAME_2
: the name of the redundant tunnel—in this case,vpn-tunnel2-office2
; when including a second tunnel, do not use a space between the comma and the name of second tunnelREGION
: the Google Cloud region where the spoke is located—in this case, inus-east1
KEY
: the key in the key-value pair for the optional label textVALUE
: the value in the key-value pair for the optional label textTo add the
Office2
spoke to the hub, continue to Create the spoke for Office 2.
To create the spoke, use the
networkconnectivity.spokes.create
method.
POST https://networkconnectivity.googleapis.com/v1/projects/PROJECT_ID /locations/REGION /spokes/SPOKE_NAME { "hub": "HUB_NAME ", "labels": {"KEY ": "VALUE "}, "linkedVpnTunnels": { "uris": [ "TUNNEL_NAME ", "TUNNEL_NAME_2 " ], "siteToSiteDataTransfer": true } }
Replace the following values:
PROJECT_ID
: the project ID of your projectREGION
: the Google Cloud region where you want to locate the spoke—in this case,us-east1
SPOKE_NAME
: the name for the spokeHUB_NAME
: the name of the hub that you are attaching the spoke toKEY
: the key in the key-value pair for the optional label textVALUE
: the value in the key-value pair for the optional label textTUNNEL_NAME
: the name of the first HA VPN tunnel—in this case,vpn-tunnel1-office2
TUNNEL_NAME_2
: the name of the redundant tunnel—in this case,vpn-tunnel2-office2
;when including a second tunnel, do not use a space between the comma and the name of second tunnel
Verify the configuration
After configuring the hub and its spokes, you should be able to pass traffic from the virtual machine (VM) instance in one office to the VM instance in the other office. To do this, each VM must have access to the VPN tunnel in its region.
Clean up the configuration
Use the steps in the following sections to clean up your sample configuration. To avoid continued billing, delete the resources that you created.
Delete the project
If you want to delete the project that you created, use the following steps. Alternatively, you can retain the project and delete individual resources, as described in the following sections.
- In the Google Cloud console, go to the Manage resources page.
- In the project list, select the project that you want to delete, and then click Delete.
- In the dialog, type the project ID, and then click Shut down to delete the project.
Delete both spokes
You must delete all spokes before you can delete a hub.
Permissions required for this task
To perform this task, you must have been granted the following permissions or the following IAM roles.
Permissions
networkconnectivity.spokes.delete
- Additionally, if you are working in the Google Cloud console:
networkconnectivity.hubs.get
networkconnectivity.hubs.list
networkconnectivity.spokes.list
compute.projects.get
Roles
- One of the following:
- Spoke Admin (
roles/networkconnectivity.spokeAdmin
- Hub & Spoke Admin (
roles/networkconnectivity.hubAdmin)
- Spoke Admin (
Additionally, if you are working in the Google Cloud console:
- Compute Network Viewer (
roles/compute.networkViewer)
- Compute Network Viewer (
Go to the Network Connectivity Center page.
In the project pull-down menu, select a project—in the example diagram, the project is
my-project
.Click the Spokes tab.
View the list of Spoke names for the project.
Select the checkboxes for the spokes you want to delete—in this case,
office-1-spoke
andoffice-2-spoke
.Click
Delete spokes.In the confirmation dialog, click Delete.
To delete spokes, use the gcloud network-connectivity spokes delete
command.
Use the command twice, once to delete office-1-spoke
and
again to delete office-2-spoke
.
gcloud network-connectivity spokes deleteSPOKE_NAME \ --region=REGION
Replace the following values:
SPOKE_NAME
: the name of the spoke to delete—in this case,office-1-spoke
andoffice-2-spoke
REGION
: the Google Cloud region where the spoke is located
To delete spokes, use the
networkconnectivity.spokes.delete
method.
Use this method twice, once to delete office-1-spoke
and again to delete
office-2-spoke
.
DELETE https://networkconnectivity.googleapis.com/v1/projects/PROJECT_ID /locations/REGION /spokes/SPOKE_NAME
Replace the following values:
PROJECT_ID
: the project ID of the project that contains the spoke—in the example diagram, the project ismy-project
REGION
: the Google Cloud region where the spoke is locatedSPOKE_NAME
: the name of the spoke to delete—in this case,office-1-spoke
andoffice-2-spoke
Delete the hub
After you have deleted the spokes, you can delete the hub.
Permissions required for this task
To perform this task, you must have been granted the following permissions or the following IAM roles.
Permissions
networkconnectivity.hubs.delete
- Additionally, if you are working in the Google Cloud console:
networkconnectivity.hubs.get
networkconnectivity.hubs.list
networkconnectivity.spokes.list
compute.projects.get
Roles
- Hub & Spoke Admin (
roles/networkconnectivity.hubAdmin)
Additionally, if you are working in the Google Cloud console, Compute Network Viewer (
roles/compute.networkViewer)
In the Google Cloud console, go to the Network Connectivity Center page.
In the project pull-down menu, select a project—in the example diagram, the project is
my-project
.Click
Delete hub.In the confirmation dialog, click Delete to delete the hub.
To delete the hub, use the
gcloud network-connectivity hubs delete
command.
gcloud network-connectivity hubs deleteHUB_NAME / --project=PROJECT_ID
Replace the following values:
HUB_NAME
: the name of the hub to delete—in this case,my-hub
.PROJECT_ID
: the project ID of the project that contains the hub;in the example diagram, the project ismy-project
To delete the hub, use the
networkconnectivity.hubs.delete
method.
DELETE https://networkconnectivity.googleapis.com/v1/projects/PROJECT_ID /locations/global/hubs/HUB_NAME
Replace the following values:
PROJECT_ID
: the project ID of the project that contains the hub;in the example diagram, the project ismy-project
HUB_NAME
: the name of the hub to delete
Delete the VPC network and subnet
Delete the VPC network and subnet that you configured for this tutorial.
What's next
- To view a sample topology, see Sample topology for site-to-site data transfer.
- To learn more about how Network Connectivity Center enables full mesh connectivity, see Route exchange with site-to-site data transfer.
- To learn about high availability requirements, see High availability requirements for spoke resources.
- To create hubs and spokes, see Work with hubs and spokes.
- To find solutions for Network Connectivity Center issues, see Troubleshooting.