
Signed-off-by: Michael Crosby <crosbymichael@gmail.com> Update go-runc to 49b2a02ec1ed3e4ae52d30b54a291b75 Signed-off-by: Michael Crosby <crosbymichael@gmail.com> Add shim to restore creation Signed-off-by: Michael Crosby <crosbymichael@gmail.com> Keep checkpoint path in service Signed-off-by: Michael Crosby <crosbymichael@gmail.com> Add C/R to non-shim build Signed-off-by: Michael Crosby <crosbymichael@gmail.com> Checkpoint rw and image Signed-off-by: Michael Crosby <crosbymichael@gmail.com> Pause container on bind checkpoints Signed-off-by: Michael Crosby <crosbymichael@gmail.com> Return dump.log in error on checkpoint failure Signed-off-by: Michael Crosby <crosbymichael@gmail.com> Pause container for checkpoint Signed-off-by: Michael Crosby <crosbymichael@gmail.com> Update runc to 639454475cb9c8b861cc599f8bcd5c8c790ae402 For checkpoint into to work you need runc version 639454475cb9c8b861cc599f8bcd5c8c790ae402 + and criu 3.0 as this is what I have been testing with. Signed-off-by: Michael Crosby <crosbymichael@gmail.com> Move restore behind create calls This remove the restore RPCs in favor of providing the checkpoint information to the `Create` calls of a container. If provided, the container will be created/restored from the checkpoint instead of an existing container. Signed-off-by: Michael Crosby <crosbymichael@gmail.com> Regen protos after rebase Signed-off-by: Michael Crosby <crosbymichael@gmail.com>
64 lines
1.3 KiB
Go
64 lines
1.3 KiB
Go
package plugin
|
|
|
|
// ContainerMonitor provides an interface for monitoring of containers within containerd
|
|
type ContainerMonitor interface {
|
|
// Monitor adds the provided container to the monitor
|
|
Monitor(Container) error
|
|
// Stop stops and removes the provided container from the monitor
|
|
Stop(Container) error
|
|
// Events emits events from the monitor
|
|
Events(chan<- *Event)
|
|
}
|
|
|
|
func NewMultiContainerMonitor(monitors ...ContainerMonitor) ContainerMonitor {
|
|
return &multiContainerMonitor{
|
|
monitors: monitors,
|
|
}
|
|
}
|
|
|
|
func NewNoopMonitor() ContainerMonitor {
|
|
return &noopContainerMonitor{}
|
|
}
|
|
|
|
type noopContainerMonitor struct {
|
|
}
|
|
|
|
func (mm *noopContainerMonitor) Monitor(c Container) error {
|
|
return nil
|
|
}
|
|
|
|
func (mm *noopContainerMonitor) Stop(c Container) error {
|
|
return nil
|
|
}
|
|
|
|
func (mm *noopContainerMonitor) Events(events chan<- *Event) {
|
|
}
|
|
|
|
type multiContainerMonitor struct {
|
|
monitors []ContainerMonitor
|
|
}
|
|
|
|
func (mm *multiContainerMonitor) Monitor(c Container) error {
|
|
for _, m := range mm.monitors {
|
|
if err := m.Monitor(c); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (mm *multiContainerMonitor) Stop(c Container) error {
|
|
for _, m := range mm.monitors {
|
|
if err := m.Stop(c); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (mm *multiContainerMonitor) Events(events chan<- *Event) {
|
|
for _, m := range mm.monitors {
|
|
m.Events(events)
|
|
}
|
|
}
|