forked from amelbakry/kubernetes-scripts
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcluster-health.sh
executable file
·111 lines (100 loc) · 5.68 KB
/
cluster-health.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
###########################################################################################
# Script to check the health status of the cluster and report the objects and resources #
###########################################################################################
#!/bin/bash
# Colors
RED='\033[0;31m'
GREEN='\033[0;32m'
YELLOW='\033[0;33m'
BLUE='\033[0;36m'
PLAIN='\033[0m'
bold=$(tput bold)
normal=$(tput sgr0)
deploy="$2"
namespace="$1"
cluster_objects() {
echo -e "\e[44mCollecting Information from the Cluster:\e[21m"
deployments=$(kubectl get deployment --all-namespaces | grep -v NAMESPACE | wc -l)
pods=$(kubectl get po --all-namespaces | grep -v NAMESPACE | wc -l)
services=$(kubectl get svc --all-namespaces | grep -v NAMESPACE | wc -l)
ingresses=$(kubectl get ing --all-namespaces | grep -v NAMESPACE | wc -l)
statefulset=$(kubectl get statefulset --all-namespaces | grep -v NAMESPACE | wc -l)
postgresql=$(kubectl get postgresql --all-namespaces | grep -v NAMESPACE | wc -l)
daemonset=$(kubectl get daemonset --all-namespaces | grep -v NAMESPACE | wc -l)
replicaset=$(kubectl get rs --all-namespaces | grep -v NAMESPACE | wc -l)
serviceaccount=$(kubectl get sa --all-namespaces | grep -v NAMESPACE | wc -l)
storageclass=$(kubectl get sc --all-namespaces | grep -v NAMESPACE | wc -l)
PodDistrubtion=$(kubectl get pdb --all-namespaces | grep -v NAMESPACE | wc -l)
CustomResources=$(kubectl get crd --all-namespaces | grep -v NAMESPACE | wc -l)
cronjobs=$(kubectl get cronjobs --all-namespaces | grep -v NAMESPACE | wc -l)
persistancevolumes=$(kubectl get pv --all-namespaces | grep -v NAMESPACE | wc -l)
volumeclaims=$(kubectl get pvc --all-namespaces | grep -v NAMESPACE | wc -l)
hpa=$(kubectl get hpa --all-namespaces | grep -v NAMESPACE | wc -l)
echo -e "\e[1m\e[39mCluster Resources:\e[21m"
echo -e "${BLUE}"Deployments" :${GREEN}$deployments"
echo -e "${BLUE}"Services" :${GREEN}$services"
echo -e "${BLUE}"Ingresses" :${GREEN}$ingresses"
echo -e "${BLUE}"StatefulSets" :${GREEN}$statefulset"
echo -e "${BLUE}"Pods" :${GREEN}$pods"
echo -e "${BLUE}"DaemonSets" :${GREEN}$daemonset"
echo -e "${BLUE}"ReplicaSets" :${GREEN}$replicaset"
echo -e "${BLUE}"StorageClasses" :${GREEN}$storageclass"
echo -e "${BLUE}"CronJobs" :${GREEN}$cronjobs"
echo -e "${BLUE}"PostgreSQL" :${GREEN}$postgresql"
echo -e "${BLUE}"CustomResources" :${GREEN}$CustomResources"
echo -e "${BLUE}"HorizontalPodAutoscaler" :${GREEN}$hpa"
echo -e "${BLUE}"PersistanceVolumes" :${GREEN}$persistancevolumes"
echo -e "${BLUE}"VolumeClaims" :${GREEN}$volumeclaims"
}
cluster_nodes() {
nodes=$(kubectl get nodes | grep -v NAME | wc -l)
worker=$(kubectl get nodes | grep -v NAME | grep worker | wc -l)
master=$(kubectl get nodes | grep -v NAME | grep master | wc -l)
node_status=$(for i in $(kubectl get node | grep -v NAME | awk {'print $2'} | sort -u); do echo "$i";done)
echo -e "\e[1m\e[39mCluster Node Status:\e[21m"
echo -e "${BLUE}"ALL Nodes" :${GREEN}$nodes"
echo -e "${BLUE}"Worker Nodes" :${GREEN}$worker"
echo -e "${BLUE}"Master Nodes" :${GREEN}$master"
echo -e "${BLUE}"Nodes Status" :${GREEN}$node_status"
echo -e "\e[1m\e[39mNodes Conditions:\e[21m"
echo -e "${BLUE}$(kubectl describe node | grep kubelet | awk {'print $15'} | sort -u)"
echo -e "\e[1m\e[39mPods Per Node:\e[21m"
for node in $(kubectl get node | grep -v NAME | awk {'print $1'})
do pod_per_node=$(kubectl get pods --all-namespaces --field-selector spec.nodeName=$node -o wide | wc -l)
echo -e "${BLUE}"$node" \t :${GREEN}$pod_per_node"
done
# Nodes Per AZ
a=$(kubectl get node -l failure-domain.beta.kubernetes.io/zone=eu-central-1a | grep -v NAME | grep -v master | wc -l)
b=$(kubectl get node -l failure-domain.beta.kubernetes.io/zone=eu-central-1b | grep -v NAME | grep -v master | wc -l)
c=$(kubectl get node -l failure-domain.beta.kubernetes.io/zone=eu-central-1c | grep -v NAME | grep -v master | wc -l)
echo -e "\e[1m\e[39mWorker Nodes per AZ:\e[21m"
echo -e "${BLUE}"eu-central-1a" \t :${GREEN}$a"
echo -e "${BLUE}"eu-central-1b" \t :${GREEN}$b"
echo -e "${BLUE}"eu-central-1c" \t :${GREEN}$c"
#Node Types
types=$(kubectl describe node | grep beta.kubernetes.io/instance-type | cut -d"=" -f2 | sort | uniq -c | awk -F$'\t' {'print $2 $1'})
echo -e "\e[1m\e[39mCluster Node Types:\e[21m"
echo -e "\e[34m$types"
}
pod_with_issues() {
echo -e "\e[1m\e[39mPods not in Running or Completed State:\e[21m"
kubectl get pods --all-namespaces --field-selector=status.phase!=Running | grep -v Completed
}
top_mem_pods() {
echo -e "\e[1m\e[39mTop Pods According to Memory Limits:\e[21m"
for node in $(kubectl get node | awk {'print $1'} | grep -v NAME)
do kubectl describe node $node | sed -n "/Non-terminated Pods/,/Allocated resources/p"| grep -P -v "terminated|Allocated|Namespace"
done | grep '[0-9]G' | awk -v OFS=' \t' '{if ($9 >= '2Gi') print "\033[0;36m"$2," ", "\033[0;31m"$9}' | sort -k2 -r | column -t
}
top_cpu_pods() {
echo -e "\e[1m\e[39mTop Pods According to CPU Limits:\e[21m"
for node in $(kubectl get node | awk {'print $1'} | grep -v NAME)
do kubectl describe node $node | sed -n "/Non-terminated Pods/,/Allocated resources/p" | grep -P -v "terminated|Allocated|Namespace"
done | awk -v OFS=' \t' '{if ($5 ~/^[2-9]+$/) print "\033[0;36m"$2, "\033[0;31m"$5}' | sort -k2 -r | column -t
}
clear
cluster_objects
cluster_nodes
pod_with_issues
top_mem_pods
top_cpu_pods