Skip to content

Commit

Permalink
persist: baseline persist data format
Browse files Browse the repository at this point in the history
Fixes kata-containers#803

The disk persist data should be "versioned" and baselined, any modification in
persist data should be considered potential break of backward compatibility.

Signed-off-by: Wei Zhang <[email protected]>
  • Loading branch information
WeiZhang555 committed Feb 8, 2019
1 parent 3f3385a commit 66c27d7
Show file tree
Hide file tree
Showing 6 changed files with 576 additions and 0 deletions.
227 changes: 227 additions & 0 deletions virtcontainers/persist/api/config.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,227 @@
// Copyright (c) 2016 Intel Corporation
// Copyright (c) 2018 Huawei Corporation
//
// SPDX-License-Identifier: Apache-2.0
//

package persistapi

// Param is a key/value representation for hypervisor and kernel parameters.
type Param struct {
Key string
Value string
}

// Asset saves hypervisor asset
type Asset struct {
Path string `json:"path"`
Custom bool `json:"bool"`
}

// HypervisorConfig saves configurations of sandbox hypervisor
type HypervisorConfig struct {
// NumVCPUs specifies default number of vCPUs for the VM.
NumVCPUs uint32

//DefaultMaxVCPUs specifies the maximum number of vCPUs for the VM.
DefaultMaxVCPUs uint32

// DefaultMem specifies default memory size in MiB for the VM.
MemorySize uint32

// DefaultBridges specifies default number of bridges for the VM.
// Bridges can be used to hot plug devices
DefaultBridges uint32

// Msize9p is used as the msize for 9p shares
Msize9p uint32

// MemSlots specifies default memory slots the VM.
MemSlots uint32

// MemOffset specifies memory space for nvdimm device
MemOffset uint32

// KernelParams are additional guest kernel parameters.
KernelParams []Param

// HypervisorParams are additional hypervisor parameters.
HypervisorParams []Param

// KernelPath is the guest kernel host path.
KernelPath string

// ImagePath is the guest image host path.
ImagePath string

// InitrdPath is the guest initrd image host path.
// ImagePath and InitrdPath cannot be set at the same time.
InitrdPath string

// FirmwarePath is the bios host path
FirmwarePath string

// MachineAccelerators are machine specific accelerators
MachineAccelerators string

// HypervisorPath is the hypervisor executable host path.
HypervisorPath string

// BlockDeviceDriver specifies the driver to be used for block device
// either VirtioSCSI or VirtioBlock with the default driver being defaultBlockDriver
BlockDeviceDriver string

// HypervisorMachineType specifies the type of machine being
// emulated.
HypervisorMachineType string

// MemoryPath is the memory file path of VM memory. Used when either BootToBeTemplate or
// BootFromTemplate is true.
MemoryPath string

// DevicesStatePath is the VM device state file path. Used when either BootToBeTemplate or
// BootFromTemplate is true.
DevicesStatePath string

// EntropySource is the path to a host source of
// entropy (/dev/random, /dev/urandom or real hardware RNG device)
EntropySource string

// customAssets is a map of assets.
// Each value in that map takes precedence over the configured assets.
// For example, if there is a value for the "kernel" key in this map,
// it will be used for the sandbox's kernel path instead of KernelPath.
CustomAssets map[string]*Asset

// BlockDeviceCacheSet specifies cache-related options will be set to block devices or not.
BlockDeviceCacheSet bool

// BlockDeviceCacheDirect specifies cache-related options for block devices.
// Denotes whether use of O_DIRECT (bypass the host page cache) is enabled.
BlockDeviceCacheDirect bool

// BlockDeviceCacheNoflush specifies cache-related options for block devices.
// Denotes whether flush requests for the device are ignored.
BlockDeviceCacheNoflush bool

// DisableBlockDeviceUse disallows a block device from being used.
DisableBlockDeviceUse bool

// EnableIOThreads enables IO to be processed in a separate thread.
// Supported currently for virtio-scsi driver.
EnableIOThreads bool

// Debug changes the default hypervisor and kernel parameters to
// enable debug output where available.
Debug bool

// MemPrealloc specifies if the memory should be pre-allocated
MemPrealloc bool

// HugePages specifies if the memory should be pre-allocated from huge pages
HugePages bool

// Realtime Used to enable/disable realtime
Realtime bool

// Mlock is used to control memory locking when Realtime is enabled
// Realtime=true and Mlock=false, allows for swapping out of VM memory
// enabling higher density
Mlock bool

// DisableNestingChecks is used to override customizations performed
// when running on top of another VMM.
DisableNestingChecks bool

// UseVSock use a vsock for agent communication
UseVSock bool

// HotplugVFIOOnRootBus is used to indicate if devices need to be hotplugged on the
// root bus instead of a bridge.
HotplugVFIOOnRootBus bool

// BootToBeTemplate used to indicate if the VM is created to be a template VM
BootToBeTemplate bool

// BootFromTemplate used to indicate if the VM should be created from a template VM
BootFromTemplate bool

// DisableVhostNet is used to indicate if host supports vhost_net
DisableVhostNet bool

// GuestHookPath is the path within the VM that will be used for 'drop-in' hooks
GuestHookPath string
}

