2017-06-08 14:51:02 +00:00
|
|
|
package container
|
2016-12-22 16:15:22 +00:00
|
|
|
|
|
|
|
import (
|
2017-06-27 16:21:16 +00:00
|
|
|
"github.com/bcicen/ctop/connector/collector"
|
2017-11-22 14:27:38 +00:00
|
|
|
"github.com/bcicen/ctop/connector/manager"
|
2017-03-06 08:25:59 +00:00
|
|
|
"github.com/bcicen/ctop/cwidgets"
|
2017-02-26 22:04:24 +00:00
|
|
|
"github.com/bcicen/ctop/cwidgets/compact"
|
2017-06-08 14:51:02 +00:00
|
|
|
"github.com/bcicen/ctop/logging"
|
2017-06-27 15:46:03 +00:00
|
|
|
"github.com/bcicen/ctop/models"
|
2016-12-22 16:15:22 +00:00
|
|
|
)
|
|
|
|
|
2017-06-08 14:51:02 +00:00
|
|
|
var (
|
|
|
|
log = logging.Init()
|
|
|
|
)
|
|
|
|
|
2017-03-03 07:57:26 +00:00
|
|
|
// Metrics and metadata representing a container
|
2016-12-22 22:04:21 +00:00
|
|
|
type Container struct {
|
2017-06-27 15:46:03 +00:00
|
|
|
models.Metrics
|
2017-03-03 07:57:26 +00:00
|
|
|
Id string
|
|
|
|
Meta map[string]string
|
|
|
|
Widgets *compact.Compact
|
2017-06-08 14:51:02 +00:00
|
|
|
Display bool // display this container in compact view
|
2017-03-06 08:25:59 +00:00
|
|
|
updater cwidgets.WidgetUpdater
|
2017-06-27 16:21:16 +00:00
|
|
|
collector collector.Collector
|
2017-11-20 11:09:36 +00:00
|
|
|
manager manager.Manager
|
2017-01-06 11:51:11 +00:00
|
|
|
}
|
|
|
|
|
2017-11-20 11:09:36 +00:00
|
|
|
func New(id string, collector collector.Collector, manager manager.Manager) *Container {
|
2017-03-06 08:25:59 +00:00
|
|
|
widgets := compact.NewCompact(id)
|
2017-03-03 07:57:26 +00:00
|
|
|
return &Container{
|
2017-06-27 15:46:03 +00:00
|
|
|
Metrics: models.NewMetrics(),
|
2017-03-03 07:57:26 +00:00
|
|
|
Id: id,
|
|
|
|
Meta: make(map[string]string),
|
2017-03-06 08:25:59 +00:00
|
|
|
Widgets: widgets,
|
|
|
|
updater: widgets,
|
2017-03-03 07:57:26 +00:00
|
|
|
collector: collector,
|
2017-11-20 11:09:36 +00:00
|
|
|
manager: manager,
|
2017-02-24 01:18:59 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-03-06 08:25:59 +00:00
|
|
|
func (c *Container) SetUpdater(u cwidgets.WidgetUpdater) {
|
|
|
|
c.updater = u
|
|
|
|
for k, v := range c.Meta {
|
|
|
|
c.updater.SetMeta(k, v)
|
2017-03-03 07:57:26 +00:00
|
|
|
}
|
2017-02-24 01:18:59 +00:00
|
|
|
}
|
|
|
|
|
2017-03-03 07:57:26 +00:00
|
|
|
func (c *Container) SetMeta(k, v string) {
|
|
|
|
c.Meta[k] = v
|
2017-03-06 08:25:59 +00:00
|
|
|
c.updater.SetMeta(k, v)
|
2017-02-24 01:18:59 +00:00
|
|
|
}
|
|
|
|
|
2017-03-06 08:25:59 +00:00
|
|
|
func (c *Container) GetMeta(k string) string {
|
|
|
|
if v, ok := c.Meta[k]; ok {
|
|
|
|
return v
|
|
|
|
}
|
|
|
|
return ""
|
2017-03-05 06:46:41 +00:00
|
|
|
}
|
|
|
|
|
2017-02-03 23:33:13 +00:00
|
|
|
func (c *Container) SetState(s string) {
|
2017-03-06 08:25:59 +00:00
|
|
|
c.SetMeta("state", s)
|
2017-03-03 07:57:26 +00:00
|
|
|
// start collector, if needed
|
2017-03-06 08:25:59 +00:00
|
|
|
if s == "running" && !c.collector.Running() {
|
2017-03-03 07:57:26 +00:00
|
|
|
c.collector.Start()
|
|
|
|
c.Read(c.collector.Stream())
|
|
|
|
}
|
|
|
|
// stop collector, if needed
|
2017-03-06 08:25:59 +00:00
|
|
|
if s != "running" && c.collector.Running() {
|
2017-03-03 07:57:26 +00:00
|
|
|
c.collector.Stop()
|
|
|
|
}
|
2017-02-24 09:10:14 +00:00
|
|
|
}
|
|
|
|
|
2017-06-27 17:18:17 +00:00
|
|
|
// Return container log collector
|
|
|
|
func (c *Container) Logs() collector.LogCollector {
|
|
|
|
return c.collector.Logs()
|
|
|
|
}
|
|
|
|
|
2017-02-23 02:01:56 +00:00
|
|
|
// Read metric stream, updating widgets
|
2017-06-27 15:46:03 +00:00
|
|
|
func (c *Container) Read(stream chan models.Metrics) {
|
2016-12-22 22:04:21 +00:00
|
|
|
go func() {
|
2017-02-23 02:01:56 +00:00
|
|
|
for metrics := range stream {
|
2017-03-03 07:57:26 +00:00
|
|
|
c.Metrics = metrics
|
2017-03-06 08:25:59 +00:00
|
|
|
c.updater.SetMetrics(metrics)
|
2016-12-22 22:04:21 +00:00
|
|
|
}
|
2017-03-03 07:57:26 +00:00
|
|
|
log.Infof("reader stopped for container: %s", c.Id)
|
2017-06-27 15:46:03 +00:00
|
|
|
c.Metrics = models.NewMetrics()
|
2017-03-03 07:57:26 +00:00
|
|
|
c.Widgets.Reset()
|
2016-12-22 22:04:21 +00:00
|
|
|
}()
|
2017-03-03 07:57:26 +00:00
|
|
|
log.Infof("reader started for container: %s", c.Id)
|
2016-12-22 22:04:21 +00:00
|
|
|
}
|
2017-11-20 11:09:36 +00:00
|
|
|
|
|
|
|
func (c *Container) Start() {
|
|
|
|
if c.Meta["state"] != "running" {
|
|
|
|
if err := c.manager.Start(); err != nil {
|
|
|
|
log.Warningf("container %s: %v", c.Id, err)
|
2018-01-11 18:27:30 +00:00
|
|
|
log.StatusErr(err)
|
2017-11-20 11:09:36 +00:00
|
|
|
return
|
|
|
|
}
|
|
|
|
c.SetState("running")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *Container) Stop() {
|
|
|
|
if c.Meta["state"] == "running" {
|
|
|
|
if err := c.manager.Stop(); err != nil {
|
|
|
|
log.Warningf("container %s: %v", c.Id, err)
|
2018-01-11 18:27:30 +00:00
|
|
|
log.StatusErr(err)
|
2017-11-20 11:09:36 +00:00
|
|
|
return
|
|
|
|
}
|
|
|
|
c.SetState("exited")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *Container) Remove() {
|
2018-01-11 14:40:21 +00:00
|
|
|
if err := c.manager.Remove(); err != nil {
|
|
|
|
log.Warningf("container %s: %v", c.Id, err)
|
2018-01-11 18:27:30 +00:00
|
|
|
log.StatusErr(err)
|
2017-11-20 11:09:36 +00:00
|
|
|
}
|
|
|
|
}
|