I am trying reach my k8s master from my workstation. I can access the master from the LAN fine but not from my workstation. The error message is:
% kubectl --context=employee-context get pods
Unable to connect to the server: x509: certificate is valid for 10.96.0.1, 10.161.233.80, not 114.215.201.87
How can I do to add 114.215.201.87 to the certificate? Do I need to remove my old cluster ca.crt, recreate it, restart whole cluster and then resign client certificate? I have deployed my cluster with kubeadm and I am not sure how to do these steps manually.
This command for new kubernetes >=1.8:
Also whould be better to add dns name into
--apiserver-cert-extra-sans
for avoid issues like this in next time.For kubeadm v1.13.3
If you used kubespray to provision your cluster then you need to add a 'floating ip' (in your case its '114.215.201.87'). This variable is called
supplementary_addresses_in_ssl_keys
in thegroup_vars/k8s-cluster/k8s-cluster.yml
file. After updating it, just re-run youransible-playbook -b -v -i inventory/<WHATEVER-YOU-NAMED-IT>/hosts.ini cluster.yml
.NOTE: you still have to remove all the apiserver certs (
rm /etc/kubernetes/pki/apiserver.*
) from each of your master nodes prior to running!One option is to tell
kubectl
that you don't want the certificate to be validated. Obviously this brings up security issues but I guess you are only testing so here you go:The better option is to fix the certificate. Easiest if you reinitialize the cluster by running
kubeadm reset
on all nodes including the master and then doIt's also possible to fix that certificate without wiping everything, but that's a bit more tricky. Execute something like this on the master as root:
Issue cause: Your configs at $HOME/.kube/ are present with your old IP address.
Try running,
Use the following command: