Hear from Salesforce leaders on how to create and deploy Agentforce agents.
Contact Us 1-800-596-4880

Provide a Domain Name for an Application on Your Kubernetes Cluster

Use ExternalDNS to expose an application or service on your Kubernetes cluster through a domain name instead of a difficult-to-understand external IP or random host name.

ExternalDNSLeaving the Site is an open source project that supports DNS configurations on many DNS providers. The tool is not a DNS server or provider. Instead, ExternalDNS discovers Kubernetes resources through public DNS servers and configures the resources for supported DNS providers.

This guide uses ExternalDNS to configure domain names in an AWS Route 53 provider, which is one of the stable providers supported by ExternalDNS.

Before You Begin

Ensure that the following prerequisites are in place:

Add ExternalDNS to Your Cluster

Add ExternalDNS (external-dns) to your cluster by creating and deploying a YAML configuration file with the following content to your cluster:

  1. Create a YAML file with the following settings.

  2. In your new YAML file, set the following options, as needed, for your deployment:

    • args options:

      • - --domain-filter=<your-domain>: Make hosted zones that match your domain visible to ExternalDNS. Omit this option to process all available hosted zones.

        The option is critical for making external-dns work as intended.

      • - --policy=upsert-only: Prevent ExternalDNS from deleting any records. Omit this option to enable full synchronization.

      • - --aws-zone-type=public: Make only public hosted zones visible. Valid values are public, private, or no value for both types of zones.

    • env option value: <aws-region>: Set the region in which your EKS cluster is installed, for example, us-east-1.

  3. If you are using static credentials, remove the comments (#) from the lines that contain hidden env and volumes configurations.

  4. Apply the configuration to your cluster by using the following command from a terminal window:

    kubectl create --filename <external-dns-yaml> --namespace <your-namespace>
    kubctl

Set DNS Names through Your Helm Chart for Flex Gateway

Use the extraAnnotations parameter with helm upgrade to set the domain names. This parameter is described in the Helm chart for Flex Gateway (flex-gateway)Leaving the Site.

  1. Create a YAML configuration file to specify an ExternalDNS key and a comma-separated set of domain values.

    Replace the placeholder values <domain-0>,…​,<domain-N> with your domains:

    extraAnnotations:
      external-dns.alpha.kubernetes.io/hostname: <domain-0>,...,<domain-N>
  2. Use the -f option to pass your configuration file to the helm upgrade command.

    The command options to use depend on whether your registered gateway is deployed to a cluster:

    1. If you are deploying Flex Gateway to the cluster for the first time, run the following command, replacing the placeholder values with the path to your gateway’s registration YAML file (by default, registration.yaml) and your domain names:

      helm -n gateway upgrade \
      -i --create-namespace \
      --wait ingress flex-gateway/flex-gateway \
      --set-file registration.content=<path-to-registration> \
      -f <your-YAML-config-file>
      helm
    2. If you are updating a running gateway with the annotation, run the following command:

      helm -n gateway upgrade \
      --wait ingress flex-gateway/flex-gateway \
      --reuse-values \
      -f <your-YAML-config-file>
      helm