You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
107 lines
3.4 KiB
Bash
107 lines
3.4 KiB
Bash
#!/usr/bin/env bash
|
|
# vim:ts=4:sts=4:sw=4:et
|
|
#
|
|
# Author: Hari Sekhon
|
|
# Date: 2020-08-13 19:38:39 +0100 (Thu, 13 Aug 2020)
|
|
# (forked from gcp_info.sh)
|
|
#
|
|
# https://github.com/HariSekhon/bash-tools
|
|
#
|
|
# License: see accompanying Hari Sekhon LICENSE file
|
|
#
|
|
# If you're using my code you're welcome to connect with me on LinkedIn and optionally send me feedback to help steer this or other code I publish
|
|
#
|
|
# https://www.linkedin.com/in/HariSekhon
|
|
#
|
|
|
|
set -euo pipefail
|
|
[ -n "${DEBUG:-}" ] && set -x
|
|
srcdir="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
|
|
|
# shellcheck disable=SC1090
|
|
. "$srcdir/lib/utils.sh"
|
|
|
|
# shellcheck disable=SC2034,SC2154
|
|
usage_description="
|
|
Lists Kubernetes info and deployed resources across all namespaces in the current cluster / kube context
|
|
|
|
Can optionally specify a different kubernetes context to switch to (will switch back to original context on any exit except kill -9)
|
|
|
|
Lists:
|
|
|
|
- cluster-info
|
|
- master component statuses
|
|
- nodes
|
|
- namespaces
|
|
- deployments, replicasets, replication controllers, statefulsets, daemonsets, horizontal pod autoscalers
|
|
- services, ingresses
|
|
- jobs, cronjobs
|
|
- storage classes, persistent volumes, persistent volume claims
|
|
- service accounts, resource quotas, network policies, pod security policies
|
|
- container images running
|
|
- container images running counts descending
|
|
- pods # might be too much detail if you have high replica counts, so done last, comment if you're sure nobody has deployed pods outside deployments
|
|
"
|
|
|
|
# used by usage() in lib/utils.sh
|
|
# shellcheck disable=SC2034
|
|
usage_args="[<kubernetes_context>]"
|
|
|
|
help_usage "$@"
|
|
|
|
# XXX: set the kubectl context for the lifetime of this script to avoid a concurrency race condition changing the cluster we're speaking to half way through - this way the context reported at the beginning is the one we're using all the way through for consistent results
|
|
kubeconfig="/tmp/.kube/config.${EUID:-$UID}.$$"
|
|
mkdir -pv "$(dirname "$kubeconfig")"
|
|
cp -f "${KUBECONFIG:-$HOME/.kube/config}" "$kubeconfig"
|
|
export KUBECONFIG="$kubeconfig"
|
|
|
|
current_context="$(kubectl config current-context)"
|
|
|
|
if [ $# -gt 0 ]; then
|
|
context="$1"
|
|
# want interpolation now
|
|
# shellcheck disable=SC2064
|
|
trap "echo; kubectl config use-context '$current_context'" EXIT
|
|
# kubectl declares this just fine
|
|
#echo "switching to kubernetes context '$context'"
|
|
kubectl config use-context "$context"
|
|
echo
|
|
fi
|
|
|
|
echo "kubectl context: $(kubectl config current-context)"
|
|
echo
|
|
kubectl cluster-info
|
|
echo
|
|
kubectl get componentstatuses
|
|
echo
|
|
kubectl get nodes -o wide
|
|
echo
|
|
kubectl get namespaces
|
|
echo
|
|
kubectl get --all-namespaces deployments,replicasets,replicationcontrollers,statefulsets,daemonsets,horizontalpodautoscalers
|
|
echo
|
|
kubectl get --all-namespaces services,ingresses
|
|
echo
|
|
echo
|
|
kubectl get --all-namespaces jobs,cronjobs
|
|
echo
|
|
echo
|
|
kubectl get --all-namespaces storageclasses,persistentvolumes,persistentvolumeclaims
|
|
echo
|
|
echo
|
|
kubectl get --all-namespaces serviceaccounts,resourcequotas,networkpolicies,podsecuritypolicies
|
|
echo
|
|
echo
|
|
echo "# Running container images:"
|
|
echo
|
|
"$srcdir/kubernetes_running_images.sh"
|
|
echo
|
|
echo
|
|
echo "# Running container image counts:"
|
|
echo
|
|
"$srcdir/kubernetes_running_image_counts.sh"
|
|
echo
|
|
echo
|
|
# pods might be too numerous with high replica counts and low value info, but there is always a chance that people launched pods without deployments, you can comment it out if you're confident that isn't the case
|
|
kubectl get --all-namespaces pods
|