Skip to content

Instantly share code, notes, and snippets.

@dekz
Forked from tekwiz/aws-logs-tail-group.sh
Created November 14, 2016 11:48
Show Gist options
  • Save dekz/c9632b21931db05efc18d2054abea711 to your computer and use it in GitHub Desktop.
Save dekz/c9632b21931db05efc18d2054abea711 to your computer and use it in GitHub Desktop.
AWS Logs Tailer
#!/bin/bash
group_name='<log-group-name>'
start_seconds_ago=3600
aws_cmd_opts= # e.g. "--profile <profile-name>"
# Usage: get_loglines "<log-group-name>" <start-time>
get_loglines() {
aws $aws_cmd_opts --output text logs filter-log-events \
--log-group-name "$1" \
--interleaved \
--start-time $2
}
# Usage: get_next_start_time <prev-start-time> "<loglines>"
get_next_start_time() {
next_start_time=$( sed -nE 's/^EVENTS.([^[:blank:]]+).([[:digit:]]+).+$/\2/ p' <<< "$2" | tail -n1 )
if [[ -n "$next_start_time" ]]; then
echo $(( $next_start_time + 1 ))
else
echo $1
fi
}
start_time=$(( ( $(date -u +"%s") - $start_seconds_ago ) * 1000 ))
while [[ -n "$start_time" ]]; do
loglines=$( get_loglines "$group_name" $start_time )
[ $? -ne 0 ] && break
start_time=$( get_next_start_time $start_time "$loglines" )
echo "$loglines"
sleep 2
done
#!/bin/bash
group_name='<log-group-name>'
stream_name='<log-stream-name>'
start_seconds_ago=3600
aws_cmd_opts= # e.g. "--profile <profile-name>"
# Usage: get_loglines "<log-group-name>" "<log-stream-name>" <start-time>
get_loglines() {
aws $aws_cmd_opts --output text logs get-log-events \
--log-group-name "$1" \
--log-stream-name "$2" \
--start-time $3
}
# Usage: get_next_start_time <prev-start-time> "<loglines>"
get_next_start_time() {
next_start_time=$( sed -nE 's/^EVENTS.([[:digit:]]+).+$/\1/ p' <<< "$2" | tail -n1 )
if [[ -n "$next_start_time" ]]; then
echo $(( $next_start_time + 1 ))
else
echo $1
fi
}
start_time=$(( ( $(date -u +"%s") - $start_seconds_ago ) * 1000 ))
while [[ -n "$start_time" ]]; do
loglines=$( get_loglines "$group_name" "$stream_name" $start_time )
[ $? -ne 0 ] && break
start_time=$( get_next_start_time $start_time "$loglines" )
echo "$loglines"
sleep 2
done
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment