#bash (2020-02)
A channel for bash scripting
2020-02-26
data:image/s3,"s3://crabby-images/bef0a/bef0ab8a8f47fbd57aa7553b6e8029dff04dfeba" alt="Hemanth avatar"
@Hemanth has joined the channel
data:image/s3,"s3://crabby-images/bef0a/bef0ab8a8f47fbd57aa7553b6e8029dff04dfeba" alt="Hemanth avatar"
set the channel description: A channel for bash scripting
data:image/s3,"s3://crabby-images/908e0/908e047829a334ae81285b49bd79cf30644d5ba9" alt="wave"
data:image/s3,"s3://crabby-images/77add/77add115ee9c3ec563da0cb7663a6048fa3eebfe" alt="Adam Crews avatar"
@Adam Crews has joined the channel
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Erik Osterman (Cloud Posse) has joined the channel
data:image/s3,"s3://crabby-images/13ba6/13ba6046042d92f6e2153ef5d99bf1a792713776" alt="Tyrone Meijn avatar"
@Tyrone Meijn has joined the channel
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Hemanth any burning bash questions?
data:image/s3,"s3://crabby-images/f32e8/f32e85f027666416b654b0749258dcbce33cf974" alt="Jeremy G (Cloud Posse) avatar"
@Jeremy G (Cloud Posse) has joined the channel
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Andriy Knysh (Cloud Posse) has joined the channel
data:image/s3,"s3://crabby-images/a1a25/a1a2552c07b7a64517c7f76cbafad031c3fa4268" alt="Ievgenii Shepeliuk avatar"
@Ievgenii Shepeliuk has joined the channel
data:image/s3,"s3://crabby-images/bef0a/bef0ab8a8f47fbd57aa7553b6e8029dff04dfeba" alt="Hemanth avatar"
@Erik Osterman (Cloud Posse) haha yes
data:image/s3,"s3://crabby-images/bef0a/bef0ab8a8f47fbd57aa7553b6e8029dff04dfeba" alt="Hemanth avatar"
I am trying to do some sorting stuff, my output is like (those are aws instance IDs)
Instance-BCD222
19.5140495
12.7219977
13.3188209
Instance-OIUQWE
Instance-QOWIEU
Instance-QOWIEU
Instance-BCD123
19.5140495
12.7219977
13.3188209
Instance-QOWIEU
Instance-QWOEIU
Instance-ASLDKJ
Instance-BCD231
19.5140495
12.7219977
13.3188209
I want to remove those instances Id’s in that list that doesn’t have numbers under them
data:image/s3,"s3://crabby-images/bef0a/bef0ab8a8f47fbd57aa7553b6e8029dff04dfeba" alt="Hemanth avatar"
Presently using with jq
for i in $(aws ec2 describe-instances | jq -r '.["Reservations"]|.[]|.Instances|.[]| .InstanceId' | sort -n)
do
echo "$i"
aws cloudwatch get-metric-statistics --metric-name CPUUtilization --start-time 2020-02-20T12:00:00 --end-time 2020-02-20T13:00:00 --period 60 --namespace AWS/EC2 --extended-statistics p80 --dimensions Name=InstanceId,Value=$i | jq -r '.Datapoints[]|select(.ExtendedStatistics.p80 >=3 and .ExtendedStatistics.p80 >=0 )| [.ExtendedStatistics.p80] | @tsv'
done
data:image/s3,"s3://crabby-images/f32e8/f32e85f027666416b654b0749258dcbce33cf974" alt="Jeremy G (Cloud Posse) avatar"
Please describe the output you desire. I agree with Erik: you probably want to fix your queries rather than post-process them.
data:image/s3,"s3://crabby-images/bef0a/bef0ab8a8f47fbd57aa7553b6e8029dff04dfeba" alt="Hemanth avatar"
@Jeremy G (Cloud Posse) looking to eliminate those Instance-ID’s from output, that doesn’t show the numbers under them
Instance-BCD222
19.5140495
12.7219977
13.3188209
Instance-OIUQWE
Instance-QOWIEU
Instance-QOWIEU
Instance-BCD123
19.5140495
12.7219977
13.3188209
Instance-QOWIEU
Instance-QWOEIU
Instance-ASLDKJ
Instance-BCD231
19.5140495
12.7219977
13.3188209
data:image/s3,"s3://crabby-images/f32e8/f32e85f027666416b654b0749258dcbce33cf974" alt="Jeremy G (Cloud Posse) avatar"
But what are you really trying to accomplish? Would it be OK if the output were
Instance-BCD222 19.5140495 12.7219977 13.3188209
Instance-BCD123 19.5140495 12.7219977 13.3188209
Instance-BCD231 19.5140495 12.7219977 13.3188209
data:image/s3,"s3://crabby-images/bef0a/bef0ab8a8f47fbd57aa7553b6e8029dff04dfeba" alt="Hemanth avatar"
To get list of the numbers i am trying with my conditions in the query with a instance id that i can associate, I believe the output you shared looks fine to me as well
data:image/s3,"s3://crabby-images/fc362/fc362ec35b156d34c27d9c18b0d705efdc1813aa" alt="erik-stephens avatar"
@Hemanth Perhaps this?
x=$(aws ...)
if test -n "$x"; then
echo $i
echo "$x"
fi
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Hemanth if you attach some JSON snippets that might help us with the jq
query
data:image/s3,"s3://crabby-images/bef0a/bef0ab8a8f47fbd57aa7553b6e8029dff04dfeba" alt="Hemanth avatar"
@Erik Osterman (Cloud Posse) JSON snippet
{
"Label": "CPUUtilization",
"Datapoints": [
{
"Timestamp": "2020-02-20T12:15:00Z",
"Unit": "Percent",
"ExtendedStatistics": {
"p80": 15.954233538159674
}
},
{
"Timestamp": "2020-02-20T12:50:00Z",
"Unit": "Percent",
"ExtendedStatistics": {
"p80": 15.954233538159674
}
},
{
"Timestamp": "2020-02-20T12:25:00Z",
"Unit": "Percent",
"ExtendedStatistics": {
"p80": 15.931399422129846
}
},
{
"Timestamp": "2020-02-20T12:30:00Z",
"Unit": "Percent",
"ExtendedStatistics": {
"p80": 15.86309297171495
}
},
{
"Timestamp": "2020-02-20T12:05:00Z",
"Unit": "Percent",
"ExtendedStatistics": {
"p80": 15.954233538159674
}
},
{
"Timestamp": "2020-02-20T12:40:00Z",
"Unit": "Percent",
"ExtendedStatistics": {
"p80": 15.931399422129846
}
},
{
"Timestamp": "2020-02-20T12:10:00Z",
"Unit": "Percent",
"ExtendedStatistics": {
"p80": 14.707647811929322
}
},
{
"Timestamp": "2020-02-20T12:45:00Z",
"Unit": "Percent",
"ExtendedStatistics": {
"p80": 15.931399422129846
}
},
{
"Timestamp": "2020-02-20T12:20:00Z",
"Unit": "Percent",
"ExtendedStatistics": {
"p80": 15.86309297171495
}
},
{
"Timestamp": "2020-02-20T12:55:00Z",
"Unit": "Percent",
"ExtendedStatistics": {
"p80": 15.931399422129846
}
},
{
"Timestamp": "2020-02-20T12:00:00Z",
"Unit": "Percent",
"ExtendedStatistics": {
"p80": 15.931399422129846
}
},
{
"Timestamp": "2020-02-20T12:35:00Z",
"Unit": "Percent",
"ExtendedStatistics": {
"p80": 15.86309297171495
}
}
]
}
data:image/s3,"s3://crabby-images/bef0a/bef0ab8a8f47fbd57aa7553b6e8029dff04dfeba" alt="Hemanth avatar"
The one’s(instances) that doesn’t have numbers underneath them looks like
{
"Label": "CPUUtilization",
"Datapoints": [
{
"Timestamp": "2020-02-20T12:15:00Z",
"Unit": "Percent",
"ExtendedStatistics": {
"p80": 0.0
}
},
{
"Timestamp": "2020-02-20T12:50:00Z",
"Unit": "Percent",
"ExtendedStatistics": {
"p80": 0.0
}
},
data:image/s3,"s3://crabby-images/fc362/fc362ec35b156d34c27d9c18b0d705efdc1813aa" alt="erik-stephens avatar"
@Hemanth 0.0 can’t be >= 3 and >= 0
data:image/s3,"s3://crabby-images/f32e8/f32e85f027666416b654b0749258dcbce33cf974" alt="Jeremy G (Cloud Posse) avatar"
One main issue is that you should be outputting one array of Datapoints (on one line) per instance, and you are not. jq
is stream oriented, which is a different way of thinking. You will be helped by collecting the Datapoints into a single array, which is not what your jq
query is doing.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Oh, I think this is stemming from an earlier question that involved jq
?
data:image/s3,"s3://crabby-images/bef0a/bef0ab8a8f47fbd57aa7553b6e8029dff04dfeba" alt="Hemanth avatar"
yes
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Since jq
is so powerful, better to share that part again.
data:image/s3,"s3://crabby-images/bef0a/bef0ab8a8f47fbd57aa7553b6e8029dff04dfeba" alt="Hemanth avatar"
trying to work my way through
data:image/s3,"s3://crabby-images/bef0a/bef0ab8a8f47fbd57aa7553b6e8029dff04dfeba" alt="Hemanth avatar"
sure
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
It may be easier to get the query right rather than offload it to bash.
data:image/s3,"s3://crabby-images/bef0a/bef0ab8a8f47fbd57aa7553b6e8029dff04dfeba" alt="Hemanth avatar"
yes i am amazed at jq
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Yea, it’s awesome
data:image/s3,"s3://crabby-images/703f1/703f16033ebe0e670b09b496ca98cfe4d690b1a9" alt="bradym avatar"
@bradym has joined the channel
data:image/s3,"s3://crabby-images/68706/68706e9656cd71ed80a7a03984d34e63fd4f0429" alt="Kendall Link avatar"
@Kendall Link has joined the channel
data:image/s3,"s3://crabby-images/9f7d3/9f7d37e6df4fb280d718c728e563fdba7ce5b9ba" alt="Chris Fowles avatar"
@Chris Fowles has joined the channel
data:image/s3,"s3://crabby-images/fc362/fc362ec35b156d34c27d9c18b0d705efdc1813aa" alt="erik-stephens avatar"
@erik-stephens has joined the channel
data:image/s3,"s3://crabby-images/18e8e/18e8ed1b096524c68985bb4b5e42ddc80468fd8a" alt="osirisx.tls_cloudposs avatar"
@osirisx.tls_cloudposs has joined the channel
2020-02-27
data:image/s3,"s3://crabby-images/997de/997deac351b2277d68838501a28baf21fa053183" alt="wattiez.morgan avatar"
@wattiez.morgan has joined the channel
2020-02-28
data:image/s3,"s3://crabby-images/f32e8/f32e85f027666416b654b0749258dcbce33cf974" alt="Jeremy G (Cloud Posse) avatar"
@Hemanth try this:
for i in $(aws ec2 describe-instances | jq -r '.["Reservations"]|.[]|.Instances|.[]| .InstanceId' | sort -n); do echo "$i,$(aws cloudwatch get-metric-statistics --metric-name CPUUtilization --start-time 2020-02-20T12:00:00 --end-time 2020-02-20T13:00:00 --period 60 --namespace AWS/EC2 --extended-statistics p80 --dimensions Name=InstanceId,Value=$i | jq -r '[.Datapoints[]|select(.ExtendedStatistics.p80 >=0).ExtendedStatistics.p80] | @csv')" | grep -v ',$'; done
data:image/s3,"s3://crabby-images/9110b/9110bbbb13c7cbd081c09354e37b7de8f42b7073" alt="bowtie"
data:image/s3,"s3://crabby-images/bef0a/bef0ab8a8f47fbd57aa7553b6e8029dff04dfeba" alt="Hemanth avatar"
@Jeremy G (Cloud Posse) Thanks this is Neat