cancel
Showing results for 
Show  only  | Search instead for 
Did you mean: 

Timeseries dt.availability.state split by hours - business non business

AlanFoley
Participant

Hi All

I am successfully able to calculate an overall monthly Availability % which aligns to the value show in Host Classic for availability for a given host

Here is the DQL:

timeseries {AvailabilityStateUP=sum(dt.host.availability),end()}, filter:availability.state == "up"
, by: {dt.entity.host,availability.state},interval:1h
| expand `end()`
| filter dt.entity.host == "HOST-xxx"
| fieldsAdd hour = formatTimestamp(`end()`, format:"HH")
| sort `end()`

| ... rest of DQL statements for Availability Percentage Calculation and output fields

I would like to be able to report on Monthly availability percentage split by Business (06h00-18h00) and Non Business Hours (18h00-06h00) - ideally split at the "timeseries" level

In the screenshot below you can see that "AvailabilityStateUP" contains the array for the WHOLE reporting interval - in this case the last 24 hours - not split by "end()" -   I can filter by "hour" after the timeries extraction but it does not help as the array contains all values for the whole reporting period

The problem is the availability figure for each hour will be the availability % calculation of the WHOLE array for the reporting period

I thought I could split by: end() but this is also not possible

I also looked at "bins:" but the documentation did not help me - is this an option? can someone assit with the syntax as per my requirement 

AlanFoley_1-1721196206198.png

Any other ides? Apprecaite any assistance

Thanks

Alan

 

2 REPLIES 2

krzysztof_hoja
Dynatrace Mentor
Dynatrace Mentor

You do not need to expand. You can use iterative expressions:

timeseries {AvailabilityStateUP=sum(dt.host.availability),e=end()}, filter:availability.state == "up" and dt.entity.host == "HOST-000CA78B479207CD"
, by: {dt.entity.host,availability.state},interval:1h
| fieldsAdd AvailabilityStateUP_BH = if( getHour(e[])>=8 and getHour(e[])<=17, AvailabilityStateUP[] )
| fieldsAdd AvailabilityStateUP_NBH = if( getHour(e[])<8 or getHour(e[])>17, AvailabilityStateUP[] )

 this way you get 2 timeseries, each one filled only values in our outside business hours. Then you can proceed with summarization of the array using array functions.

krzysztof_hoja_1-1721212267538.png

 

It is possible with expand too, but you need to construct single array of records containing both: availability metric and time:

timeseries {AvailabilityStateUP=sum(dt.host.availability),e=end()}, filter:availability.state == "up" and dt.entity.host == "HOST-000CA78B479207CD"
, by: {dt.entity.host,availability.state},interval:1h
| fieldsAdd AvailabilityStateUPWithH = record(av=AvailabilityStateUP[], h=getHour(e[]))
| expand AvailabilityStateUPWithH
| fieldsFlatten AvailabilityStateUPWithH

 

krzysztof_hoja_0-1721212219589.png

 

 

Hi krzysztof_hoja

The iterative expressions solution is perfect - works like a charm

Really appreciate you taking the time to test and provide a solution

Thanks a mil

Regards

Alan

 

Featured Posts