Shared VPC
This page provides an overview of Shared VPC in Google Cloud. Shared VPC allows an organization to connect resources from multiple projects to a common Virtual Private Cloud (VPC) network so that they can communicate with each other securely and efficiently by using internal IP addresses from that network.
When you use Shared VPC, you designate a project as a host project and attach one or more other service projects to it. The VPC networks in the host project are called Shared VPC networks. Eligible resources from service projects can use subnets in the Shared VPC network.
Shared VPC lets organization administrators delegate administrative responsibilities, such as creating and managing instances, to Service Project Admins while maintaining centralized control over network resources like subnets, routes, and firewalls. This model allows organizations to do the following:
- Implement a security best practice of least privilege for network administration, auditing, and access control. Shared VPC Admins can delegate network administration tasks to Network and Security Admins in the Shared VPC network without allowing Service Project Admins to make network-impacting changes. Service Project Admins are only given the ability to create and manage instances that make use of the Shared VPC network. Refer to the administrators and IAM section for more details.
- Apply and enforce consistent access control policies at the network level for multiple service projects in the organization while delegating administrative responsibilities. For example, Service Project Admins can be Compute Instance Admins in their project, creating and deleting instances that use approved subnets in the Shared VPC host project.
- Use service projects to separate budgeting or internal cost centers. Refer to the billing section for more details.
Concepts
Organizations, folders, and projects
Shared VPC connects projects within the same organization. Linked projects can be in the same or different folders, but if they are in different folders the admin must have Shared VPC Admin rights to both folders. Refer to the Google Cloud resource hierarchy for more information about organizations, folders, and projects.
Participating host and service projects cannot belong to different organizations. The only exception is during a migration of your projects from one organization to another. During the migration, service projects can be in a different organization than the host project temporarily. For more information about migrating projects, see Migrating projects.
A project that participates in Shared VPC is either a host project or a service project:
A host project contains one or more Shared VPC networks. A Shared VPC Admin must first enable a project as a host project. After that, a Shared VPC Admin can attach one or more service projects to it.
A service project is any project that has been attached to a host project by a Shared VPC Admin. This attachment allows it to participate in Shared VPC. It's a common practice to have multiple service projects operated and administered by different departments or teams in your organization.
A project cannot be both a host project and a service project simultaneously. Thus, a service project cannot be a host project to further service projects.
You can create and use multiple host projects; however, each service project can only be attached to a single host project. For an illustration, see the multiple host projects example.
You can create networks, subnets, secondary address ranges, firewall rules, and other network resources in the host project. The host project can then share selected subnets, including secondary ranges, with the service projects. Services running in a service project can use Shared VPC to communicate with resources running in the other service projects.
For clarity, a project that does not participate in Shared VPC is called a standalone project. This emphasizes that it is neither a host project nor a service project.
A standalone VPC network is an unshared VPC network that exists in either a standalone project or a service project.
Networks
A Shared VPC network is a VPC network defined in a host project and made available as a centrally shared network for eligible resources in service projects. Shared VPC networks can be either auto or custom mode, but legacy networks are not supported.
When a host project is enabled, you have two options for sharing networks:
- You can share all host project subnets. If you select this option, then any new subnets created in the host project, including subnets in new networks, will also be shared.
- You can specify individual subnets to share. If you share subnets individually, then only those subnets are shared unless you manually change the list.
Host and service projects are connected by attachments at the project level. Subnets of the Shared VPC networks in the host project are accessible by Service Project Admins as described in the next section, administrators and IAM.
Organization policy constraints
Organization policies and IAM permissions work together to provide different levels of access control. Organization policies enable you to set controls at the organization, folder, or project level.
If you are an organization policy administrator, you can specify the following Shared VPC constraints in an organization policy:
You can limit the set of host projects to which a non-host project or non-host projects in a folder or organization can be attached. The constraint applies when a Shared VPC Admin attaches a service project with a host project. The constraint doesn't affect existing attachments. Existing attachments remain intact even if a policy denies new ones. For more information, see the
constraints/compute.restrictSharedVpcHostProjects
constraint.You can specify the Shared VPC subnets that a service project can access at the project, folder, or organization level. The constraint applies when you create new resources in the specified subnets and doesn't affect existing resources. Existing resources continue to operate normally in their subnets even if a policy prevents new resources from being added. For more information, see the
constraints/compute.restrictSharedVpcSubnetworks
constraint.
Administrators and IAM
Shared VPC makes use of Identity and Access Management (IAM) roles for delegated administration. The following roles can be granted to IAM principals, such as users, Google groups, Google domains, or Google Cloud service accounts. If you need to contact any of these admins, you can look them up in your organization's or project's IAM policy. If you don't have the required permissions, you must contact a network or project administrator in your organization.
Required administrative roles
Administrator (IAM role) | Purpose |
---|---|
Organization Admin (resourcemanager.organizationAdmin )
• IAM principal in the organization |
Organization Admins have the
resourcemanager.organizationAdmin role for your organization.
They nominate Shared VPC Admins by granting them
appropriate
project creation and deletion roles, and the Shared VPC Admin
role for the organization. These admins can define organization-level
policies, but specific folder and project actions require additional
folder and project roles. |
Shared VPC Admin ( compute.xpnAdmin and resourcemanager.projectIamAdmin )
• IAM principal in the organization, or • IAM principal in a folder |
Shared VPC Admins have the
Compute Shared VPC Admin (compute.xpnAdmin )
and
Project IAM Admin
(resourcemanager.projectIamAdmin ) roles for
the organization or one or more folders. They perform various tasks
necessary to
set up Shared VPC,
such as enabling host projects, attaching service
projects to host projects, and delegating access to some or all of the
subnets in Shared VPC networks to Service Project Admins. A Shared VPC
Admin for a given host project is typically its project owner as well. A user assigned the Compute Shared VPC Admin role for the organization has that role for all folders in the organization. A user assigned the role for a folder has that role for the given folder and any folders nested underneath it. A Shared VPC Admin can link projects in two different folders only if the admin has the role for both folders. |
Service Project Admin ( compute.networkUser )
• IAM principal in the organization, or • IAM principal in a host project, or • IAM principal in some subnets in the host project |
A Shared VPC Admin defines a Service Project Admin by granting an IAM
principal the
Network User (compute.networkUser ) role to
either the whole host project or select subnets
of its Shared VPC networks. Service Project Admins also maintain
ownership and control over resources defined in the service projects, so
they should have the
Instance Admin (compute.instanceAdmin ) role to
the corresponding service projects. They may have additional IAM roles to
the service projects, such as project owner.
|
Service Project Admins
When defining each Service Project Admin, a Shared VPC Admin can grant permission to use the whole host project or just some subnets:
Project-level permissions: A Service Project Admin can be defined to have permission to use all subnets in the host project if the Shared VPC Admin grants the role of
compute.networkUser
for the whole host project to the Service Project Admin. The result is that the Service Project Admin has permission to use all subnets in all VPC networks of the host project, including subnets and VPC networks added to the host project in the future.Subnet-level permissions: Alternatively, a Service Project Admin can be granted a more restrictive set of permissions to use only some subnets if the Shared VPC Admin grants the role of
compute.networkUser
for those selected subnets to the Service Project Admin. A Service Project Admin who only has subnet-level permissions is restricted to using only those subnets. After new Shared VPC networks or new subnets are added to the host project, a Shared VPC Admin should review the permission bindings for thecompute.networkUser
role to ensure that the subnet-level permissions for all Service Project Admins match the intended configuration.
Network and Security Admins
Shared VPC Admins have full control over the resources in the host project, including administration of the Shared VPC network. They can optionally delegate certain network administrative tasks to other IAM principals:
Administrator | Purpose |
---|---|
Network Admin
• IAM principal in the host project, or • IAM principal in the organization |
Shared VPC Admin defines a Network Admin by granting an IAM
principal the
Network Admin (compute.networkAdmin ) role to the
host project. Network Admins have full control over all network resources
except for firewall rules and SSL certificates.
|
Security Admin
• IAM principal in the host project, or • IAM principal in the organization |
A Shared VPC Admin can define a Security Admin by granting an IAM
principal the
Security Admin (compute.securityAdmin ) role to
the host project. Security Admins manage firewall rules and SSL
certificates.
|
Specifications
Quotas and limits
Shared VPC host projects are subject to standard per-project VPC quotas. Shared VPC networks are subject to the per-network limits and per-instance limits for VPC networks. Additionally, the relationships between host and service projects are governed by limits specific to Shared VPC.
Billing
Billing for resources that participate in a Shared VPC network is attributed to the service project where the resource is located, even though the resource uses the Shared VPC network in the host project.
- The rates and rules used to calculate billing amounts for resources in service projects using a Shared VPC network is the same as if the resources were located in the host project itself.
- Billing for outbound traffic generated by a resource is attributed to the
project where the resource is defined:
- Outbound traffic from an instance is attributed to the project containing the instance. For example, if an instance is created in a service project but uses a Shared VPC network, any billing for outbound traffic that it generates is attributed to its service project. In this way, you can use Shared VPC to organize resources into cost centers for your organization.
- Costs associated with a load balancer are charged to the project containing the load balancer components. For more details about load balancing and Shared VPC, see the load balancing section.
- Outbound traffic to VPNs is attributed to the project containing the VPN Gateway resource. For example, if a VPN Gateway is created in the Shared VPC network, it is contained in the host project. Outbound traffic through the VPN Gateway — regardless of which service project initiates the outbound data transfer — is attributed to the host project.
- Costs for traffic from a resource in a Shared VPC service project that transfers out through a VLAN attachment are attributed to the project that owns the VLAN attachment. For more information, see Cloud Interconnect pricing.
Resources
Eligible resources
You can use most Google Cloud products and features in Shared VPC service projects.
The following limitations apply to resources that are eligible for participation in a Shared VPC scenario:
Use of a Shared VPC network is not mandatory. For example, instance admins can create instances in the service project that use a VPC network in that project. Networks defined in service projects are not shared.
Some resources must be re-created in order to use a Shared VPC network. When a Shared VPC Admin attaches an existing project to a host project, that project becomes a service project, but its existing resources do not automatically use shared network resources. To use a Shared VPC network, a Service Project Admin has to create an eligible resource and configure it to use a subnet of a Shared VPC network. For example, an existing instance in a service project cannot be reconfigured to use a Shared VPC network, but a new instance can be created to use available subnets in a Shared VPC network. This limitation applies to private zones.
IP addresses
When you create an instance in a service project, the IP versions that you can configure depend on the host project's subnet configuration. For more information, see Create an instance.
Instances in service projects attached to a host project that uses the same Shared VPC network can communicate internally with one another by using either their internal IPv4 addresses or their internal or external IPv6 addresses, subject to applicable firewall rules.
Service Project Admins can assign any of the following IP address types to resources in a service project:
Ephemeral IPv4 and IPv6 addresses: An ephemeral IP address can be automatically assigned to an instance in a service project. For example, when Service Project Admins create instances, they select the Shared VPC network and an available shared subnet. For instances with IPv4 addresses, the primary internal IPv4 address comes from the range of available IP addresses in the selected shared subnet's primary IPv4 address range. For instances with IPv6 addresses, the IPv6 address comes from the range of available IP addresses in the selected shared subnet's IPv6 subnet range.
Ephemeral IPv4 addresses can also be automatically assigned to internal load balancers. For more information, see create an internal passthrough Network Load Balancer or create an internal Application Load Balancer.
Static internal IPv4 and IPv6 addresses: A static internal IPv4 or IPv6 address can be reserved in a service project. The internal IPv4 or IPv6 address object must be created in the same service project as the resource that uses it, even though the value of the IP address comes from the available IP addresses of the selected shared subnet in a Shared VPC network. For more information, see Reserve static internal IP4 and IPv6 addresses on the "Provision Shared VPC" page.
Static external IPv4 addresses: External IPv4 address objects defined in the host project can be used by resources in either that host project or any attached service project. Service projects can also use their own external IPv4 address objects. For example, an instance in a service project can use a regional external IPv4 address defined in either its service project or in the host project.
Static external IPv6 addresses: A Service Project Admin can also choose to reserve a static external IPv6 address. The external IPv6 address object must be created in the same service project as the resource that uses it, even though the value of the IP address comes from the available IPv6 addresses of the selected shared subnet in a Shared VPC network. For more information, see Reserve a static external IPv6 address on the Provision Shared VPC page.
Internal DNS
VMs in the same service project can reach each other using the internal DNS names that Google Cloud creates automatically. These DNS names use the project ID of the service project where the VMs are created, even though the names point to internal IP addresses in the host project. For a complete explanation, see Internal DNS names and Shared VPC in the Internal DNS documentation.
Cloud DNS private zones
You can use Cloud DNS private zones in a Shared VPC network. You can create your private zone in the host project and authorize access to the zone for the Shared VPC network or set up the zone in a service project using cross-project binding.
Load balancing
Shared VPC can be used in conjunction with Cloud Load Balancing. In most cases, you create the backend instances in a service project. In that case, all load balancer components are created in that project. While it's possible to create backend instances in the host project, such a setup is not well suited for typical Shared VPC deployments since it does not separate network administration and service development responsibilities.
Use the links in the following table to learn more about supported Shared VPC architectures for each type of load balancer.
Examples and use cases
Basic concepts
Figure 1 shows a simple Shared VPC scenario:
A Shared VPC Admin for the organization has created a host project and attached two service projects to it:
Service Project Admins in
Service project A
can be configured to access all or some of the subnets in the Shared VPC network. A Service Project Admin with at least subnet-level permissions to the10.0.1.0/24 subnet
has createdInstance A
in a zone of theus-west1
region. This instance receives its internal IP address,10.0.1.3
, from the10.0.1.0/24
CIDR block.Service Project Admins in
Service project B
can be configured to access all or some of the subnets in the Shared VPC network. A Service Project Admin with at least subnet-level permissions to the10.15.2.0/24 subnet
has createdInstance B
in a zone of theus-east1
region. This instance receives its internal IP address,10.15.2.4
, from the10.15.2.0/24
CIDR block.
The Standalone Project does not participate in the Shared VPC at all; it is neither a host nor a service project. Standalone instances are created by IAM principals who have at least the
compute.InstanceAdmin
role for the project.
Multiple host projects
Figure 2 shows how Shared VPC can be used to build separate testing and production environments. For this case, an organization has decided to use two separate host projects, a Test Environment and a Production Environment.
A Shared VPC Admin for the organization has created two host projects and attached two service projects to them as follows:
The
Apps testing
andMobile testing
service projects are attached to theTest environment
host project. Service Project Admins in each project can be configured to access all or some of the subnets in theTesting network
.The
Apps production
andMobile production
service projects are attached to theProduction environment
host project. Service Project Admins in each project can be configured to access all or some of the subnets in theProduction network
.
Both host projects have one Shared VPC network with subnets configured to use the same CIDR ranges. In both the
Testing network
andProduction network
, the two subnets are:10.0.1.0/24 subnet
in theus-west1
region10.15.2.0/24 subnet
in theus-east1
region
Consider
Instance AT
in theApps testing
service project andInstance AP
in theApps production
service project:Service Project Admins can create instances like them provided they have at least subnet-level permissions to the
10.0.1.0/24 subnet
.Notice that both instances use the IP address
10.0.1.3
. This is acceptable because each instance exists in a service project attached to a unique host project containing its own Shared VPC network. Both the testing and production networks have been purposefully configured in the same way.Instances using the
10.0.1.0/24 subnet
must be located in a zone in the same region as the subnet, even though the subnet and instances are defined in separate projects. Because the10.0.1.0/24 subnet
is located in theus-west1
region, Service Project Admins who create instances using that subnet must choose a zone in the same region, such asus-west1-a
.
Hybrid cloud scenario
Figure 3 shows how Shared VPC can be used in a hybrid environment.
For this example, an organization has a created a single host project with a single Shared VPC network. The Shared VPC network is connected by using Cloud VPN to an on-premises network. Some services and applications are hosted in Google Cloud while others are kept on-premises:
A Shared VPC Admin enabled the host project and connected three service projects to it:
Service project A
,Service project B
, andService project C
.Separate teams can manage each of the service projects. IAM permissions have been configured such that a Service Project Admin for one project has no permissions to the other service projects.
The Shared VPC Admin has granted subnet-level or project-level permissions to the necessary Service Project Admins so they can create instances that use the Shared VPC network:
A Service Project Admin for
Service project A
who has subnet-level permissions to the10.0.1.0/24 subnet
can createInstance A
in it. The Service Project Admin has to choose a zone in theus-west1
region for the instance, because that is the region that contains the10.0.1.0/24 subnet
.Instance A
receives its IP address,10.0.1.3
, from the range of free IP addresses in the10.0.1.0/24 subnet
.A Service Project Admin for
Service project B
who has subnet-level permissions to the10.15.2.0/24 subnet
can createInstance B
in it. The Service Project Admin has to choose a zone in theus-east1
region for the instance, because that is the region that contains the10.15.2.0/24 subnet
.Instance B
receives its IP address,10.15.2.4
, from the range of free IP addresses in10.15.2.0/24 subnet
.A Service Project Admin for
Service project C
who has project-level permissions to the whole host project can create instances in any of the subnets in any of the VPC networks in the host project. For example, the Service Project Admin can createInstance C
in the10.7.1.0/24 subnet
, choosing a zone in theus-east1
region to match the region for the subnet.Instance C
receives its IP address,10.7.1.50
, from the range of free IP addresses in the10.7.1.0/24 Subnet
.
The Service Project Admins in each project are responsible for creating and managing resources.
A Shared VPC Admin has delegated network administration tasks to other IAM principals who are Network and Security Admins for the Shared VPC network.
A Network Admin has created a Cloud VPN gateway and configured a VPN tunnel through the internet to an on-premises gateway. The Cloud VPN exchanges and receives routes with its on-premises counterpart because a corresponding Cloud Router in the same
us-east1
region has been configured.If the dynamic routing mode of the VPC is global, the Cloud Router applies the learned routes to the on-premises network in all subnets in the VPC network, and it shares routes to all of the VPC subnets with its on-premises counterpart.
Security Admins create and manage firewall rules in the Shared VPC network to control traffic among instances in Google Cloud and the on-premises network.
Subject to applicable firewall rules, instances in the service projects can be configured to communicate with internal services, such as database or directory servers located on-premises.
Two-tier web service
Figure 4 demonstrates how Shared VPC can be employed to delegate administrative responsibilities and maintain the principle of least privilege. For this case, an organization has a web service that is separated into two tiers, and different teams manage each tier. Tier 1 represents the externally facing component, behind an HTTP(S) load balancer. Tier 2 represents an internal service upon which Tier 1 relies, and it is balanced using an internal TCP/UDP load balancer.
Shared VPC lets you map each tier of the web service to different projects so that they can be managed by different teams while sharing a common VPC network:
Resources, such as instances and load balancer components, for each tier are placed in individual service projects managed by different teams.
Each tier service project has been attached to the host project by a Shared VPC Admin. The Shared VPC Admin also enabled the host project.
Separate teams can manage each tier of the web service by virtue of being a Service Project Admin in the appropriate service project.
The Service Project Admins in each project are responsible for creating and managing resources.
Network access control is delineated as follows:
IAM principals who only work on Tier 1 are Service Project Admins for the
Tier 1 service project
and are granted subnet-level permissions for only the10.0.1.0/24 subnet
. In this example, one such Service Project Admin has created threeTier 1 instances
in that subnet.IAM principals who only work on Tier 2 are Service Project Admins for the
Tier 2 service project
and are granted subnet-level permissions for just the10.0.2.0/24 subnet
. In this example, another Service Project Admin has created threeTier 2 instances
in that subnet along with an internal load balancer whose forwarding rule uses an IP address from the range available in that subnet.IAM principals who oversee the whole web service are Service Project Admins in both service projects, and they have project-level permissions to the host project so they can use any subnet defined in it.
Optionally, a Shared VPC Admin can delegate network administration tasks to Network and Security Admins.
What's next
- To set up Shared VPC, see Provisioning Shared VPC.
- To set up Kubernetes Engine clusters with Shared VPC, see Setting up clusters with Shared VPC.
- To delete a Shared VPC setup, see Deprovisioning Shared VPC.