2022-10-10 08:21:17 -04:00
|
|
|
#!/usr/bin/env bash
|
2022-09-05 12:12:46 -04:00
|
|
|
|
2022-10-31 05:40:08 -04:00
|
|
|
# Usage: ./gcp-logs.sh
|
|
|
|
|
|
|
|
CONTROL_INSTANCE_GROUP=$(terraform show -json | jq -r .'values.root_module.child_modules[] | select(.address == "module.instance_group_control_plane") | .resources[0].values.base_instance_name' )
|
|
|
|
WORKER_INSTANCE_GROUP=$(terraform show -json | jq -r .'values.root_module.child_modules[] | select(.address == "module.instance_group_worker") | .resources[0].values.base_instance_name')
|
|
|
|
ZONE=$(terraform show -json | jq -r .'values.root_module.child_modules[] | select(.address == "module.instance_group_control_plane") | .resources[0].values.zone' )
|
|
|
|
|
|
|
|
CONTROL_INSTANCE_GROUP_SHORT=${CONTROL_INSTANCE_GROUP##*/}
|
|
|
|
WORKER_INSTANCE_GROUP_SHORT=${WORKER_INSTANCE_GROUP##*/}
|
|
|
|
|
|
|
|
CONTROL_INSTANCES=$(gcloud compute instance-groups managed list-instances ${CONTROL_INSTANCE_GROUP_SHORT} --zone ${ZONE} --format=json | jq -r '.[] | .instance')
|
|
|
|
WORKER_INSTANCES=$(gcloud compute instance-groups managed list-instances ${WORKER_INSTANCE_GROUP_SHORT} --zone ${ZONE} --format=json | jq -r '.[] | .instance')
|
2022-09-05 12:12:46 -04:00
|
|
|
|
|
|
|
ALL_INSTANCES="$CONTROL_INSTANCES $WORKER_INSTANCES"
|
|
|
|
|
2022-10-31 05:40:08 -04:00
|
|
|
printf "Fetching logs for %s and %s\n" ${CONTROL_INSTANCES} ${WORKER_INSTANCES}
|
2022-09-05 12:12:46 -04:00
|
|
|
|
|
|
|
for INSTANCE in $ALL_INSTANCES; do
|
|
|
|
SHORT_NAME=${INSTANCE##*/}
|
2022-10-31 05:40:08 -04:00
|
|
|
printf "Fetching for %s\n" ${SHORT_NAME}
|
|
|
|
gcloud compute instances get-serial-port-output ${INSTANCE} \
|
2022-09-05 12:12:46 -04:00
|
|
|
--port 1 \
|
|
|
|
--start 0 \
|
2022-10-31 05:40:08 -04:00
|
|
|
--zone ${ZONE} > ${SHORT_NAME}.log
|
2022-09-05 12:12:46 -04:00
|
|
|
done
|