Kamal Verma:
Hi All,
Need help as I am not able to understand the solution mentioned for Practice Test - Troubleshoot Network in CKA Course.
Section 13: Troubleshooting -> Practice Test - Troubleshoot Network - Question 2
I can see from Kube-proxy logs below error
controlplane $ kubectl logs -f kube-proxy-4zwst -n kube-system
F0630 20:12:55.120890 1 server.go:490] failed complete: open /var/lib/kube-proxy/configuration.conf: no such file or directory
I have check the DeamonSet for Kubeproxy and I could see Config map is mount on Kubeproxy DS.
In Configmap also the kubeconfig: /var/lib/kube-proxy/kubeconfig.conf and this path does not exists.
controlplane $ kubectl describe cm kube-proxy -n kube-system
Name: kube-proxy
Namespace: kube-system
Labels: app=kube-proxy
Annotations: http://kubeadm.kubernetes.io/component-config.hash|kubeadm.kubernetes.io/component-config.hash : sha256:fd1719f5b165f8b868725bb0f9ee65a6d1f27d4d833791d68a51a731cb8d20be
Data
config.conf:
apiVersion: http://kubeproxy.config.k8s.io/v1alpha1|kubeproxy.config.k8s.io/v1alpha1
bindAddress: 0.0.0.0
bindAddressHardFail: false
clientConnection:
acceptContentTypes: “”
burst: 0
contentType: “”
kubeconfig: /var/lib/kube-proxy/kubeconfig.conf
qps: 0
Please help me to understand the exact reason for the issue.
Thanks,
Kamal
1 Like
Phani M:
Hi @Kamal Verma if you look at the config map for kube-proxy by doing
controlplane $ k get cm kube-proxy -n kube-system -o yaml
apiVersion: v1
data:
config.conf: |-
apiVersion: <http://kubeproxy.config.k8s.io/v1alpha1|kubeproxy.config.k8s.io/v1alpha1>
the first item in data portion says config.conf
whereas in the daemonset yaml manifest, the --config refers to
/var/lib/kube-proxy/configuration.conf
If you look at the VolumeMounts for the daemonset, the configuration is being mounted from the configMap.
So in order to make the kube-proxy pods to be up and running, do this:
k edit ds kube-proxy -n kube-system
change the --config
path as /var/lib/kube-proxy/config.conf
check the kube-proxy pods should be in Running status in the kube-system namespace
Hope this clears your question
2 Likes
This is a problem, because not exist folder “/var/lib/kube-proxy/” in server
The directory “/var/lib/kube-proxy” is not present on the server.
The solution explain for this ‘lab’ is badly clear.
The folder ‘var/lib/kube-proxy/’ is not present in controlplane node but inside the runnig kube-proxy pod.
You can check the folder/file within pod, accessing it directly:
kubectl exec -it kube-proxy-XXXXX -n kube-system – /bin/sh
Once inside the pod you can check then
ls -l /var/lib/kube-proxy/
This is something tricky and you will not find a solution video for this lab.
Here you need to know kube-proxy default configuration file location and file name.
Then you need to edit the daemon set yaml file.
k edit -n kube-systems ds kube-proxy
–config=/var/lib/kube-proxy/config.conf
The solutions to this lab are here
# Solution Troubleshoot Network
Lets have a look at the [Practice Test](https://kodekloud.com/topic/practice-test-troubleshoot-network/) of the Troubleshoot Network
Note that this lab is sequential. You must solve test 1 completely before you can solve test 2, i.e. you cannot skip test 1 and do test 2 only.
1. <details>
<summary>Troubleshooting Test 1</summary>
We are asked to ensure all the components are working, so first let's examine the cluster to see what state it is in.
How many nodes, and their status?
```
kubectl get nodes
```
Seems OK...
Next, the pods
This file has been truncated. show original