/
latency-time-service.go
94 lines (73 loc) · 2.63 KB
/
latency-time-service.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
package services
import (
"fmt"
"log"
"time"
"github.com/Appkube-awsx/awsx-lambda/utils"
"github.com/aws/aws-sdk-go/aws"
"github.com/aws/aws-sdk-go/service/cloudwatchlogs"
)
func GetLambadaLatencyTime(cloudClient *cloudwatchlogs.CloudWatchLogs, function string, startTime string, endTime string) (string, int, error) {
log.Println("Getting execution number and errors")
logGroupName := fmt.Sprintf("/aws/lambda/%s", function)
layout := "2006-01-02 15:04:05.000000000 -0700 MST"
fmt.Println("log group name", logGroupName)
// startTime = time.Date(2019, 1, 1, 1, 1, 1, 1, time.UTC) // 1 hour ago
input := &cloudwatchlogs.DescribeLogStreamsInput{
LogGroupName: aws.String(logGroupName),
}
resp, err := cloudClient.DescribeLogStreams(input)
dataCreationTime := resp.LogStreams[0].CreationTime
durationCreationTime := int64(*dataCreationTime)
durationCreationTimeInSeconds := durationCreationTime / 1000
creationTime := time.Unix(durationCreationTimeInSeconds, 0)
creationTimeString := creationTime.Format("2006-01-02 15:04:05.000000000 -0700 MST")
if err != nil {
log.Fatalln("Error: in getting event data", err)
}
var up_endTime time.Time
var up_startTime time.Time
if endTime == "" && startTime == "" {
up_endTime = time.Now()
up_startTime, err = time.Parse("2006-01-02 15:04:05.000000000 -0700 MST", creationTimeString)
if err != nil {
log.Fatalln("Error: in getting event data", err)
}
} else if startTime == "" {
up_startTime, err = time.Parse(layout, creationTimeString)
if err != nil {
log.Fatalln("Error: in getting event data", err)
}
up_endTime, err = time.Parse(layout, endTime)
fmt.Println("this is updt start time", up_startTime)
if err != nil {
log.Fatalln("Error: in getting event data", err)
}
} else if endTime == "" {
up_startTime, err = time.Parse(layout, startTime)
up_endTime = time.Now()
fmt.Println("this is updt end time", up_endTime)
if err != nil {
log.Fatal("This is time", err)
}
} else {
up_startTime, err = time.Parse(layout, startTime)
if err != nil {
log.Fatalln("Error: in getting event data", err)
}
up_endTime, err = time.Parse(layout, endTime)
if err != nil {
log.Fatalln("Error: in getting event data", err)
}
}
query := `stats avg(@duration)`
result, err := utils.GetQueryData(cloudClient, logGroupName, up_startTime, up_endTime, query)
//fmt.Println("This is result", result)
if err != nil {
return "", 0, err
}
fmt.Println("Result json: ", result)
// fmt.Println("Avg latency of ", logGroupName, "is", *result.Results[0][0].Value, "ms")
fmt.Println()
return *result.Results[0][0].Value, int(*result.Statistics.RecordsScanned), nil
}