external-dns VS cert-manager

Compare external-dns vs cert-manager and see what are their differences.

external-dns

Configure external DNS servers (AWS Route53, Google CloudDNS and others) for Kubernetes Ingresses and Services (by kubernetes-sigs)

cert-manager

Automatically provision and manage TLS certificates in Kubernetes (by cert-manager)
Our great sponsors
  • WorkOS - The modern identity platform for B2B SaaS
  • InfluxDB - Power Real-Time Data Analytics at Scale
  • SaaSHub - Software Alternatives and Reviews
external-dns cert-manager
79 101
7,242 11,429
1.7% 1.5%
9.6 9.6
5 days ago 6 days ago
Go Go
Apache License 2.0 Apache License 2.0
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

external-dns

Posts with mentions or reviews of external-dns. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-04-03.
  • Upgrading Hundreds of Kubernetes Clusters
    17 projects | dev.to | 3 Apr 2024
    The second one is a combination of tools: External DNS, cert-manager, and NGINX ingress. Using these as a stack, you can quickly deploy an application, making it available through a DNS with a TLS without much effort via simple annotations. When I first discovered External DNS, I was amazed at its quality.
  • Kubernetes External DNS provider for Hetzner
    2 projects | /r/hetzner | 3 Nov 2023
    One of the reasons why I chose Hetzner was that it WAS supported by the ExternalDNS project. I didn't quite understand why the Hetzner provider was pulled, but I saw that an attempt of re-adding it was refused, on the ground that the upcoming webhook architecture would have allowed to better maintain providers.
  • Istio Multi-Cluster Setup
    1 project | /r/kubernetes | 25 Jun 2023
    Write a custom controller for the external DNS controller, or setup some form of ArgoCD app / appset templating.
  • Looking for ExternalDns alternative for non k8s environment
    1 project | /r/Traefik | 5 Jun 2023
    so I am looking at having an automated way for new routers registered in Traefik to also have the corresponding DNS entry added to my Pihole instance similar to external-dns but obviously, this is exclusive to ingress on k8s environments. my current setup is traefik in a container on unraid.
  • Is a Load Balancer necessary for a HA Cluster?
    1 project | /r/kubernetes | 21 May 2023
    You technically don’t need to run a load balancer or have a virtual IP for your control plane. If you control your dns, you can add an A record pointing to all IPs for your control plane nodes. It won’t load balance your traffic, but combined with something like External DNS it gives you HA for the control plane.
  • How can I assign an EIP to a Kubernetes deployment?
    1 project | /r/aws | 9 May 2023
    I normally deploy external-dns, which automatically updates DNS with the ingress controller's external IP address.
  • Registering DNS with Windows Domain DNS
    1 project | /r/kubernetes | 24 Apr 2023
    Background: Having a look I can see this https://github.com/kubernetes-sigs/external-dns
  • Cluster nodes on different networks
    1 project | /r/kubernetes | 4 Apr 2023
    3) Use the Kubernetes External-DNS. I've never used this, but this is assuming it can update DNS for each pods/app to point to the correct Node (it'd need to update my Homelab DNS running on Windows Server)
  • I am stuck on learning how to provision K8s in AWS. Security groups? ALB? ACM? R53?
    3 projects | /r/Terraform | 19 Mar 2023
    So here’s the solution I have taken for our current stack. EKS and its dependencies are created through terraform using the eks module as well as provision a route53 subdomain and a wildcard cert. Once we have that created, I have installed this deployment into the cluster via the helm module: https://kubernetes-sigs.github.io/aws-load-balancer-controller/v2.4/. This allows me to use kuberentes resources (load balancers or ingress objects) and it will handle all the provisioning of load balancers and security groups for me, based on my application yaml and annotations. We also use https://github.com/kubernetes-sigs/external-dns to manage all of our specific host names for the applications through annotations. So to generally put, terraform manages out Kubernetes clusters, and Kubernetes manages the deployment of anything needed for the application including volumes, load balancers, hostnames though Kubernetes system deployments
  • How to expose services/apps to my home network with custom DNS names
    1 project | /r/kubernetes | 26 Feb 2023
    Metallb for your load balancer (layer2 mode will do) NginX-ingress, will be spot on for internal home apps External-dns to publish your dns record to your Dns server at home, https://github.com/kubernetes-sigs/external-dns

cert-manager

