Connecting to GCP Public-facing services such as Google Cloud Storage, Cloud Spanner, etc. is typically something you would do over the public Internet, however you may want the added benefits of consistent latency and performance offered by private connectivity. And while you can access these services over private connectivity from within a Google Cloud VPC using Private Google Access, and even from your on-premises data centers via Google Cloud Interconnect or Google Peering, getting there from your AWS VPC or Azure vNet via private line has historically meant standing up leased lines from your premises to each of your cloud environments (Cloud Interconnect, Direct Connect, and ExpressRoute) and managing the routing yourself. This method means long-term contracts and, depending on your location, may also introduce more latency than it's worth given that all of the data hairpins through your facility on its journey between the clouds.

Pureport's Multicloud Fabric enables you to quickly and easily connect two clouds together via native private connectivity. In the solution brief below, we'll focus specifically on accessing Google's public-facing services from an AWS VPC via AWS Direct Connect and Google Cloud Interconnect using our Multicloud Fabric as the connection broker.

Geographical Considerations

When planning your deployment, you should carefully consider geographical distance between your two cloud environments in order to minimize latency. While each cloud provider has many overlapping regions, the naming of these regions varies widely. For example, Google's US West 1 is in Oregon, while for AWS US West 1 is in Northern California and US West 2 is the Oregon region. You also need to consider which Pureport location is closest to each. The table below maps out the best combinations of cloud regions and Pureport POPs based on location.

Pureport LocationAWS RegionsGoogle Cloud Regions
Ashburn / Washington DC

US-East-1, Northern VA

US-East4, N. Virginia


US-West-2, Oregon

US-West1, Oregon

San Jose / Silicon Valley

US-West-1, Northern California

US-West2, Los Angeles


US-East-2, Ohio

US-Central1, Iowa


First you will need:

Putting it together

The steps required to complete connectivity between an AWS VPC and Google public services are outlined below:

  1. Create a Pureport Network as outlined in Creating a Network

  2. Connect your Pureport Network to your AWS VPC via:
  3. Connect your Pureport Network to your Google VPC

  4. Configure Private Access to GCP Public Services within your Google VPC

  5. Ensure that the route for has been propagated from the GCP Cloud Router to the AWS VPC route table.  If not, you may need to revisit step 2 or 3 to ensure that the GCP Interconnect and AWS Direct Connect connections are both up and peered.  Also verify that Route Propagation is enabled for the VGW within the AWS VPC Route Table.

  6. For the Configuring DNS step of configuring Private Access to GCP Public Services, use the following steps to configure a private hosted zone within AWS Route53.
    1. Use the AWS Route53 Console or API to create a new private hosted zone with a domain name of and associate it with your VPC.
    2. Add a new Record Set to the hosted zone with the following values:
      • name: *
      • type: CNAME
      • TTL: 300 seconds
      • value:
    3. Ensure that both of the following values are set to true on your VPC to allow Route53 to be used for DNS lookups.
      • enableDnsHostnames
      • enableDnsSupport

Supported GCP Public services

Currently, Google offers private connectivity support for a subset of services, as compared to Private Google Access (access to services from within a VPC). Only the following Google APIs and services that support the restricted VIP are supported:

  • BigQuery
  • Cloud Bigtable
  • Cloud Dataflow
  • Cloud Dataproc
  • Cloud Data Loss Prevention
  • Cloud Deployment Manager
  • Cloud DNS
  • Cloud KMS
  • Cloud Pub/Sub
  • Cloud Spanner
  • Cloud Storage
  • Container Registry
  • Stackdriver logging
  • Stackdriver Error Reporting