Documentation ¶
Index ¶
Constants ¶
const ( // SleepBetweenUsageDataCollection is the sleep duration between collecting usage data for a container. SleepBetweenUsageDataCollection = 1 * time.Second // ContainerStatsBufferLength is the number of usage metrics stored in memory for a container. It is calculated as // Number of usage metrics gathered in a second (1) * 60 * Time duration in minutes to store the data for (2) ContainerStatsBufferLength = 120 )
const (
// BytesInMiB is the number of bytes in a MebiByte.
BytesInMiB = 1024 * 1024
)
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type ContainerMetadata ¶
type ContainerMetadata struct {
DockerID string `json:"-"`
}
ContainerMetadata contains meta-data information for a container.
type ContainerStats ¶
type ContainerStats struct {
// contains filtered or unexported fields
}
ContainerStats encapsulates the raw CPU and memory utilization from cgroup fs.
type DockerContainerMetadataResolver ¶
type DockerContainerMetadataResolver struct {
// contains filtered or unexported fields
}
DockerContainerMetadataResolver implements ContainerMetadataResolver for DockerTaskEngine.
func (*DockerContainerMetadataResolver) ResolveContainer ¶ added in v1.12.2
func (resolver *DockerContainerMetadataResolver) ResolveContainer(dockerID string) (*api.DockerContainer, error)
ResolveContainer resolves the api container object, given container id.
func (*DockerContainerMetadataResolver) ResolveTask ¶
func (resolver *DockerContainerMetadataResolver) ResolveTask(dockerID string) (*api.Task, error)
ResolveTask resolves the api task object, given container id.
type DockerStatsEngine ¶
type DockerStatsEngine struct {
// contains filtered or unexported fields
}
DockerStatsEngine is used to monitor docker container events and to report utlization metrics of the same.
func NewDockerStatsEngine ¶
func NewDockerStatsEngine(cfg *config.Config, client ecsengine.DockerClient, containerChangeEventStream *eventstream.EventStream) *DockerStatsEngine
NewDockerStatsEngine creates a new instance of the DockerStatsEngine object. MustInit() must be called to initialize the fields of the new event listener.
func (*DockerStatsEngine) GetInstanceMetrics ¶
func (engine *DockerStatsEngine) GetInstanceMetrics() (*ecstcs.MetricsMetadata, []*ecstcs.TaskMetric, error)
GetInstanceMetrics gets all task metrics and instance metadata from stats engine.
func (*DockerStatsEngine) Init ¶
func (engine *DockerStatsEngine) Init() error
Init subscribes to the container change event stream.
func (*DockerStatsEngine) MustInit ¶
func (engine *DockerStatsEngine) MustInit(taskEngine ecsengine.TaskEngine, cluster string, containerInstanceArn string) error
MustInit initializes fields of the DockerStatsEngine object.
type Engine ¶
type Engine interface {
GetInstanceMetrics() (*ecstcs.MetricsMetadata, []*ecstcs.TaskMetric, error)
}
Engine defines methods to be implemented by the engine struct. It is defined to make testing easier.
type Queue ¶
type Queue struct {
// contains filtered or unexported fields
}
Queue abstracts a queue using UsageStats slice.
func (*Queue) Add ¶
func (queue *Queue) Add(rawStat *ContainerStats)
Add adds a new set of container stats to the queue.
func (*Queue) GetCPUStatsSet ¶
func (queue *Queue) GetCPUStatsSet() (*ecstcs.CWStatsSet, error)
GetCPUStatsSet gets the stats set for CPU utilization.
func (*Queue) GetMemoryStatsSet ¶
func (queue *Queue) GetMemoryStatsSet() (*ecstcs.CWStatsSet, error)
GetMemoryStatsSet gets the stats set for memory utilization.
func (*Queue) GetRawUsageStats ¶
func (queue *Queue) GetRawUsageStats(numStats int) ([]UsageStats, error)
GetRawUsageStats gets the array of most recent raw UsageStats, in descending order of timestamps.
type StatsContainer ¶ added in v1.10.0
type StatsContainer struct {
// contains filtered or unexported fields
}
StatsContainer abstracts methods to gather and aggregate utilization data for a container.
func (*StatsContainer) StartStatsCollection ¶ added in v1.10.0
func (container *StatsContainer) StartStatsCollection()
func (*StatsContainer) StopStatsCollection ¶ added in v1.10.0
func (container *StatsContainer) StopStatsCollection()