Use AWS VPC Peering with Confluent Cloud

AWS VPC peering enables you to route traffic using private IPv4 addresses between your AWS virtual private cloud (VPC) and Confluent Cloud. Your VPC can communicate with Confluent Cloud as if they are within the same network.

Confluent Cloud is available through AWS Marketplace or directly from Confluent.

For more information about VPC peering with AWS, see Introduction to Amazon VPC.

Managed connectors created in a VPC-peered cluster can access data sources and sinks hosted in all peered VPCs, if the firewall rules allow connector traffic to and from the peered VPCs.

When you set up a VPC peering connection between AWS VPC and Confluent Cloud using /27 CIDR blocks, the following Confluent Cloud feature is supported:

  • Fetch from Follower, a cost optimization to allow clients to consume from the nearest follower, instead of the leader

The high-level workflow to set up a VPC peering connection to Confluent Cloud:

  1. Identify a Confluent Cloud network you want to use, or set up a new Confluent Cloud network.
  2. In Confluent Cloud, create a VPC peering connection.
  3. In AWS, accept the peering request.
  4. In AWS, add the new connection to the route table.
  5. To support outbound connections from Confluent Cloud, set up DNS forwarding in Confluent Cloud.

Requirements and considerations

  • A Confluent Cloud network of the “VPC Peering” type and the “AWS” provider.

    Pay special attention that the CIDR blocks you select satisfy the requirements described in Confluent Cloud network CIDR blocks and block size for peering and Transit Gateway.

  • All AWS availability zones, except use1-az3 in the us-east-1 region, are supported.

  • Transitive VPC peering is not supported.

    If you peer Network A to Network B, and peer Network B to Confluent Cloud, applications running in Network A will not be able to access Confluent Cloud. Although they don’t provide transitive routing, shared AWS VPCs can be leveraged to enable Confluent Cloud connectivity. For more information, see AWS Working with Shared VPCs.

    To achieve transitivity, you can link an AWS Transit Gateway to a Confluent Cloud cluster in AWS.

  • You can have multiple VPC peering connections. For information about limits, see Network quotas in Confluent Cloud.

  • You can colocate multiple Confluent Cloud Dedicated clusters in the same Confluent Cloud network, but this is limited by the expected number and size of the clusters. The applicable limits are specified in Networks.

  • Cross-region peering is not supported through the Confluent Cloud Console. Contact Confluent Support to see if your regions are supported and to request configuration.

  • You might need to increase your route quota when you use VPC peering because the Confluent Cloud and AWS routes are shared.

  • If you have custom DNS, your DNS servers must be able to access the authoritative DNS servers for Confluent Cloud, which are hosted by Confluent on the internet.

  • Access to Confluent Cloud serverless products

    Connections established for use with Dedicated Kafka clusters may also be used to connect to some serverless products. For service-specific information, see:

Create a VPC peering connection

This section describes how to create an AWS VPC peering connection to a Confluent Cloud network.

Step 1: Create a VPC peering connection in Confluent Cloud

You need to gather the following information from the Amazon VPC Console:

  • The AWS account ID associated with the VPC you are peering to Confluent Cloud network.
  • The AWS VPC ID you are peering with Confluent Cloud network.
  • The CIDR block of the AWS VPC you are peering with the Confluent Cloud network.

Follow the steps below to create a VPC peering connection in Confluent Cloud.

  1. In the Network Management tab of the desired Confluent Cloud environment, click the For dedicated cluster tab.

  2. Click the Confluent Cloud network to which you want to add the peering connection.

  3. In the Ingress connections tab, click + VPC Peering.

  4. Specify the following field values.

    • Name: The name of this connection.
    • AWS Account Number: The AWS account ID associated with the VPC you are peering to Confluent Cloud network.
    • AWS VPC ID: The AWS VPC ID you are peering with Confluent Cloud network.
    • AWS VPC CIDR: The CIDR block of the AWS VPC you are peering with the Confluent Cloud network.
  5. Click Add.

    Peering connection provisioning will take a few minutes to complete. Your peering connection status will transition from “Provisioning” to “Waiting for connection” in the Confluent Cloud Console.

