mirror of
https://github.com/LCTT/TranslateProject.git
synced 2025-01-13 22:30:37 +08:00
242 lines
11 KiB
Markdown
242 lines
11 KiB
Markdown
|
[#]: subject: "Monitoring and Debugging Kubernetes with Lens Desktop"
|
|||
|
[#]: via: "https://www.opensourceforu.com/2022/09/monitoring-and-debugging-kubernetes-with-lens-desktop/"
|
|||
|
[#]: author: "Mitesh Soni https://www.opensourceforu.com/author/mitesh_soni/"
|
|||
|
[#]: collector: "lkxed"
|
|||
|
[#]: translator: " "
|
|||
|
[#]: reviewer: " "
|
|||
|
[#]: publisher: " "
|
|||
|
[#]: url: " "
|
|||
|
|
|||
|
Monitoring and Debugging Kubernetes with Lens Desktop
|
|||
|
======
|
|||
|
*Lens Desktop is an exciting platform for working with Kubernetes. It is a distribution of the OpenLens repository with specific customisations. In this article we will see what Lens Desktop can do and how it works.*
|
|||
|
|
|||
|
Lens Desktop is free of charge. For more details, you can visit *https://k8slens.dev/pricing.html.* A few benefits of using Lens Desktop are:
|
|||
|
|
|||
|
* Simplicity and increased productivity – no need to learn kubectl commands
|
|||
|
* Visibility in existing Kubernetes resources
|
|||
|
* Built on open source
|
|||
|
* Observability — live statistics, events, and log streams in real-time
|
|||
|
* Errors and warnings are directly available on the Lens dashboard
|
|||
|
* Supports EKS, AKS, GKE, Minikube, Rancher, k0s, k3s, OpenShift
|
|||
|
* Huge community support — 450,000 users and 17,000 stars on GitHub
|
|||
|
|
|||
|
### Minikube installation
|
|||
|
|
|||
|
Minikube is a tool that is used to run Kubernetes locally. It runs a single-node Kubernetes cluster so that hands-on work can be done on Kubernetes for daily software development.
|
|||
|
|
|||
|
We will use minikube and verify the usage of Lens. Let’s install minikube on a Windows based system first. You can also install it on other operating systems, virtual machines or laptops.
|
|||
|
|
|||
|
* Two or more CPUs
|
|||
|
* 2GB of RAM
|
|||
|
* 20GB of free disk space
|
|||
|
* Internet connectivity
|
|||
|
* Container or virtual machine manager such as Docker or VirtualBox
|
|||
|
|
|||
|
From a terminal or command prompt, execute the minikube start command.
|
|||
|
|
|||
|
```
|
|||
|
minikube start --driver=virtualbox
|
|||
|
* minikube v1.12.3 on Microsoft Windows 10 Home Single Language 10.0.19044 Build 19044
|
|||
|
* Using the virtualbox driver based on existing profile
|
|||
|
* minikube 1.26.0 is available! Download it: https://github.com/kubernetes/minikube/releases/tag/v1.26.0
|
|||
|
* To disable this notice, run: ‘minikube config set WantUpdateNotification false’
|
|||
|
* Starting control plane node minikube in cluster minikube
|
|||
|
* virtualbox “minikube” VM is missing, will recreate.
|
|||
|
* Creating virtualbox VM (CPUs=2, Memory=3000MB, Disk=20000MB) ...
|
|||
|
! This VM is having trouble accessing https://k8s.gcr.io
|
|||
|
* To pull new external images, you may need to configure a proxy: https://minikube.sigs.k8s.io/docs/reference/networking/proxy/
|
|||
|
* Preparing Kubernetes v1.18.3 on Docker 19.03.12 ...
|
|||
|
* Verifying Kubernetes components...
|
|||
|
* Enabled addons: default-storageclass, storage-provisioner
|
|||
|
* Done! kubectl is now configured to use “minikube”
|
|||
|
```
|
|||
|
|
|||
|
Go to your virtual box and verify the newly created minikube virtual machine (Figure 1).
|
|||
|
|
|||
|
![Figure 1: Minikube virtual machine in virtual box][1]
|
|||
|
|
|||
|
Now verify the existing status of minikube using the *minikube* status command.
|
|||
|
|
|||
|
```
|
|||
|
C:\>minikube status
|
|||
|
minikube
|
|||
|
type: Control Plane
|
|||
|
host: Running
|
|||
|
kubelet: Running
|
|||
|
apiserver: Running
|
|||
|
kubeconfig: Configured
|
|||
|
```
|
|||
|
|
|||
|
Next, use the *kubectl cluster-info* command to get details about kubeDNS.
|
|||
|
|
|||
|
```
|
|||
|
kubectl cluster-info
|
|||
|
Kubernetes master is running at https://192.168.99.103:8443
|
|||
|
KubeDNS is running at https://192.168.99.103:8443/api/v1/namespaces/kube-system/services/kube-dns:dns/proxy
|
|||
|
```
|
|||
|
|
|||
|
To get more details on debugging and to diagnose cluster problems, use the *kubectl cluster-info* dump command.
|
|||
|
|
|||
|
Once minikube is ready, install kubectl *[(https://kubernetes.io/docs/tasks/tools/)][2]*. It is a command line cluster that is used to run commands against Kubernetes clusters and minikube as well.
|
|||
|
|
|||
|
![Figure 2: Lens][3]
|
|||
|
|
|||
|
Execute the *kubectl get* *nodes* command to get details on all nodes and, in this case, minikube.
|
|||
|
|
|||
|
```
|
|||
|
C:\>kubectl get nodes
|
|||
|
NAME STATUS ROLES AGE VERSION
|
|||
|
minikube Ready master 7m57s v1.18.3
|
|||
|
```
|
|||
|
|
|||
|
Use the *kubectl get all* command to get all details for the default name space.
|
|||
|
|
|||
|
```
|
|||
|
C:\>kubectl get all
|
|||
|
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
|
|||
|
service/kubernetes ClusterIP 10.96.0.1 <none> 443/TCP 7m58s
|
|||
|
```
|
|||
|
|
|||
|
We now have a minikube cluster ready with kubectl. The next step is to install and configure Lens and verify the sample applications.
|
|||
|
|
|||
|
### Lens installation and configuration
|
|||
|
|
|||
|
Go to *https://k8slens.dev/* and download an installable package based on the operating system you have.
|
|||
|
|
|||
|
Next, install Lens as per the instruction displayed on the screen. Open Lens after successful installation. You will find a minikube in the catalogue (Figure 3).
|
|||
|
|
|||
|
![Figure 3: Lens catalogue][4]
|
|||
|
|
|||
|
Click on *minikube* and you will enter the world of minikube clusters, which you will love forever.
|
|||
|
|
|||
|
Click on *Nodes* and get the node details that you got after executing the kubectl get nodes commands.
|
|||
|
|
|||
|
Now, Lens is ready to use.
|
|||
|
|
|||
|
![Figure 4: Lens cluster][5]
|
|||
|
|
|||
|
Let’s deploy [https://github.com/GoogleCloudPlatform/microservices-demo][6], which is a cloud-native microservices demo application. It has 11-tier microservices applications, and is a Web based e-commerce app.
|
|||
|
|
|||
|
Download the application and extract it locally in the system where you have downloaded and configured minikube.
|
|||
|
|
|||
|
Go to the *release* directory and execute the following command.
|
|||
|
|
|||
|
```
|
|||
|
kubectl apply -f kubernetes-manifests.yaml
|
|||
|
|
|||
|
deployment.apps/emailservice created
|
|||
|
service/emailservice created
|
|||
|
deployment.apps/checkoutservice created
|
|||
|
service/checkoutservice created
|
|||
|
deployment.apps/recommendationservice created
|
|||
|
service/recommendationservice created
|
|||
|
deployment.apps/frontend created
|
|||
|
service/frontend created
|
|||
|
service/frontend-external created
|
|||
|
deployment.apps/paymentservice created
|
|||
|
service/paymentservice created
|
|||
|
deployment.apps/productcatalogservice created
|
|||
|
service/productcatalogservice created
|
|||
|
deployment.apps/cartservice created
|
|||
|
service/cartservice created
|
|||
|
deployment.apps/loadgenerator created
|
|||
|
deployment.apps/currencyservice created
|
|||
|
service/currencyservice created
|
|||
|
deployment.apps/shippingservice created
|
|||
|
service/shippingservice created
|
|||
|
deployment.apps/redis-cart created
|
|||
|
service/redis-cart created
|
|||
|
deployment.apps/adservice created
|
|||
|
service/adservice created
|
|||
|
```
|
|||
|
|
|||
|
The installation of the app will start now, but it will take some time to reflect that we have used kubectl commands.
|
|||
|
|
|||
|
![Figure 5: Lens nodes][7]
|
|||
|
|
|||
|
```
|
|||
|
kubectl get pods
|
|||
|
NAME READY STATUS RESTARTS AGE
|
|||
|
adservice-775d8b9bf5-cp7jr 0/1 Pending 0 8h
|
|||
|
cartservice-79749895f5-jrq4d 1/1 Running 0 8h
|
|||
|
checkoutservice-5645bf9c65-882m4 1/1 Running 0 8h
|
|||
|
currencyservice-545c79d477-8rhg7 1/1 Running 0 8h
|
|||
|
emailservice-7cc5c74b4f-hk74s 1/1 Running 0 8h
|
|||
|
frontend-9cdf787f5-klfkh 1/1 Running 1 8h
|
|||
|
loadgenerator-7b6874cb4c-645v9 1/1 Running 0 8h
|
|||
|
paymentservice-5f74bc7b87-l4248 1/1 Running 0 8h
|
|||
|
productcatalogservice-6846f59899-v4q4w 1/1 Running 0 8h
|
|||
|
recommendationservice-d9c6c8b55-m2x9k 1/1 Running 0 8h
|
|||
|
redis-cart-57bd646894-v7kfr 0/1 Pending 0 8h
|
|||
|
shippingservice-8685dd9855-pmgjm 1/1 Running 0 8h
|
|||
|
```
|
|||
|
|
|||
|
Table 1 lists a few commands that you can use to get information from kubectl.
|
|||
|
|
|||
|
![Figure 6: Lens pods][8]
|
|||
|
|
|||
|
| Description | Command |
|
|||
|
| :- | :- |
|
|||
|
| List one or more nodes | kubectl get node |
|
|||
|
| List all resources in the cluster | kubectl get all –all-namespaces |
|
|||
|
| List one or more deployments | kubectl get deployment |
|
|||
|
| Display the complete state of one or more deployments | kubectl describe deployment <deployment_name> |
|
|||
|
| Edit and update one or more deployments on the cluster | kubectl edit deployment <deployment_name> |
|
|||
|
| Delete deployments | kubectl delete deployment <deployment_name> |
|
|||
|
| List one or more pods | kubectl get pod |
|
|||
|
| Delete a pod | kubectl delete pod <pod_name> |
|
|||
|
| Display the complete state of a pod | kubectl describe pod <pod_name> |
|
|||
|
| Get a shell to a running single-container pod | kubectl exec -it <pod_name> /bin/bash |
|
|||
|
| List secrets | kubectl get secrets |
|
|||
|
| List one or more services | kubectl get services |
|
|||
|
| Display the complete state of a service | kubectl describe services |
|
|||
|
| Edit and update one or more services on the cluster | kubectl edit services / kubectl edit deployment <deployment_name> |
|
|||
|
| List one or more namespaces | kubectl get namespace <namespace_name> |
|
|||
|
| Print the logs for a pod | kubectl logs <pod_name> |
|
|||
|
| Print the logs for a specific container in a pod | kubectl logs -c <container_name> <pod_name> |
|
|||
|
|
|||
|
Lens can help you get all the information listed in Table 1 and more for a specific cluster. We can also perform edit and delete actions on Kubernetes resources using Lens.
|
|||
|
|
|||
|
![Figure 7: Lens deployments][9]
|
|||
|
|
|||
|
Let’s see how this works. Select *Pods* in the Workloads section (Figure 6). We can edit, delete, access logs, access terminals of pod from Lens itself. Cool, right?
|
|||
|
|
|||
|
![Figure 8: Lens Replicasets][10]
|
|||
|
|
|||
|
You can verify all *deployments* in the *Workloads* section (Figure 7), verify all *Replicasets* in the *Workloads* section (Figure 8), all *Secrets* in the *Config* section (Figure 9) and all *Services* in the *Network* section (Figure 10).
|
|||
|
|
|||
|
![Figure 9: Lens Secrets][11]
|
|||
|
|
|||
|
You can see how easy it is to navigate to all resources, and effectively find all Kubernetes resources from a single place quickly. We can edit YAML files in Lens and apply it at runtime to see the change.
|
|||
|
|
|||
|
![Figure 10: Lens Services][12]
|
|||
|
|
|||
|
We can also configure multiple clusters deployed by multiple cloud service providers and use Lens for visibility and troubleshooting.
|
|||
|
|
|||
|
--------------------------------------------------------------------------------
|
|||
|
|
|||
|
via: https://www.opensourceforu.com/2022/09/monitoring-and-debugging-kubernetes-with-lens-desktop/
|
|||
|
|
|||
|
作者:[Mitesh Soni][a]
|
|||
|
选题:[lkxed][b]
|
|||
|
译者:[译者ID](https://github.com/译者ID)
|
|||
|
校对:[校对者ID](https://github.com/校对者ID)
|
|||
|
|
|||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
|
|||
|
|
|||
|
[a]: https://www.opensourceforu.com/author/mitesh_soni/
|
|||
|
[b]: https://github.com/lkxed
|
|||
|
[1]: https://www.opensourceforu.com/wp-content/uploads/2022/08/Figure-1-Minikube-virtual-machine-in-virtual-box.jpg
|
|||
|
[2]: https://kubernetes.io/docs/tasks/tools/
|
|||
|
[3]: https://www.opensourceforu.com/wp-content/uploads/2022/08/Figure-2-Lens.jpg
|
|||
|
[4]: https://www.opensourceforu.com/wp-content/uploads/2022/08/Figure-3-Lens-catalogue.jpg
|
|||
|
[5]: https://www.opensourceforu.com/wp-content/uploads/2022/08/Figure-4-Lens-cluster.jpg
|
|||
|
[6]: https://github.com/GoogleCloudPlatform/microservices-demo
|
|||
|
[7]: https://www.opensourceforu.com/wp-content/uploads/2022/08/Figure-5-Lens-nodes.jpg
|
|||
|
[8]: https://www.opensourceforu.com/wp-content/uploads/2022/08/Figure-6-Lens-pods.jpg
|
|||
|
[9]: https://www.opensourceforu.com/wp-content/uploads/2022/08/Figure-7-Lens-deployments-2.jpg
|
|||
|
[10]: https://www.opensourceforu.com/wp-content/uploads/2022/08/Figure-8-Lens-Replicasets.jpg
|
|||
|
[11]: https://www.opensourceforu.com/wp-content/uploads/2022/08/Figure-9-Lens-Secrets.jpg
|
|||
|
[12]: https://www.opensourceforu.com/wp-content/uploads/2022/08/Figure-10-Lens-Services-1.jpg
|