2022-10-10 14:21:17 +02:00
|
|
|
#!/usr/bin/env bash
|
2022-09-05 18:12:46 +02:00
|
|
|
|
2022-11-10 10:28:35 +01:00
|
|
|
set -euo pipefail
|
|
|
|
shopt -s inherit_errexit
|
|
|
|
|
|
|
|
printf "Fetching logs of instances in resource group %s\n" "${1}"
|
2022-09-05 18:12:46 +02:00
|
|
|
|
|
|
|
# get list of all scale sets
|
2022-11-10 10:28:35 +01:00
|
|
|
scalesetsjson=$(az vmss list --resource-group "${1}" -o json)
|
|
|
|
scalesetslist=$(echo "${scalesetsjson}" | jq -r '.[] | .name')
|
2022-11-10 14:17:04 +01:00
|
|
|
subscription=$(az account show | jq -r .id)
|
2022-09-05 18:12:46 +02:00
|
|
|
|
2022-11-10 10:28:35 +01:00
|
|
|
printf "Checking scalesets %s\n" "${scalesetslist}"
|
2022-09-05 18:12:46 +02:00
|
|
|
|
2022-11-10 10:28:35 +01:00
|
|
|
for scaleset in ${scalesetslist}; do
|
2022-11-10 14:17:04 +01:00
|
|
|
instanceids=$(
|
|
|
|
az vmss list-instances \
|
|
|
|
--resource-group "${1}" \
|
|
|
|
--name "${scaleset}" \
|
|
|
|
-o json |
|
|
|
|
jq -r '.[] | .instanceId'
|
|
|
|
)
|
|
|
|
printf "Checking instance IDs %s\n" "${instanceids}"
|
|
|
|
for instanceid in ${instanceids}; do
|
|
|
|
bloburi=$(
|
|
|
|
az rest \
|
|
|
|
--method post \
|
|
|
|
--url https://management.azure.com/subscriptions/"${subscription}"/resourceGroups/"${1}"/providers/Microsoft.Compute/virtualMachineScaleSets/"${scaleset}"/virtualmachines/"${instanceid}"/retrieveBootDiagnosticsData?api-version=2022-03-01 |
|
|
|
|
jq '.serialConsoleLogBlobUri' -r
|
|
|
|
)
|
|
|
|
sleep 4
|
2023-01-19 11:22:31 +01:00
|
|
|
curl -fsSL -o "./${scaleset}-${instanceid}.log" "${bloburi}"
|
2022-11-10 14:17:04 +01:00
|
|
|
realpath "./${scaleset}-${instanceid}.log"
|
|
|
|
done
|
2022-09-05 18:12:46 +02:00
|
|
|
done
|