Step 2: Accept the peering connection request in AWS

When the connection status is “Waiting for connection” in the Confluent Cloud Console, go to the Amazon VPC Console and accept the peering request.

You have seven days to accept the request before it expires. For details on accepting peering connections, refer to Create and accept VPC peering connections in Amazon Virtual Private Cloud in the AWS documentation.

If your request has expired, contact Confluent to resend the request. After you have accepted the peering request, the status of the peering connection will change to “Ready”.

  1. In the Amazon VPC Console, click Peering connections in the navigation pane.

  2. Select the pending VPC peering connection (the status is Pending acceptance).

    If there is no pending VPC peering connection, verify that you selected the Region of the accepter VPC.

  3. Click Actions, and click Accept request.

  4. When prompted for confirmation, choose Accept request.

    Save the connection id. The value is prefixed with pcx-. You need to input this value in the next step when you add the connection to the route table.

When the connection request is accepted, the connection status becomes “Ready” in the Confluent Cloud Console.

Step 3: Add the new connection to the route table in AWS

Add the new peering connection that you accepted in Step 2: Accept the peering connection request in AWS, to the route table for your VPC. For details on updating route tables, see the AWS documentation.

For the routing to become effective, the route table must be associated with subnet(s).

  1. Go to the Amazon VPC Console, and click Route Tables.

  2. Select the route table for your VPC and click Edit routes.

  3. Click Add route, and specify the following.

    Add routes for all three /27 CIDR blocks to all your VPC route tables, not just the zone-aligned routes.

    • Destination: Specify the Confluent Cloud network VPC CIDR block.

      You can find the Confluent Cloud network VPC CIDR blocks in the Network Overview of your Confluent Cloud network, in the Confluent Cloud CIDR field.

    • Target:

      1. Select Peering connection.
      2. Specify the Peering connection ID of the new connection you accepted in Step 2: Accept the peering connection request in AWS. The value is prefixed with pcx-.
  4. Click Save changes.

  5. Update the network ACLs on your VPCs.

    If required, update the security group rules that are associated with your EC2 instance to ensure that traffic can flow between your VPCs and the Confluent Cloud network.

Configure DNS forwarding

To resolve hostnames that reside within private DNS zones or a self-hosted DNS server and access your own VPC or on-prem from Confluent Cloud, set up DNS forwarding in Confluent Cloud.

For example, you can use DNS forwarding for Confluent Cloud fully-managed connectors that need to access data in your VPC.

DNS forwarding requires VPC peering or TGW connection where there is bi-directional network access between your network and Confluent Cloud clusters.

Step 1: Get DNS resolver IP addresses

To use the DNS forwarding feature with your AWS VPC, you can set up AWS Inbound Endpoints or use your own DNS server:

  • If you wish to forward DNS requests from Confluent Cloud to a Route53 hosted zone, create Inbound Endpoints for Confluent Cloud network to access your DNS servers.

    AWS recommends deploying multiple endpoints in different availability zones for availability reasons.

    For details, see Configuring inbound endpoints.

    Once the endpoints are created, input the IP addresses of the Inbound Endpoints to which to forward requests as described in the next step.

  • If you want to use your self-hosted DNS server, use the IP address of that DNS server in Confluent Cloud in the next step.

Step 2: Create a DNS Forwarder in Confluent Cloud

Set up DNS forwarding in Confluent Cloud:

  1. In Confluent Cloud, navigate to the DNS Forwarding tab on the Network Detail page.
  2. Input the following information:
    • DNS server IPs: Up to 3 IP addresses of your DNS servers to which we should forward DNS requests.
    • Domain list: Up to 10 domains to which you wish to route the DNS requests.
  3. Wait until provisioning is complete and DNS is propagated.

Next steps

Try Confluent Cloud on AWS Marketplace with $1000 of free usage for 30 days, and pay as you go. No credit card is required.