// KataAgentConfig is a structure storing information needed
// to reach the Kata Containers agent.
type KataAgentConfig struct {
LongLiveConn bool
UseVSock bool
}

// HyperstartConfig is a structure storing information needed for
// hyperstart agent initialization.
type HyperstartConfig struct {
SockCtlName string
SockTtyName string
}

// ProxyConfig is a structure storing information needed from any
// proxy in order to be properly initialized.
type ProxyConfig struct {
Path string
Debug bool
}

// ShimConfig is the structure providing specific configuration
// for shim implementation.
type ShimConfig struct {
Path string
Debug bool
}

// NetworkConfig is the network configuration related to a network.
type NetworkConfig struct {
}

// SandboxConfig is a sandbox configuration.
// Refs: virtcontainers/sandbox.go:SandboxConfig
type SandboxConfig struct {
HypervisorType string
HypervisorConfig HypervisorConfig

// only one agent config can be non-nil according to agent type
AgentType string
KataAgentConfig *KataAgentConfig `json:",omitempty"`
HyperstartConfig *HyperstartConfig `json:",omitempty"`

ProxyType string
ProxyConfig ProxyConfig

ShimType string
KataShimConfig ShimConfig

NetworkModel string
NetworkConfig NetworkConfig

ShmSize uint64

// SharePidNs sets all containers to share the same sandbox level pid namespace.
SharePidNs bool

// Stateful keeps sandbox resources in memory across APIs. Users will be responsible
// for calling Release() to release the memory resources.
Stateful bool

// SystemdCgroup enables systemd cgroup support
SystemdCgroup bool

// Experimental enables experimental features
Experimental bool

// Information for fields not saved:
// * Annotation: this is kind of casual data, we don't need casual data in persist file,
// if you know this data needs to persist, please gives it
// a specific field
}
111 changes: 111 additions & 0 deletions virtcontainers/persist/api/container.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,111 @@
// Copyright (c) 2016 Intel Corporation
// Copyright (c) 2018 Huawei Corporation
//
// SPDX-License-Identifier: Apache-2.0
//

package persistapi

import (
"os"
"time"
)

// ============= container level resources =============

// DeviceMap saves how host device maps to container device
// one hypervisor device can be
// Refs: virtcontainers/container.go:ContainerDevice
type DeviceMap struct {
// ID reference to VM device
ID string

// ContainerPath is device path displayed in container
ContainerPath string

// FileMode permission bits for the device.
FileMode os.FileMode

// UID is user ID in the container namespace
UID uint32

// GID is group ID in the container namespace
GID uint32
}

// Mount describes a container mount.
type Mount struct {
Source string
Destination string

// Type specifies the type of filesystem to mount.
Type string

// Options list all the mount options of the filesystem.
Options []string

// HostPath used to store host side bind mount path
HostPath string

// ReadOnly specifies if the mount should be read only or not
ReadOnly bool

// BlockDeviceID represents block device that is attached to the
// VM in case this mount is a block device file or a directory
// backed by a block device.
BlockDeviceID string
}

// RootfsState saves state of container rootfs
type RootfsState struct {
// BlockDeviceID represents container rootfs block device ID
// when backed by devicemapper
BlockDeviceID string

// RootFStype is file system of the rootfs incase it is block device
FsType string
}

// Process gathers data related to a container process.
// Refs: virtcontainers/container.go:Process
type Process struct {
// Token is the process execution context ID. It must be
// unique per sandbox.
// Token is used to manipulate processes for containers
// that have not started yet, and later identify them
// uniquely within a sandbox.
Token string

// Pid is the process ID as seen by the host software
// stack, e.g. CRI-O, containerd. This is typically the
// shim PID.
Pid int

StartTime time.Time
}

// ContainerState represents container state
type ContainerState struct {
// State is container running status
State string

// Rootfs contains information of container rootfs
Rootfs RootfsState

// ShimPid is pid of shim process for each container
ShimPid int

// DeviceMaps is mapping between sandbox device to dest in container
DeviceMaps []DeviceMap

// Mounts is mount info from OCI spec
Mounts []Mount

// Process on host representing container process
// FIXME: []Process or Process ?
Process []Process

// BundlePath saves container OCI config.json, which can be unmarshaled
// and translated to "CompatOCISpec"
BundlePath string
}
Loading

0 comments on commit 66c27d7

Please sign in to comment.