-
Notifications
You must be signed in to change notification settings - Fork 22
Expand file tree
/
Copy pathtrace_types.go
More file actions
126 lines (107 loc) · 3.92 KB
/
trace_types.go
File metadata and controls
126 lines (107 loc) · 3.92 KB
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
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
/*
* MIT License
*
* Copyright (c) 2023 EASL and the vHive community
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*/
package common
import "container/list"
type FunctionInvocationStats struct {
HashOwner string
HashApp string
HashFunction string
Trigger string
Invocations []int
}
type FunctionRuntimeStats struct {
HashOwner string `csv:"HashOwner"`
HashApp string `csv:"HashApp"`
HashFunction string `csv:"HashFunction"`
Average float64 `csv:"Average"`
Count float64 `csv:"Count"`
Minimum float64 `csv:"Minimum"`
Maximum float64 `csv:"Maximum"`
Percentile0 float64 `csv:"percentile_Average_0"`
Percentile1 float64 `csv:"percentile_Average_1"`
Percentile25 float64 `csv:"percentile_Average_25"`
Percentile50 float64 `csv:"percentile_Average_50"`
Percentile75 float64 `csv:"percentile_Average_75"`
Percentile99 float64 `csv:"percentile_Average_99"`
Percentile100 float64 `csv:"percentile_Average_100"`
}
type FunctionMemoryStats struct {
HashOwner string `csv:"HashOwner"`
HashApp string `csv:"HashApp"`
HashFunction string `csv:"HashFunction"`
Count float64 `csv:"SampleCount"`
Average float64 `csv:"AverageAllocatedMb"`
Percentile1 float64 `csv:"AverageAllocatedMb_pct1"`
Percentile5 float64 `csv:"AverageAllocatedMb_pct5"`
Percentile25 float64 `csv:"AverageAllocatedMb_pct25"`
Percentile50 float64 `csv:"AverageAllocatedMb_pct50"`
Percentile75 float64 `csv:"AverageAllocatedMb_pct75"`
Percentile95 float64 `csv:"AverageAllocatedMb_pct95"`
Percentile99 float64 `csv:"AverageAllocatedMb_pct99"`
Percentile100 float64 `csv:"AverageAllocatedMb_pct100"`
}
type DirigentMetadata struct {
HashFunction string `json:"HashFunction"`
Image string `json:"Image"`
Port int `json:"Port"`
Protocol string `json:"Protocol"`
ScalingUpperBound int `json:"ScalingUpperBound"`
ScalingLowerBound int `json:"ScalingLowerBound"`
IterationMultiplier int `json:"IterationMultiplier"`
IOPercentage int `json:"IOPercentage"`
EnvVars []string `json:"EnvVars"`
ProgramArgs []string `json:"ProgramArgs"`
// dandelion only
NumArgs int `json:"NumArgs"`
NumRets int `json:"NumRets"`
}
type WorkflowMetadata struct {
InvocationRequest string
}
type Function struct {
Name string
Endpoint string
// From the static trace profiler
InitialScale int
// From the trace
InvocationStats *FunctionInvocationStats
RuntimeStats *FunctionRuntimeStats
MemoryStats *FunctionMemoryStats
DirigentMetadata *DirigentMetadata
ColdStartBusyLoopMs int
CPURequestsMilli int
MemoryRequestsMiB int
CPULimitsMilli int
YAMLPath string
PredeploymentPath []string
Specification *FunctionSpecification
// used only for dirigent workflows
WorkflowMetadata *WorkflowMetadata
}
type Node struct {
Function *Function
Branches []*list.List
Depth int
DAG string
}