Datastream uses Private Service Connect interfaces to let you replicate data in a way that keeps the traffic entirely within Google Cloud.
A Private Service Connect interface is a resource that lets a producer Virtual Private Cloud (VPC) network initiate connections to and receive connections from a network attachment in a consumer VPC network. Producer and consumer networks can be in different projects and organizations.
Figure 1. Private Service Connect interfaces let service producers initiate connections to service consumers.
For key term definitions, see the section that follows.
For more information about Private Service Connect, see the Virtual Private Cloud documentation.
Key terms
This section provides an overview of key terms and concepts that apply to Private Service Connect.
- Producer: an entity, typically a service or a VM within a VPC network, that initiates the connection to the consumer network. The producer delivers the service: in the Datastream context, it fetches and replicates data to a destination. 
- Consumer: an entity, typically a VM within a VPC network, that receives the connection from the producer. When the consumer accepts the connection, Google Cloud allocates the Private Service Connect interface an IP address from a subnet in the consumer VPC network that's specified by the network attachment. The VM of the Private Service Connect interface has a second network interface that connects to the producer's VPC network. 
- Network attachment: a regional resource that lets a producer VPC network initiate connections to a consumer VPC network through a Private Service Connect interface. In the consumer VPC network, the network attachment acts as a designated entry point for connections from Private Service Connect interfaces in the producer network. When a Private Service Connect interface is established on a network attachment, the producer VM is assigned an IP from the subnet of the network attachment. The virtual machine instance of the Private Service Connect interface has at least one more regular network interface that connects to a producer subnet. For more information, see About network attachments. 
- Producer project: a Google-owned project where the virtual machines (VMs) running Datastream are hosted. To access resources in the customer VPC, the Datastream VMs use the IP address that the Private Service Connect network interface assigns from its subnet. 
Private Service Connect prerequisites
Before you create a private connectivity configuration using a Private Service Connect interface, you need to take the following steps so that Datastream can establish a connection to your project:
- Have a VPC network that you can connect to the Datastream private network. For more information about creating a VPC network, see Create and manage VPC networks. 
- Create a network attachment in your VPC project. 
- Verify that Google Cloud and the on-premises firewall allow traffic from the network attachment IP address range to the source database from which you want to stream data. For information about how to create firewall rules, see Use VPC firewall rules. 
Pricing
Data ingress and egress through Private Service Connect is charged. For more information, see the Private Service Connect pricing.
Required roles and permissions
To get the permissions that you need to create a network attachment, ask your administrator to grant you the following Identity and Access Management (IAM) roles on your project:
- Create, view, and delete network attachments:
Compute Network Admin
(roles/compute.networkAdmin)
If your network attachment is in a different project than Datastream,
then you need to grant the following role to the
service-DATASTREAM-PROJECT-NUMBER@gcp-sa-datastream.iam.gserviceaccount.com
service account:
- Read-only access to networking resources: Compute Network Viewer ( - roles/compute.networkViewer)- Grant the role on the project where your network attachment is, and replace DATASTREAM-PROJECT-NUMBER with the number of the project where Datastream is deployed. 
For more information about granting roles, see Manage access.
You might also be able to get the required permissions through custom roles or other predefined roles.
For more information about access control options in Datastream, see Access control with IAM.
Configure Private Service Connect
To let Datastream establish outbound connectivity to your network using a Private Service Connect interface:
- Create a network attachment in your project.
- Create a private connectivity configuration.
Create a network attachment
To configure Private Service Connect in Datastream, you must first create a network attachment.
Console
- In the Google Cloud console, go to the Network attachments page: 
- Click Create network attachment. 
- In the Name field, enter a name for your network attachment. 
- From the Network list, select a VPC or a Shared VPC network. 
- From the Region list, select a Google Cloud region. This region must be the same as the region used for the subnet of the VPC network peered to the Datastream private network. For more information, see Private Service Connect prerequisites. 
- From the Subnetwork list, select a subnetwork range. 
- In Connection preference, select Accept connections for selected projects. - Datastream automatically adds the producer project to the Accepted projects list when you create the Datastream private connectivity resource. 
- Don't add Accepted projects or Rejected projects. 
- Click Create network attachment. 
gcloud
- Create one or more subnetworks. For example: - gcloud compute networks subnets create subnet-1 --network=network-0 --range=10.10.1.0/24 --region=REGION- The network attachment uses these subnetworks in the subsequent steps. 
- Create a network attachment resource in the same region as the Datastream project, with the - connection-preferenceproperty set to- ACCEPT_MANUAL:- gcloud compute network-attachments create NAME --region=REGION --connection-preference=ACCEPT_MANUAL --subnets=SUBNET- Replace the following: - NAME: the name for your network attachment.
- REGION: the name of the Google Cloud region. This region must be the same as the Datastream private network.
- SUBNET: the name of the subnet.
 - The output of this command is a network attachment URL of the following format: - projects/PROJECT/locations/REGION/network-attachments/NETWORK_ATTACHMENT_ID.- Make a note of this URL as Datastream needs it for connectivity. For information about how to create a Private Service Connect interface private connectivity configuration using Google Cloud, see Manage private connectivity configurations. 
Create a private connectivity configuration
After you create a network attachment in your Google Cloud project, you need to set up your private connectivity configuration using Private Service Connect interfaces. When you create the configuration, you allowlist the project that hosts the Private Service Connect interface. You then provide the network attachment URL to Datastream as part of the Private Service Connect resource.
For more information, see Create a private connectivity configuration.
What's next
- Learn how to view your private connectivity configuration.
- Find out how to delete a private connectivity configuration.