Use AWS PrivateLink for Serverless Instances on Confluent Cloud¶
Confluent Cloud supports private connectivity for Enterprise Kafka clusters and Confluent Cloud for Apache Flink®️, using PrivateLink Attachment. When you use PrivateLink Attachment, your Enterprise cluster or Flink resources are only accessible from customer-specific private endpoints. Public access is blocked with PrivateLink Attachment.
Note
By creating an environment-wide PrivateLink Attachment, you enable your Confluent Cloud data movement components (such as Flink statements and Cluster Links) to securely move data between all the private networks in the environment, including the Confluent Cloud network associated with any Dedicated Kafka clusters.
Confluent Cloud uses the following private networking resources for Enterprise clusters. These resources are regional and do not have a mapping to specific availability zones.
- PrivateLink Attachment
The PrivateLink Attachment (
PrivateLinkAttachment
) resource represents a reservation to establish a PrivateLink connection from your virtual private cloud (VPC) to regional services in a Confluent Cloud environment.A PrivateLink Attachment belongs to an Environment in the Confluent resource hierarchy.
- PrivateLink Attachment Connection
- A PrivateLink Attachment Connection (
PrivateLinkAttachmentConnection
) is a registration of VPC interface endpoints that are allowed to connect to Confluent Cloud. A PrivateLink Attachment Connection belongs to a specific PrivateLink Attachment.
You can use Confluent Cloud UI, Confluent REST API, Confluent CLI, or Terraform to establish a PrivateLink connectivity for serverless instances, such as Enterprise Kafka clusters or Confluent Cloud for Apache Flink®️.
The high-level workflow is:
- In Confluent Cloud, create a PrivateLinkAttachment.
- In AWS, create a VPC Endpoint to the PrivateLinkAttachment service.
- In Confluent Cloud, create a PrivateLinkAttachmentConnection.
- Set up a DNS resolution.
Requirements and considerations¶
You can connect to only one environment in a region from a VPC or from an on-premises network. A single VPC cannot have private link connections to multiple Confluent Cloud environments.
For the regions supported for PrivateLink Attachment on AWS, see Cloud Providers and Regions for Confluent Cloud.
Cross-region AWS PrivateLink Attachment Connections are not supported.
Confluent Cloud connectors connecting to sources or sinks with private IP addresses is unsupported at this time.
Confluent Cloud Console components, such as topic management and Flink workspaces, require additional configuration to function as they use cluster endpoints.
For information about using Flink with AWS Private Link, see Enable Private Networking with Confluent Cloud for Apache Flink.
To use all features of the Confluent Cloud Console with AWS PrivateLink, see Use Confluent Cloud with Private Networking.
Create a PrivateLink Attachment¶
When you create a PrivateLink Attachment in an environment and in a region, the PrivateLink Attachment resource provides connectivity to all Enterprise Kafka clusters within the environment for the specific cloud region.
- In the Confluent Cloud Console, select an environment for the PrivateLink Attachment.
- In the Network management tab in the environment, click For Enterprise Clusters.
- Click Add network configuration.
- Select AWS, select Region, and click Continue.
- Provide the PrivateLink Attachment name in the Network name field and click Add network configuration.
The PrivateLink Attachment will be provisioned and move to the Waiting for
connection
state.
A PrivateLink Attachment can be in one of the following states:
WAITING FOR CONNECTION
: The PrivateLink Attachment is waiting for a connection to be created.READY
: The connectivity is ready to be used.EXPIRED
: A valid connection has not been provisioned within the allotted time. A new PrivateLink Attachment must be provisioned.
Send a request to create a PrivateLink Attachment resource:
REST request
POST https://api.confluent.cloud/networking/v1/private-link-attachments
REST request body
{ "spec": { "display_name": "<name of this resource>", "cloud": "<provider type>", "region": "<region>", "environment": { "id": "<environement id>" } } }
In the REST response,
status.phase
should be set toPROVISIONING
because a VPC Endpoint Service has not yet been allocated.Check the status of the new PrivateLink Attachment:
REST request
GET https://api.confluent.cloud/networking/v1/private-link-attachments/<platt-id>
REST response example
{ "status": { "phase": "WAITING_FOR_CONNECTIONS", "error_code": "", "error_message": "", "cloud": { "kind": "AwsPrivateLinkAttachmentStatus", "vpc_endpoint_service_id": "com.amazonaws.vpce.us-east-1.vpce-svc-123abcc1298abc123", } } }
status.phase
isWAITING_FOR_CONNECTIONS
because no PrivateLink Attachment Connection has been associated with this PrivateLink Attachment resource yet.The
status.cloud
object has information about thevpc_endpoint_service
that you must connect your PrivateLink Attachment endpoint to.
Use the confluent network private-link attachment create Confluent CLI command to create an AWS private link attachment:
confluent network private-link attachment create <attachment-name> <flags>
The following command-specific flags are supported:
--network
: Required. Confluent Cloud network ID.--region
: Required. AWS region where the resources to be accessed using the private link attachment.
You can specify additional optional CLI flags described in the Confluent
CLI command reference,
such as --environment
.
The following is an example Confluent CLI command to create a private link attachment:
confluent network private-link attachment create my-private-link-attachment \
--cloud aws \
--region us-west-2
Create a VPC Endpoint¶
Note
Confluent recommends using a Terraform configuration for setting up VPC endpoints. This configuration automates the manual steps described below.
In AWS, create an endpoint that is associated with the PrivateLink Service ID of the PrivateLink Attachment you created in Create a PrivateLink Attachment.
- In the AWS Management Console, go to the the VPC dashboard.
- Verify that DNS hostnames and DNS resolution are enabled.
- In the navigation menu under VIRTUAL PRIVATE CLOUD, click Your VPCs.
- Select your VPC and click Edit VPC settings.
- Under DNS settings, verify that Enable DNS resolution and Enable DNS hostnames are selected and then click Save.
- In the navigation menu under VIRTUAL PRIVATE CLOUD, click Endpoints, and click Create endpoint.
- In Name tag, specify the name of the endpoint.
- In Service category, select Other endpoint services.
- In the Service name field, specify the PrivateLink Service ID of the PrivateLink Attachment you created in Create a PrivateLink Attachment.
- In the VPC field, specify the ID of this VPC.
- Uncheck the Enable DNS name setting under Additional settings (only appearing after the VPC is selected).
- In Subnets, select the subnets in which to create an endpoint network interface.
- Select or create a security group for the VPC Endpoint.
- Add three inbound rules for each of ports
80
,443
, and9092
from your desired source (your VPC CIDR). The Protocol should beTCP
for all three rules. - Port
80
is not required, but is available as a redirect only tohttps/443
, if desired.
- Add three inbound rules for each of ports
- Click Create endpoint.
- Note that the VPC endpoint ID created.
aws ec2 create-vpc-endpoint --vpc-id <id of this VPC> \
--service-name <privatelink attachment service id> \
--subnet-ids <subnet IDs for the endpoint> \
--region <region to use> \
--private-dns-enabled false \
--vpc-endpoint-type Interface
Note that the VPC endpoint ID is created.
For example, using the information in
status.cloud.vpc_endpoint_service_id
in the PrivateLink Attachment status:
aws ec2 create-vpc-endpoint --vpc-id vpc-097799943f9fc059d \
--service-name com.amazonaws.vpce.us-east-1.vpce-svc-123abcc1298abc123 \
--subnet-ids subnet-7b16de0c \
--region us-east-1 \
--private-dns-enabled false \
--vpc-endpoint-type Interface
Create a PrivateLink Attachment Connection¶
Create a PrivateLink Attachment Connection (PrivateLinkAttachmentConnection) resource in Confluent Cloud. A PrivateLink Attachment Connection represents a VPC Interface Endpoint in your VPC.
The name of the VPC Endpoint Service is not required. Confluent will check which VPC Endpoint Service is associated with the PrivateLink Attachment that has a pending VPC Endpoint with the given ID.
In Confluent Cloud Console, in the Network management tab in the environment, click the PrivateLink Attachment you want to add a connection to.
Make sure the PrivateLink Attachment is in the correct region of the VPC Private Endpoint.
Click + Add connection.
Specify the connection name and the Private Endpoint ID.
The Private Endpoint ID is the id of the VPC Endpoint that was created in Create a VPC Endpoint.
Click Finish.
The PrivateLink Attachment and PrivateLink Attachment Connection should now move to the READY
state once the VPC
Endpoint connection is accepted.
Send a request to create a PrivateLink Attachment Connection resource:
REST request
POST https://api.confluent.cloud/networking/v1/private-link-attachment-connections
REST request body
{ "spec": { "display_name": "<PrivateLinkAttachmentEndpoint name>", "cloud": { "kind": "AwsPrivateLinkAttachmentConnection", "vpc_endpoint_id": "<VPC Private Endpoint ID>", }, "environment": { "id": "<Environment ID>", }, "private_link_attachment": { "id": "<PrivateLinkAttachment>", } } }
REST response example
{ "api_version": "networking/v1", "kind": "PrivateLinkAttachmentConnection", "id": "plattc-xyzuvw", "status": { "phase": "PROVISIONING", "error_code": "", "error_message": "", } }
status.phase
isPROVISIONING
because a VPC Endpoint connection has not yet been accepted.Check the status of the new PrivateLink Attachment Connection:
REST request
GET https://api.confluent.cloud/networking/v1/private-link-attachment-connections/<platt-id>
REST response example
{ "api_version": "networking/v1", "kind": "PrivateLinkAttachmentConnection", "id": "plattc-xyzuvw", "status": { "phase": "READY", "error_code": "", "error_message": "", "cloud": { "kind": "AwsPrivateLinkAttachmentConnectionStatus", "phase": "READY", "vpc_endpoint_service": "com.amazonaws.vpce.us-east-1.vpce-svc-123abcc1298abc123", "vpc_endpoint_id": "vpce-bbbbbb2222222333" } } }
status.phase
isREADY
because a VPC Endpoint connection has been accepted.status.cloud
has an object of kindAwsPrivateLinkConnectionStatus
.vpc_endpoint_id
reflects the valuevpce-bbbbbb2222222333
that you registered.
Use the confluent network private-link attachment connection create Confluent CLI command to create an AWS private link attachment connection:
confluent network private-link attachment connection create <connection-name> <flags>
The following command-specific flags are supported:
--cloud
: Required. The cloud provider. Set toaws
.--endpoint
: Required. ID of an AWS VPC endpoint that is connected to the AWS VPC endpoint service.--attachment
: Required. Private link attachment ID.
You can specify additional optional CLI flags described in the Confluent
CLI command reference,
such as --environment
.
The following is an example Confluent CLI command to create a private link attachment connection:
confluent network private-link attachment connection create aws-private-link-attachment-connection \
--cloud aws \
--endpoint vpce-1234567890abcdef0 \
--attachment platt-123456
Set up DNS resolution¶
Set up a Route53 Private Hosted Zone in your AWS VPC for DNS resolution.
In Confluent Cloud, verify that the status of the PrivateLink Attachment Connection is
READY
.In Confluent Cloud, open the newly created PrivateLink Attachment to get the DNS domain value of Confluent Cloud.
The value is in the
<region>.aws.private.confluent.cloud
pattern.In the AWS Route 53 console, create a Route53 Private Hosted Zone:
Specify the following values:
- Domain name: Confluent Cloud DNS domain value from the previous step
- Type:
Private hosted zone
- VPC ID: VPC ID where you added the VPC Endpoint
For example:
Click Create hosted zone to associate the Private Hosted Zone with your VPC.
Create a DNS record for the Hosted Zone you created above.
This record is regional DNS and is used for all the target Confluent Cloud resources in the region.
Click Create Record from within the previously created Hosted Zone.
Specify the following values:
Record name:
*
Enter
*
as the subdomain name.The Record name consists of the subdomain and the DNS domain name. The DNS domain name is filled in with the Confluent Cloud DNS domain value you specified when you created the Route53 Private Hosted Zone in the previous step.
Record type:
CNAME
Value: DNS Name of your VPC Interface Endpoint, such as
vpce-<>.vpce-svc-<>.us-east-2.vpce.amazonaws.com
.
Click Create Record.
You will see the summary of the new record. For example:
Connectivity scenarios¶
Below are a few connectivity scenarios that are supported for Enterprise clusters in Confluent Cloud.
Scenario: Access one environment from one VPC¶
The following resources are configured:
PLATT-prod
as a PrivateLink Attachment for accessing Kafka clusters in the env-prod environmentPLATTC-123
as a PrivateLink Attachment Connection for thevpce-1
VPC endpoint inVPC-1
ProdApp
as a Kafka client bootstrapped withlkc-123.us-west-2.aws.private.confluent.cloud
phz-1
as a Route53 Private Hosted Zone with the regional wildcard*.us-west-2.aws.private.confluent.cloud
The following steps are performed:
ProdApp
attempts to accesslkc-123
in the env-prod environment. A DNS query forlkc-123.us-west-2.aws.private.confluent.cloud
resolves againstphz-1
and returnsvpce-1
.- Application sends traffic to
vpce-1
. vpce-1
forwards traffic toPLATT-prod
, andlkc-123
can be accessed sincePLATTC-123
is associated withvpce-1
.
Scenario: Access one environment from many VPC’s¶
The following resources are configured:
PLATT-abc
as a PrivateLink Attachment for accessing Kafka clusters in the env-prod environmentPLATTC-123
as a PrivateLink Attachment Connection for thevpce-1
VPC endpoint inVPC-1
PLATTC-456
for thevpce-2
VPC endpoint in VPC-2ProdApp-1
as a Kafka client bootstrapped withlkc-123.us-west-2.aws.private.confluent.cloud
ProdApp-2
as a Kafka client bootstrapped withlkc-456.us-west-2.aws.private.confluent.cloud
phz-1
as a Route53 Private Hosted Zone with the regional wildcard*.us-west-2.aws.private.confluent.cloud
phz-2
as a Route53 Private Hosted Zone with the regional wildcard*.us-west-2.aws.private.confluent.cloud
The following steps are performed:
ProdApp-1
attempts to accesslkc-123
in the env-prod environment. A DNS query forlkc-123.us-west-2.aws.private.confluent.cloud
resolves againstphz-1
and returnsvpce-1
.ProdApp-1
sends traffic tovpce-1
.vpce-1
forwards traffic toPLATT-abc
, andlkc-123
can be accessed sincePLATTC-123
is associated withvpce-1
.ProdApp-2
attempts to accesslkc-456
in the env-prod environment. A DNS query forlkc-456.us-west-2.aws.private.confluent.cloud
resolves againstphz-2
and returnsvpce-2
.ProdApp-2
sends traffic tovpce-2
.vpce-2
forwards traffic toPLATT-abc
, andlkc-456
can be accessed sincePLATTC-456
is associated withvpce-2
.
Scenario: Access one environment from an on-premises network¶
The following resources are configured:
PLATT-abc
as a PrivateLink Attachment for accessing Kafka clusters in the env-abc environmentPLATTC-123
as a PrivateLink Attachment Connection for thevpce-1
endpoint inVPC-1
On-Prem-1
as a Kafka client bootstrapped withlkc-123.us-west-2.aws.private.confluent.cloud
ProdApp-1
as a Kafka client bootstrapped withlkc-123.us-west-2.aws.private.confluent.cloud
phz-fwd
as a DNS forwarding rule with the regional wildcard*.us-west-2.aws.private.confluent.cloud
phz-1
as a Route53 Private Hosted Zone with the regional wildcard*.us-west-2.aws.private.confluent.cloud
The following steps are performed:
On-Prem-1
attempts to accesslkc-123
in the env-abc environment. A DNS query forlkc-123.us-west-2.aws.private.confluent.cloud
forwards tophz-1
and returnsvpce-1
.On-Prem-1
sends traffic tovpce-1
over AWS DirectConnect.vpce-1
forwards traffic toPLATT-abc
andlkc-123
can be accessed sincePLATTC-123
is associated withvpce-1
.