Kom is a command-line tool written in Go that allows you to display Kubernetes metrics for nodes and pods. It provides an easy way to monitor resource usage and quickly identify performance issues in your Kubernetes cluster.
- View CPU and memory usage metrics for all nodes in the cluster.
- View CPU and memory usage metrics for all pods in the cluster.
- View Logs from pods and save inside folder komlogs
- Color-coded output for easy visualization of resource usage levels.
Kom uses color-coding to visualize resource usage levels:
- CPU usage above 80% is displayed in red.
- CPU usage between 50% and 80% is displayed in yellow.
- CPU usage below 50% is displayed in green.
- Memory usage above 80% is displayed in red.
- Memory usage between 50% and 80% is displayed in yellow.
- Memory usage below 50% is displayed in green.
Assuming you have Git and Go installed on your system, here's what you can do:
Clone the repository:
git clone https://github.com/miltlima/kom.git
Change to the project directory:
cd kom
Build the binary:
go build
This will generate a binary file named "kom" in the project directory.
sudo mv kom /usr/local/bin
Now, the "kom" binary is located in your bin folder, and you can run it from any terminal window as long as the bin folder is in your system's PATH.
Save the file and either restart your terminal or run source to apply the changes:
source ~/.bashrc
Or
source ~/.bash_profile
Now, you should be able to run the "kom" command from anywhere in your terminal.
To display metrics for all nodes in the Kubernetes cluster, use the following command:
kom nodes
This will show a table with information about each node's CPU usage, memory usage, and IP addresses.
β― ./kom nodes
+-------+-----------+-------------+----------------+----+-----------------------------------------------------------+
| NODE | IP | CPU USAGE % | MEMORY USAGE % | H | STATUS - LABELS |
+-------+-----------+-------------+----------------+----+-----------------------------------------------------------+
| node1 | 10.0.0.11 | 7 | 42 | π© | OK, Has Labels: node-role.kubernetes.io/control-plane=, |
| | | | | | node.kubernetes.io/exclude-from-external-load-balancers=, |
| | | | | | beta.kubernetes.io/arch=arm64, |
| | | | | | beta.kubernetes.io/os=linux, kubernetes.io/arch=arm64, |
| | | | | | kubernetes.io/hostname=node1, kubernetes.io/os=linux |
| node2 | 10.0.0.12 | 2 | 44 | π© | OK, Has Labels: |
| | | | | | kubernetes.io/arch=arm64, |
| | | | | | kubernetes.io/hostname=node2, |
| | | | | | kubernetes.io/os=linux, |
| | | | | | beta.kubernetes.io/arch=arm64, |
| | | | | | beta.kubernetes.io/os=linux |
| node3 | 10.0.0.13 | 2 | 37 | π© | OK, Has Labels: |
| | | | | | kubernetes.io/os=linux, |
| | | | | | beta.kubernetes.io/arch=arm64, |
| | | | | | beta.kubernetes.io/os=linux, |
| | | | | | kubernetes.io/arch=arm64, |
| | | | | | kubernetes.io/hostname=node3 |
| node4 | 10.0.0.14 | 4 | 36 | π© | OK, Has Labels: |
| | | | | | kubernetes.io/hostname=node4, |
| | | | | | kubernetes.io/os=linux, |
| | | | | | beta.kubernetes.io/arch=arm64, |
| | | | | | beta.kubernetes.io/os=linux, |
| | | | | | kubernetes.io/arch=arm64 |
+-------+-----------+-------------+----------------+----+-----------------------------------------------------------+
To display metrics for all pods in the Kubernetes cluster, use the following command:
kom pods
This will show a table with information about each node, pod's namespace, name, CPU usage, memory usage, and IP.
β― ./kom pods
+-------+-------------+--------------------------------------------------+-----------+-------------+----------------+----+
| NODE | NAMESPACE | POD | POD IP | CPU USAGE % | MEMORY USAGE % | H |
+-------+-------------+--------------------------------------------------+-----------+-------------+----------------+----+
| node2 | default | build-code-deployment-68dd47875-4bt5p | 10.36.0.1 | 0 | 0 | π© |
| node2 | default | health-check-deployment-59f4b679b-8k4pj | 10.36.0.5 | 0 | 0 | π© |
| node3 | default | hidden-in-layers-qtst5 | 10.44.0.1 | 0 | 0 | π© |
| node2 | default | internal-proxy-deployment-7699c5dd65-xm4tw | 10.36.0.3 | 0 | 0 | π© |
| node2 | default | kubernetes-goat-home-deployment-7bf7785ff5-gghts | 10.36.0.2 | 0 | 0 | π© |
| node4 | default | metadata-db-648b64948f-vjvsg | 10.42.0.1 | 0 | 0 | π© |
| node2 | default | poor-registry-deployment-75f47d55dc-vhs9d | 10.36.0.4 | 0 | 0 | π© |
| node4 | default | system-monitor-deployment-674bb4dc65-9wj4m | 10.42.0.3 | 0 | 0 | π© |
| node1 | kube-system | coredns-787d4945fb-4vnqj | 10.32.0.3 | 0 | 0 | π© |
| node1 | kube-system | coredns-787d4945fb-q5r2h | 10.32.0.2 | 0 | 0 | π© |
| node1 | kube-system | etcd-node1 | 10.0.0.11 | 1 | 1 | π© |
| node1 | kube-system | kube-apiserver-node1 | 10.0.0.11 | 3 | 8 | π© |
| node1 | kube-system | kube-controller-manager-node1 | 10.0.0.11 | 0 | 0 | π© |
| node4 | kube-system | kube-proxy-5r278 | 10.0.0.14 | 0 | 0 | π© |
| node3 | kube-system | kube-proxy-dzzrp | 10.0.0.13 | 0 | 0 | π© |
| node1 | kube-system | kube-proxy-h5wsb | 10.0.0.11 | 0 | 0 | π© |
| node2 | kube-system | kube-proxy-htlwv | 10.0.0.12 | 0 | 0 | π© |
| node1 | kube-system | kube-scheduler-node1 | 10.0.0.11 | 0 | 0 | π© |
| node4 | kube-system | metrics-server-75fcb88b7d-n2l7p | 10.0.0.14 | 0 | 0 | π© |
| node4 | kube-system | weave-net-774l4 | 10.0.0.14 | 0 | 0 | π© |
| node3 | kube-system | weave-net-gv6dn | 10.0.0.13 | 0 | 0 | π© |
| node2 | kube-system | weave-net-n6n8f | 10.0.0.12 | 0 | 0 | π© |
| node1 | kube-system | weave-net-sn6v9 | 10.0.0.11 | 0 | 0 | π© |
+-------+-------------+--------------------------------------------------+-----------+-------------+----------------+----+
The logs command in the kom CLI allows you to collect logs from a Kubernetes pod and optionally save them to a file.
kom logs <pod-name> [flags]
<pod-name>
: The name of the pod from which you want to collect logs.
-s, --save: (Optional) Save the output to a log file. If this flag is not provided, the logs will be displayed in the terminal.
-o, --output <file-path>: (Optional) Specify the file path to save the logs. Default is output.log in the komlogs folder.
-n, --namespace <namespace>: (Optional) Specify the namespace of the pod. Default is default.
-c, --container <container-name>: (Optional) Specify the name of the container in the pod. If not provided, logs will be collected from the first container in the pod.