Section 13.3 - Setting up the dashboard
Summary: I would love some help setting up/viewing my Kubernetes Dashboard. Right now, no matter what I do, I get ERR_CONNECTION_REFUSED when attempting to access it.
Details --
- I used helm pull to grab the
kubernetes-dashboard
chart. - I modified the chart's values.yaml to make it a NodePort, then installed with
helm install...
:
service: type: NodePort # Dashboard service port externalPort: 443
(I named the installation "kdash"; otherwise my setup seems identical to the instructions)
- I successfully added the role binding (reformatted for readability):
~$ kubectl get rolebindings,clusterrolebindings --all-namespaces NAME: clusterrolebinding.rbac.authorization.k8s.io/dashaccess ROLE: ClusterRole/cluster-admin NAME: clusterrolebinding.rbac.authorization.k8s.io/kdash-kubernetes-dashboard-metrics ROLE: ClusterRole/kdash-kubernetes-dashboard-metrics
- Other parameters check out too --
- The service exists as a nodeport with an open port:
$ kubectl get svc kdash-kubernetes-dashboard NodePort 10.99.89.8 <none> 443:32599/TCP $ kubectl describe svc kdash-kubernetes-dashboard Type: NodePort IP Family Policy: SingleStack IP Families: IPv4 IP: 10.99.89.8 IPs: 10.99.89.8 Port: https 443/TCP TargetPort: https/TCP NodePort: https 32599/TCP Endpoints: 192.168.169.236:8443 Session Affinity: None External Traffic Policy: Cluster
- The pod exists and is reachable:
$ kubectl get pods kdash-kubernetes-dashboard-66446945c5-qhf8f 1/1 Running $ kubectl describe pod kdash-kubernetes-dashboard-66446945c5-qhf8f Name: kdash-kubernetes-dashboard-66446945c5-qhf8f Node: k8stest-raw-worker/10.2.0.5 Start Time: Wed, 09 Nov 2022 18:25:04 +0000 Labels: app.kubernetes.io/component=kubernetes-dashboard app.kubernetes.io/instance=kdash app.kubernetes.io/managed-by=Helm app.kubernetes.io/name=kubernetes-dashboard app.kubernetes.io/version=2.7.0 helm.sh/chart=kubernetes-dashboard-5.11.0 pod-template-hash=66446945c5 Annotations: cni.projectcalico.org/containerID: 2d4d90457004e845d7d4f8111a6d11b1f9145a96fee7024e4093a71e1fb75a66 cni.projectcalico.org/podIP: 192.168.169.236/32 cni.projectcalico.org/podIPs: 192.168.169.236/32 seccomp.security.alpha.kubernetes.io/pod: runtime/default Status: Running IP: 192.168.169.236 IPs: IP: 192.168.169.236 Controlled By: ReplicaSet/kdash-kubernetes-dashboard-66446945c5 Containers: kubernetes-dashboard: Container ID: containerd://1f8d2f2bb0a0a09e6d5cb6f0275cc1e0fcd9b77ee8acca40a8736bc520785f4c Image: kubernetesui/dashboard:v2.7.0 Image ID: docker.io/kubernetesui/dashboard@sha256:2e500d29e9d5f4a086b908eb8dfe7ecac57d2ab09d65b24f588b1d449841ef93 Port: 8443/TCP Host Port: 0/TCP Args: --namespace=default --auto-generate-certificates --metrics-provider=none State: Running Started: Wed, 09 Nov 2022 18:42:07 +0000 Last State: Terminated Reason: Error Exit Code: 2 Started: Wed, 09 Nov 2022 18:41:17 +0000 Finished: Wed, 09 Nov 2022 18:41:17 +0000 Ready: True Restart Count: 4
- Logs look normal:
$ kubectl logs kdash-kubernetes-dashboard-66446945c5-qhf8f 2022/11/09 18:42:07 Starting overwatch 2022/11/09 18:42:07 Using namespace: default 2022/11/09 18:42:07 Using in-cluster config to connect to apiserver 2022/11/09 18:42:07 Using secret token for csrf signing 2022/11/09 18:42:07 Initializing csrf token from kubernetes-dashboard-csrf secret 2022/11/09 18:42:07 Successful initial request to the apiserver, version: v1.24.0 2022/11/09 18:42:07 Generating JWE encryption key 2022/11/09 18:42:07 New synchronizer has been registered: kubernetes-dashboard-key-holder-default. Starting 2022/11/09 18:42:07 Starting secret synchronizer for kubernetes-dashboard-key-holder in namespace default 2022/11/09 18:42:07 Initializing JWE encryption key from synchronized object 2022/11/09 18:42:07 no metrics provider selected, will not check metrics. 2022/11/09 18:42:07 Auto-generating certificates 2022/11/09 18:42:07 Successfully created certificates 2022/11/09 18:42:07 Serving securely on HTTPS port: 8443
My CP IP:
$ curl ifconfig.io 34.134.162.12
But when I visit https://34.134.162.12/32599, I always get ERR_CONNECTION_REFUSED.
Other steps I've tried.
-Using the IP of my worker node: https://34.134.162.12/32599.
-Using different targetports: 80, 8080, 8443, etc.
-Using different browsers.
-Checking my firewall. All http and https requests are allowed on all ports (I know this because I had to change these settings in a previous exercise, to get the linkderd dashboard to appear)
-Deleting the dashboard pod
-Deleting and reinstalling with helm.
What am I missing? What steps should I take next?
Best Answers
-
@nlp
Yes, but I can access your dashboard UI.
So you've done something right.I'd look into:
- Client side/browser issues connecting on https to server with self signed cert. I'm using Firefox 105 which gives me a MOZILLA_PKIX_ERROR_SELF_SIGNED_CERT warning that I have to accept before I'm allowed to connect to your dashboard.
- 34.134.162.12 is in the Google cloud ipv4 range. Are there any security groups / edge firewall rules that would allow me, but not allow you, to connect?
0 -
Hi @nlp,
After reading that @pnts was successful in accessing your dash, I tried as well with both Chrome and Firefox. On Chrome I had to click on the "Advanced" button and then the "Proceed... (unsafe)" link at the bottom of the page. On Firefox similarly I had to "Accept" a certificate warning prior to being able to access the login page of the dash.
So, your dash app works, NP service exposes the dash publicly, and all you are left with is to create the access token and possibly use another browser to access the dash.
Regards,
-Chris0
Answers
-
Is this a problem with the dashboard or with external access in general?
Have you been able to create a service of type NodePort for a simple nginx deployment?You should be able to do
curl -k https://192.168.169.236:8443
on a worker node.
You should also be able to docurl -k https://10.99.89.8:443
on a worker node.
Finally, you should be able to docurl -k https://34.134.162.12:32599
from any computer.
Because I just did from my computer :-)I used Bearer token for authentication with my dashboard.
I was very simple to get going:
1. Creating a Service Account
2. Creating a ClusterRoleBinding
3. Getting a Bearer Token
https://github.com/kubernetes/dashboard/blob/master/docs/user/access-control/creating-sample-user.md0 -
Hi @nlp,
The output of your
kubectl describe
is missing the Events section, where possible reasons for the 4 restarts, and any errors that may have caused the unexpected terminations should be listed.Regards,
-Chris0 -
@chrispokorni said:
Hi @nlp,The output of your
kubectl describe
is missing the Events section, where possible reasons for the 4 restarts, and any errors that may have caused the unexpected terminations should be listed.Regards,
-ChrisChris, good eye. Here's the rest of the output from
kubectl describe...
; unfortunately Events doesn't tell us much:kubernetes-dashboard: Container ID: containerd://1f8d2f2bb0a0a09e6d5cb6f0275cc1e0fcd9b77ee8acca40a8736bc520785f4c Image: kubernetesui/dashboard:v2.7.0 Image ID: docker.io/kubernetesui/dashboard@sha256:2e500d29e9d5f4a086b908eb8dfe7ecac57d2ab09d65b24f588b1d449841ef93 Port: 8443/TCP Host Port: 0/TCP Args: --namespace=default --auto-generate-certificates --metrics-provider=none State: Running Started: Wed, 09 Nov 2022 18:42:07 +0000 Last State: Terminated Reason: Error Exit Code: 2 Started: Wed, 09 Nov 2022 18:41:17 +0000 Finished: Wed, 09 Nov 2022 18:41:17 +0000 Ready: True Restart Count: 4 Limits: cpu: 2 memory: 200Mi Requests: cpu: 100m memory: 200Mi Liveness: http-get https://:8443/ delay=30s timeout=30s period=10s #success=1 #failure=3 Environment: <none> Mounts: /certs from kubernetes-dashboard-certs (rw) /tmp from tmp-volume (rw) /var/run/secrets/kubernetes.io/serviceaccount from kube-api-access-7r4l6 (ro) Conditions: Type Status Initialized True Ready True ContainersReady True PodScheduled True Volumes: kubernetes-dashboard-certs: Type: Secret (a volume populated by a Secret) SecretName: kdash-kubernetes-dashboard-certs Optional: false tmp-volume: Type: EmptyDir (a temporary directory that shares a pod's lifetime) Medium: SizeLimit: <unset> kube-api-access-7r4l6: Type: Projected (a volume that contains injected data from multiple sources) TokenExpirationSeconds: 3607 ConfigMapName: kube-root-ca.crt ConfigMapOptional: <nil> DownwardAPI: true QoS Class: Burstable Node-Selectors: <none> Tolerations: node.kubernetes.io/not-ready:NoExecute op=Exists for 300s node.kubernetes.io/unreachable:NoExecute op=Exists for 300s Events: <none>
0 -
@pnts said:
Is this a problem with the dashboard or with external access in general?
Have you been able to create a service of type NodePort for a simple nginx deployment?You should be able to do
curl -k https://192.168.169.236:8443
on a worker node.
You should also be able to docurl -k https://10.99.89.8:443
on a worker node.
Finally, you should be able to docurl -k https://34.134.162.12:32599
from any computer.
Because I just did from my computer :-)I used Bearer token for authentication with my dashboard.
I was very simple to get going:
1. Creating a Service Account
2. Creating a ClusterRoleBinding
3. Getting a Bearer Token
https://github.com/kubernetes/dashboard/blob/master/docs/user/access-control/creating-sample-user.md@pnts, thanks for chiming in.
Is this a problem with the dashboard or with external access in general?
I would have said, "I don't know!", but I can indeed
curl -k https://34.134.162.12:32599
, so this must be an external access issue specific to this resource.Have you been able to create a service of type NodePort for a simple nginx deployment?
Yes, I've been able to complete every exercise until now, including the linkerd dashboard, which presents similar challenges.
I'll take a look at bearer tokens - good call.
To the folks who maintain this course: are you planning to include a bearer token-based approach to this problem? Or any kind of troubleshooting help? It's frustrating to be left high and dry with instructions that don't work consistently, and no recourse. Even if bearer tokens do work, it would be instructive to understand why the default approach didn't. External access does tend to be trickier than internal, so exercises like this would benefit from greater depth.
0 -
@nlp
You're fine.
https://34.134.162.12:32599 is accessible on the public internet.0 -
@pnts said:
@nlp
You're fine.
https://34.134.162.12:32599 is accessible on the public internet.@pnts, you're right about the bearer token creation - it's dead simple. My problem is, I can't even access the UI in order to enter the bearer token. I appreciate the help; unfortunately this doesn't fix this issue.
0 -
Well this is an odd one.
Over the last couple days I've tried accessing the dashboard in a "grid" fashion:
- On my work laptop
- On my personal laptop
- On my phone
On each of these devices, I tried multiple browsers:
- Chome
- Firefox
- Brave
- Edge
I cleared browser caches to eliminate that possibility. And just to be sure, I tried these steps both at home and at the office. Every combination yielded the same "connection refused" error.
The breakthrough? Using Safari on macOS 11.7 at home. Who knew.
@pnts and @chrispokorni, thank you! This was a real help; hopefully it helps future students who get tripped on this exercise.
To the people who maintain this course: this chapter has real deficiencies that need to be addressed:
- The assignment instructions differ too sharply from those in the dashboard repo. Yes, the lesson advises "check the readme for updates," and that's fine for a free online mini course or a stackoverflow post. In a $300 class, the instructions need to be accurate - that's what we're paying for.
- This lesson needs far more debugging advice, ideas for alternative access, and notes about common pitfalls. I've dealt with cert issues, caching issues, and cross browser incompatibility before - none of that prepared me for how extraordinarily finicky this particular web app would be. You need to prepare students for this.
- Help us out with stale details. The last time we discussed bearer tokens was in chapter 6, and if you follow this exercise, the bearer token you’ll need will be tied to the default service account, not the new dashboard account as the instructions suggest. I bypassed this issue easily only because of timely tips from @pnts - following the instructions would have sent me down yet another rabbit hole.
Omissions, elisions and inaccuracies like these will turn an enlightening lesson into a painful, unedifying slog. Yes, web administration involves frustration and dead ends. We buy courses like this to distill the relevant material and bypass some of those fiddly gotchas. This lesson did the opposite. I would have been better off ignoring the instructions and relying on forum posts and readmes.
1 -
Just adding some notes here. Was stuck at Lab 13.3 as well. I was able to access the installed dashboard using https://nodeip:highport , however there was no token as indicated by the lab pdf.
First created the clusterrolebinding "dashaccess" with clusterrole "cluster-admin" was created for the serviceaccount "default:kubernetes-dashboard" (in the current chart version, serviceaccount is called kubernetes-dashboard):
ck@cka1:~/kubernetes-dashboard$ kubectl create clusterrolebinding dashaccess --clusterrole=cluster-admin --serviceaccount=default:kubernetes-dashboard clusterrolebinding.rbac.authorization.k8s.io/dashaccess created
Needed to create a token manually as there was no token. A kind of similar post here in the forums already suggested that newer Kubernetes versions don't create tokens in secrets anymore (https://forum.linuxfoundation.org/discussion/862022/how-does-kubectl-create-token-work) and they need to be created manually:
ck@cka1:~/kubernetes-dashboard$ kubectl create token kubernetes-dashboard eyJhbGciOiJSUzI1NiIsImtpZCI6IndVb0ZRM2FsSzFPaE5Sb0lOR29XMFNsVjhRblJMbEd3anhYdHl5YTVyb3cifQ.eyJhdWQiOlsiaHR0cHM6Ly9rdWJlcm5ldGVzLmRlZmF1bHQuc3ZjLmNsdXN0ZXIubG9jYWwiXSwiZXhwIjoxNjY4NjEwNjY5LCJpYXQiOjE2Njg2MDcwNjksImlzcyI6Imh0dHBzOi8va3ViZXJuZXRlcy5kZWZhdWx0LnN2Yy5jbHVzdGVyLmxvY2FsIiwia3ViZXJuZXRlcy5pbyI6eyJuYW1lc3BhY2UiOiJkZWZhdWx0Iiwic2VydmljZWFjY291bnQiOnsibmFtZSI6Imt1YmVybmV0ZXMtZGFzaGJvYXJkIiwidWlkIjoiZDI2MDgxMjctYTExNi00ZDljLTk2NTItZjRiNjdjMGQ5YTNkIn19LCJuYmYiOjE2Njg2MDcwNjksInN1YiI6InN5c3RlbTpzZXJ2aWNlYWNjb3VudDpkZWZhdWx0Omt1YmVybmV0ZXMtZGFzaGJvYXJkIn0.fqIhUErlc2xGkVU9IqSHS1syH-YOG6FoOnxOFrGumDwFEXtD0rNDPtaMaq7rKcXoP-lA4EdU-bznq4q-mA2LiJU8Ymj7hmG891iyn9i5QA71A5BFqpjgC1FCRg5ta2sJMgbOw1GtOQeJJ-JNHv5L4SOuY8seFrfNApRdoV_IXBICLbpLvYbwBUfcP8dYnLUXwFEbeKxsAn02_mvVuXCVYEMOUGGimLd9ELod5RoZ-FBpHSCDy2qyvaOi916xlRfRFi0ppv3oDdlFP6oxbRLA1l49oPptVU7NaIfpJShQelwgbdPcb7rOGOJIKT3dtxcjk96MUx32lZ5xhK6VNjo2eQ
Using this I was able to access the metrics dashboard in lab 13.3.
But the course definitely needs a rework.
1 -
Hi,
I encountered the dashboard has no data, it's not loading any metrics.
I need to create clusterrolebinding for service kubernetes-dashboard-metrics-scraper.
basing from this link
https://github.com/kubernetes/dashboard/blob/master/docs/user/access-control/README.md
kubectl create clusterrolebinding dashaccess --clusterrole=cluster-admin --serviceaccount=default:kubernetes-dashboard-metrics-scraper
After that, Dashboard is showing the metrics.
Thanks
0
Categories
- All Categories
- 167 LFX Mentorship
- 167 LFX Mentorship: Linux Kernel
- 802 Linux Foundation IT Professional Programs
- 358 Cloud Engineer IT Professional Program
- 181 Advanced Cloud Engineer IT Professional Program
- 82 DevOps Engineer IT Professional Program
- 127 Cloud Native Developer IT Professional Program
- 138 Express Training Courses
- 138 Express Courses - Discussion Forum
- 6.3K Training Courses
- 24 LFC110 Class Forum - Discontinued
- 17 LFC131 Class Forum
- 42 LFD102 Class Forum
- 228 LFD103 Class Forum
- 19 LFD110 Class Forum
- 41 LFD121 Class Forum
- 15 LFD133 Class Forum
- 8 LFD134 Class Forum
- 17 LFD137 Class Forum
- 63 LFD201 Class Forum
- 3 LFD210 Class Forum
- 2 LFD210-CN Class Forum
- 2 LFD213 Class Forum - Discontinued
- 128 LFD232 Class Forum - Discontinued
- 1 LFD233 Class Forum
- 2 LFD237 Class Forum
- 23 LFD254 Class Forum
- 649 LFD259 Class Forum
- 109 LFD272 Class Forum
- 3 LFD272-JP クラス フォーラム
- 12 LFD273 Class Forum
- 162 LFS101 Class Forum
- 1 LFS111 Class Forum
- 1 LFS112 Class Forum
- 3 LFS116 Class Forum
- 1 LFS118 Class Forum
- LFS120 Class Forum
- 1 LFS142 Class Forum
- 7 LFS144 Class Forum
- 3 LFS145 Class Forum
- 1 LFS146 Class Forum
- 2 LFS148 Class Forum
- 2 LFS151 Class Forum
- 1 LFS157 Class Forum
- 1 LFS158 Class Forum
- 10 LFS162 Class Forum
- 2 LFS166 Class Forum
- 1 LFS167 Class Forum
- 1 LFS170 Class Forum
- 1 LFS171 Class Forum
- 1 LFS178 Class Forum
- 3 LFS180 Class Forum
- 2 LFS182 Class Forum
- 1 LFS183 Class Forum
- 29 LFS200 Class Forum
- 736 LFS201 Class Forum - Discontinued
- 2 LFS201-JP クラス フォーラム
- 14 LFS203 Class Forum
- 135 LFS207 Class Forum
- 1 LFS207-DE-Klassenforum
- 1 LFS207-JP クラス フォーラム
- 301 LFS211 Class Forum
- 56 LFS216 Class Forum
- 48 LFS241 Class Forum
- 48 LFS242 Class Forum
- 37 LFS243 Class Forum
- 12 LFS244 Class Forum
- 3 LFS245 Class Forum
- LFS246 Class Forum
- LFS248 Class Forum
- 52 LFS250 Class Forum
- 1 LFS250-JP クラス フォーラム
- LFS251 Class Forum
- 141 LFS253 Class Forum
- LFS254 Class Forum
- LFS255 Class Forum
- 9 LFS256 Class Forum
- 1 LFS257 Class Forum
- 1.3K LFS258 Class Forum
- 9 LFS258-JP クラス フォーラム
- 111 LFS260 Class Forum
- 149 LFS261 Class Forum
- 41 LFS262 Class Forum
- 82 LFS263 Class Forum - Discontinued
- 15 LFS264 Class Forum - Discontinued
- 11 LFS266 Class Forum - Discontinued
- 20 LFS267 Class Forum
- 18 LFS268 Class Forum
- 29 LFS269 Class Forum
- 5 LFS270 Class Forum
- 199 LFS272 Class Forum
- 1 LFS272-JP クラス フォーラム
- LFS147 Class Forum
- LFS274 Class Forum
- 3 LFS281 Class Forum
- LFW111 Class Forum
- 256 LFW211 Class Forum
- 183 LFW212 Class Forum
- 10 SKF100 Class Forum
- SKF200 Class Forum
- 1 SKF201 Class Forum
- 782 Hardware
- 198 Drivers
- 68 I/O Devices
- 37 Monitors
- 104 Multimedia
- 174 Networking
- 87 Printers & Scanners
- 83 Storage
- 743 Linux Distributions
- 80 Debian
- 66 Fedora
- 15 Linux Mint
- 13 Mageia
- 23 openSUSE
- 148 Red Hat Enterprise
- 31 Slackware
- 13 SUSE Enterprise
- 348 Ubuntu
- 468 Linux System Administration
- 39 Cloud Computing
- 70 Command Line/Scripting
- Github systems admin projects
- 90 Linux Security
- 77 Network Management
- 101 System Management
- 46 Web Management
- 55 Mobile Computing
- 17 Android
- 28 Development
- 1.2K New to Linux
- 1K Getting Started with Linux
- 373 Off Topic
- 115 Introductions
- 169 Small Talk
- 23 Study Material
- 507 Programming and Development
- 304 Kernel Development
- 204 Software Development
- 1.1K Software
- 211 Applications
- 180 Command Line
- 3 Compiling/Installing
- 405 Games
- 317 Installation
- 59 All In Program
- 59 All In Forum
Upcoming Training
-
August 20, 2018
Kubernetes Administration (LFS458)
-
August 20, 2018
Linux System Administration (LFS301)
-
August 27, 2018
Open Source Virtualization (LFS462)
-
August 27, 2018
Linux Kernel Debugging and Security (LFD440)