Posts with mentions or reviews of cert-manager. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-04-08.
  • deploying a minio service to kubernetes
    3 projects | dev.to | 8 Apr 2024
    cert-manager
  • Upgrading Hundreds of Kubernetes Clusters
    17 projects | dev.to | 3 Apr 2024
    The second one is a combination of tools: External DNS, cert-manager, and NGINX ingress. Using these as a stack, you can quickly deploy an application, making it available through a DNS with a TLS without much effort via simple annotations. When I first discovered External DNS, I was amazed at its quality.
  • Run WebAssembly on DigitalOcean Kubernetes with SpinKube - In 4 Easy Steps
    6 projects | dev.to | 27 Mar 2024
    On top of its core components, SpinKube depends on cert-manager. cert-Manager is responsible for provisioning and managing TLS certificates that are used by the admission webhook system of the Spin Operator. Let’s install cert-manager and KWasm using the commands shown here:
  • Importing kubernetes manifests with terraform for cert-manager
    1 project | dev.to | 17 Jan 2024
    terraform { required_providers { kubectl = { source = "gavinbunney/kubectl" version = "1.14.0" } } } # The reference to the current project or a AWS project data "google_client_config" "provider" {} # The reference to the current cluster or EKS data "google_container_cluster" "my_cluster" { name = var.cluster_name location = var.cluster_location } # We configure the kubectl provider to use those values for authenticating provider "kubectl" { host = data.google_container_cluster.my_cluster.endpoint token = data.google_client_config.provider.access_token cluster_ca_certificate = base64decode(data.google_container_cluster.my_cluster.master_auth[0].cluster_ca_certificate) } #Download the multiple manifests file. data "http" "cert_manager_crds" { url = "https://github.com/cert-manager/cert-manager/releases/download/v${var.cert_manager_version}/cert-manager.crds.yaml" } data "kubectl_file_documents" "cert_manager_crds" { content = data.http.cert_manager_crds.response_body lifecycle { precondition { condition = 200 == data.http.cert_manager_crds.status_code error_message = "Status code invalid" } } } # We use the for_each or else this kubectl_manifest will only import the first manifest in the file. resource "kubectl_manifest" "cert_manager_crds" { for_each = data.kubectl_file_documents.cert_manager_crds.manifests yaml_body = each.value }
  • An opinionated template for deploying a single k3s cluster with Ansible backed by Flux, SOPS, GitHub Actions, Renovate, Cilium, Cloudflare and more!
    6 projects | /r/kubernetes | 4 Dec 2023
    SSL certificates thanks to Cloudflare and cert-manager
  • Deploy Rancher on AWS EKS using Terraform & Helm Charts
    3 projects | dev.to | 14 Nov 2023
    kubectl apply -f https://github.com/cert-manager/cert-manager/releases/download/${CERT_MANAGER_VERSION}/cert-manager.crds.yaml
  • Setup/Design internal PKI
    1 project | /r/sysadmin | 4 Nov 2023
    put the Sub-CA inside hashicorp vault to be used for automatic signing of services like https://cert-manager.io/ inside our k8s clusters.
  • Task vs Make - Final Thoughts
    3 projects | dev.to | 10 Aug 2023
    install-cert-manager: desc: Install cert-manager deps: - init-cluster cmds: - kubectl apply -f https://github.com/cert-manager/cert-manager/releases/download/{{.CERT_MANAGER_VERSION}}/cert-manager.yaml - echo "Waiting for cert-manager to be ready" && sleep 25 status: - kubectl -n cert-manager get pods | grep Running | wc -l | grep -q 3
  • Easy HTTPS for your private networks
    13 projects | news.ycombinator.com | 10 Jul 2023
    I've been pretty frustrated with how private CAs are supported. Your private root CA can be maliciously used to MITM every domain on the Internet, even though you intend to use it for only a couple domain names. Most people forget to set Name Constraints when they create these and many helper tools lack support [1][2]. Worse, browser support for Name Constraints has been slow [3] and support isn't well tracked [4]. Public CAs give you certificate transparency and you can subscribe to events to detect mis-issuance. Some hosted private CAs like AWS's offer logs [5], but DIY setups don't.

    Even still, there are a lot of folks happily using private CAs, they aren't the target audience for this initial release.

    [1] https://github.com/FiloSottile/mkcert/issues/302

    [2] https://github.com/cert-manager/cert-manager/issues/3655

    [3] https://alexsci.com/blog/name-non-constraint/

    [4] https://github.com/Netflix/bettertls/issues/19

    [5] https://docs.aws.amazon.com/privateca/latest/userguide/secur...

  • ☸️ Managed Kubernetes : Our dev is on AWS, our prod is on OVH
    6 projects | dev.to | 1 Jul 2023
    the Cert Manager

What are some alternatives?

When comparing external-dns and cert-manager you can also consider the following projects:

metallb - A network load-balancer implementation for Kubernetes using standard routing protocols

cloudflare-ingress-controller - A Kubernetes ingress controller for Cloudflare's Argo Tunnels

aws-load-balancer-controller - A Kubernetes controller for Elastic Load Balancers

ingress-nginx - Ingress-NGINX Controller for Kubernetes

Portainer - Making Docker and Kubernetes management easy.

crossplane - The Cloud Native Control Plane

awx-operator - An Ansible AWX operator for Kubernetes built with Operator SDK and Ansible. 🤖

PowerDNS - PowerDNS Authoritative, PowerDNS Recursor, dnsdist

k3s - Lightweight Kubernetes

oauth2-proxy - A reverse proxy that provides authentication with Google, Azure, OpenID Connect and many more identity providers.