Resolve you cluster domain
If you are running a local k8s
instance, you might want to configure your
local setup so that it is able to resolve the domain of the cluster. So that
out-of-cluster running programs can access your services.
There are a couple of options available to you, all with their pros & cons. We will list some of them in this document. Note that this is not a exhaustive coverage of all the possibilities and feel free to contribute to the documentation if you have other ways of doing this.
Prerequisite
Before you start, you need to have access to a running Kubernetes cluster environment. A Minikube instance running on your laptop will do fine.
Start minikube with a parametrized dns-domain
name
$ minikube start --dns-domain='demo.arkmq-org.io'
😄 minikube v1.32.0 on Fedora 39
🎉 minikube 1.33.1 is available! Download it: https://github.com/kubernetes/minikube/releases/tag/v1.33.1
💡 To disable this notice, run: 'minikube config set WantUpdateNotification false'
✨ Automatically selected the kvm2 driver. Other choices: qemu2, ssh
👍 Starting control plane node minikube in cluster minikube
🔥 Creating kvm2 VM (CPUs=2, Memory=6000MB, Disk=20000MB) ...
🐳 Preparing Kubernetes v1.28.3 on Docker 24.0.7 ...
▪ Generating certificates and keys ...
▪ Booting up control plane ...
▪ Configuring RBAC rules ...
🔗 Configuring bridge CNI (Container Networking Interface) ...
▪ Using image gcr.io/k8s-minikube/storage-provisioner:v5
🔎 Verifying Kubernetes components...
🌟 Enabled addons: storage-provisioner, default-storageclass
🏄 Done! kubectl is now configured to use "minikube" cluster and "default" namespace by default
Get minikube’s ip
minikube ip
192.168.39.54
Note that every time you restart minikube you’ll have to follow update the ip in the configuration files.
/etc/hosts
The generic way to make the url resolve to an IP address is to update the
/etc/hosts/
. There’s no wildcard in this file, this means you’ll need to
specify all the urls you are interested in.
Here’s an example for an ingress:
$ cat /etc/hosts
192.168.39.54 ing.sslacceptor.send-receive-0.send-receive-project.demo.arkmq-org.io
pros
- Works on every setup and is simple
cons
- No wildcard, you need to list every domains and subdomains you’ll need to access
NetworkManager’s DNSMasq plugin
We will use networkmanager’s dnsmasq plugin
(source)to
configure the ip associated with the domain demo.arkmq-org.io
. The dnsmasq plugin
has wildcards which is better than setting manually every hosts in the
/etc/hosts
file.
Configure DNSMasq
The goal here is to set up enable dnsmasq and to make it resolve your cluster
domain demo.arkmq-org.io
to the cluster’s ip address. Because DNSMasq has a
wildcard, all subdomains will also resolve to the same ip address.
- Create the following files:
$ cat << EOF > /etc/NetworkManager/conf.d/00-use-dnsmasq.conf
[main]
dns=dnsmasq
EOF
$ cat << EOF > /etc/NetworkManager/dnsmasq.d/00-demo.arkmq-org.io.conf
local=/demo.arkmq-org.io/
address=/.demo.arkmq-org.io/192.168.39.54
EOF
$ cat << EOF > /etc/NetworkManager/dnsmasq.d/02-add-hosts.conf
addn-hosts=/etc/hosts
EOF
- restart NetworkManager:
$ sudo systemctl restart NetworkManager
pros
- Has wildcard, you only need to setup the ip once
Cons
- Works only with NetworkManager
Minikube’s ingress-dns
plugin:
Follow the official documentation.
pros
- Has wildcard, you only need to setup the ip once
- Supported for every setup (linux, mac, windows)
cons
- Can only resolve the ingresses URLs