Add debug-report.sh to aid troubleshooting
Change-Id: I45c6293ad399dcf398c9af76a3151ddd9fae0223
This commit is contained in:
parent
e2dd5369d5
commit
f5947663f5
|
@ -74,6 +74,7 @@ data:
|
|||
- kubernetes-apiserver
|
||||
- kubernetes-controller-manager
|
||||
- kubernetes-scheduler
|
||||
- tiller
|
||||
---
|
||||
schema: armada/ChartGroup/v1
|
||||
metadata:
|
||||
|
@ -1087,6 +1088,37 @@ data:
|
|||
- helm-toolkit
|
||||
---
|
||||
schema: armada/Chart/v1
|
||||
metadata:
|
||||
schema: metadata/Document/v1
|
||||
name: tiller
|
||||
layeringDefinition:
|
||||
abstract: false
|
||||
layer: site
|
||||
storagePolicy: cleartext
|
||||
data:
|
||||
chart_name: tiller
|
||||
release: tiller
|
||||
namespace: kube-system
|
||||
install:
|
||||
no_hooks: false
|
||||
upgrade:
|
||||
no_hooks: false
|
||||
values:
|
||||
images:
|
||||
tags:
|
||||
tiller: gcr.io/kubernetes-helm/tiller:v2.7.2
|
||||
labels:
|
||||
node_selector_key: ucp-control-plane
|
||||
node_selector_value: enabled
|
||||
source:
|
||||
type: git
|
||||
location: https://github.com/att-comdev/armada
|
||||
subpath: charts/tiller
|
||||
reference: master
|
||||
dependencies:
|
||||
- helm-toolkit
|
||||
---
|
||||
schema: armada/Chart/v1
|
||||
metadata:
|
||||
schema: metadata/Document/v1
|
||||
name: promenade
|
||||
|
|
|
@ -0,0 +1,127 @@
|
|||
#!/usr/bin/env bash
|
||||
|
||||
set -ux
|
||||
|
||||
SUBDIR_NAME=debug-$(hostname)
|
||||
|
||||
# NOTE(mark-burnett): This should add calicoctl to the path.
|
||||
export PATH=${PATH}:/opt/cni/bin
|
||||
|
||||
TEMP_DIR=$(mktemp -d)
|
||||
export TEMP_DIR
|
||||
export BASE_DIR="${TEMP_DIR}/${SUBDIR_NAME}"
|
||||
export HELM_DIR="${BASE_DIR}/helm"
|
||||
export CALICO_DIR="${BASE_DIR}/calico"
|
||||
|
||||
mkdir -p "${BASE_DIR}"
|
||||
|
||||
PARALLELISM_FACTOR=2
|
||||
|
||||
function get_namespaces () {
|
||||
kubectl get namespaces -o name | awk -F '/' '{ print $NF }'
|
||||
}
|
||||
|
||||
function get_pods () {
|
||||
NAMESPACE=$1
|
||||
kubectl get pods -n "${NAMESPACE}" -o name --show-all | awk -F '/' '{ print $NF }' | xargs -L1 -P 1 -I {} echo "${NAMESPACE}" {}
|
||||
}
|
||||
export -f get_pods
|
||||
|
||||
function get_pod_logs () {
|
||||
NAMESPACE=${1% *}
|
||||
POD=${1#* }
|
||||
INIT_CONTAINERS=$(kubectl get pod "${POD}" -n "${NAMESPACE}" -o json | jq -r '.spec.initContainers[]?.name')
|
||||
CONTAINERS=$(kubectl get pod "${POD}" -n "${NAMESPACE}" -o json | jq -r '.spec.containers[].name')
|
||||
POD_DIR="${BASE_DIR}/pod-logs/${NAMESPACE}/${POD}"
|
||||
mkdir -p "${POD_DIR}"
|
||||
for CONTAINER in ${INIT_CONTAINERS} ${CONTAINERS}; do
|
||||
kubectl logs "${POD}" -n "${NAMESPACE}" -c "${CONTAINER}" > "${POD_DIR}/${CONTAINER}.txt"
|
||||
done
|
||||
}
|
||||
export -f get_pod_logs
|
||||
|
||||
function list_namespaced_objects () {
|
||||
export NAMESPACE=$1
|
||||
cat | awk "{ print \"${NAMESPACE} \" \$1 }" <<OBJECTS
|
||||
configmaps
|
||||
cronjobs
|
||||
daemonsets
|
||||
deployment
|
||||
endpoints
|
||||
ingresses
|
||||
jobs
|
||||
networkpolicies
|
||||
pods
|
||||
podsecuritypolicies
|
||||
persistentvolumeclaims
|
||||
rolebindings
|
||||
roles
|
||||
serviceaccounts
|
||||
services
|
||||
statefulsets
|
||||
OBJECTS
|
||||
}
|
||||
export -f list_namespaced_objects
|
||||
|
||||
function name_objects () {
|
||||
input=($1)
|
||||
export NAMESPACE=${input[0]}
|
||||
export OBJECT=${input[1]}
|
||||
kubectl get -n "${NAMESPACE}" "${OBJECT}" -o name | awk "{ print \"${NAMESPACE} ${OBJECT} \" \$1 }"
|
||||
}
|
||||
export -f name_objects
|
||||
|
||||
function get_objects () {
|
||||
input=($1)
|
||||
export NAMESPACE=${input[0]}
|
||||
export OBJECT=${input[1]}
|
||||
export NAME=${input[2]#*/}
|
||||
echo "${NAMESPACE}/${OBJECT}/${NAME}"
|
||||
DIR="${BASE_DIR}/objects/namespaced/${NAMESPACE}/${OBJECT}"
|
||||
mkdir -p "${DIR}"
|
||||
kubectl get -n "${NAMESPACE}" "${OBJECT}" "${NAME}" -o yaml > "${DIR}/${NAME}.yaml"
|
||||
}
|
||||
export -f get_objects
|
||||
|
||||
function get_releases () {
|
||||
helm list --all --short
|
||||
}
|
||||
|
||||
function get_release () {
|
||||
input=($1)
|
||||
RELEASE=${input[0]}
|
||||
helm status "${RELEASE}" > "${HELM_DIR}/${RELEASE}.txt"
|
||||
|
||||
}
|
||||
export -f get_release
|
||||
|
||||
if which helm; then
|
||||
mkdir -p "${HELM_DIR}"
|
||||
helm list --all > "${HELM_DIR}/list" &
|
||||
get_releases | \
|
||||
xargs -r -n 1 -P "${PARALLELISM_FACTOR}" -I {} bash -c 'get_release "$@"' _ {}
|
||||
fi
|
||||
|
||||
kubectl get --all-namespaces -o wide pods > "${BASE_DIR}/pods.txt" &
|
||||
|
||||
get_namespaces | \
|
||||
xargs -r -n 1 -P "${PARALLELISM_FACTOR}" -I {} bash -c 'get_pods "$@"' _ {} | \
|
||||
xargs -r -n 2 -P "${PARALLELISM_FACTOR}" -I {} bash -c 'get_pod_logs "$@"' _ {} &
|
||||
|
||||
get_namespaces | \
|
||||
xargs -r -n 1 -P "${PARALLELISM_FACTOR}" -I {} bash -c 'list_namespaced_objects "$@"' _ {} | \
|
||||
xargs -r -n 1 -P "${PARALLELISM_FACTOR}" -I {} bash -c 'name_objects "$@"' _ {} | \
|
||||
xargs -r -n 1 -P "${PARALLELISM_FACTOR}" -I {} bash -c 'get_objects "$@"' _ {} &
|
||||
|
||||
iptables-save > "${BASE_DIR}/iptables" &
|
||||
|
||||
if which calicoctl; then
|
||||
mkdir -p "${CALICO_DIR}"
|
||||
for kind in bgpPeer hostEndpoint ipPool nodes policy profile workloadEndpoint; do
|
||||
calicoctl get "${kind}" -o yaml > "${CALICO_DIR}/${kind}.yaml" &
|
||||
done
|
||||
fi
|
||||
|
||||
wait
|
||||
|
||||
tar zcf "${SUBDIR_NAME}.tgz" -C "${TEMP_DIR}" "${SUBDIR_NAME}"
|
|
@ -10,7 +10,7 @@ else
|
|||
WORKDIR=/up/$(basename $(pwd))
|
||||
fi
|
||||
|
||||
exec docker run --rm -it \
|
||||
exec docker run --rm \
|
||||
--net host \
|
||||
-v $UPDIR:/up \
|
||||
-v /etc/kubernetes/admin:/etc/kubernetes/admin \
|
||||
|
|
Loading…
Reference in New Issue