2020-08-10 17:43:49 +00:00
|
|
|
// +build !dockerless
|
|
|
|
|
2019-01-12 04:58:27 +00:00
|
|
|
/*
|
|
|
|
Copyright 2017 The Kubernetes Authors.
|
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
package dockershim
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
|
|
|
|
|
|
|
"k8s.io/kubernetes/pkg/kubelet/checkpointmanager"
|
|
|
|
"k8s.io/kubernetes/pkg/kubelet/checkpointmanager/checksum"
|
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
// default directory to store pod sandbox checkpoint files
|
|
|
|
sandboxCheckpointDir = "sandbox"
|
|
|
|
protocolTCP = Protocol("tcp")
|
|
|
|
protocolUDP = Protocol("udp")
|
|
|
|
protocolSCTP = Protocol("sctp")
|
|
|
|
schemaVersion = "v1"
|
|
|
|
)
|
|
|
|
|
2020-12-01 01:06:26 +00:00
|
|
|
// ContainerCheckpoint provides the interface for process container's checkpoint data
|
|
|
|
type ContainerCheckpoint interface {
|
2019-01-12 04:58:27 +00:00
|
|
|
checkpointmanager.Checkpoint
|
|
|
|
GetData() (string, string, string, []*PortMapping, bool)
|
|
|
|
}
|
|
|
|
|
2020-12-01 01:06:26 +00:00
|
|
|
// Protocol is the type of port mapping protocol
|
2019-01-12 04:58:27 +00:00
|
|
|
type Protocol string
|
|
|
|
|
|
|
|
// PortMapping is the port mapping configurations of a sandbox.
|
|
|
|
type PortMapping struct {
|
|
|
|
// Protocol of the port mapping.
|
|
|
|
Protocol *Protocol `json:"protocol,omitempty"`
|
|
|
|
// Port number within the container.
|
|
|
|
ContainerPort *int32 `json:"container_port,omitempty"`
|
|
|
|
// Port number on the host.
|
|
|
|
HostPort *int32 `json:"host_port,omitempty"`
|
2019-04-07 17:07:55 +00:00
|
|
|
// Host ip to expose.
|
|
|
|
HostIP string `json:"host_ip,omitempty"`
|
2019-01-12 04:58:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// CheckpointData contains all types of data that can be stored in the checkpoint.
|
|
|
|
type CheckpointData struct {
|
|
|
|
PortMappings []*PortMapping `json:"port_mappings,omitempty"`
|
|
|
|
HostNetwork bool `json:"host_network,omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// PodSandboxCheckpoint is the checkpoint structure for a sandbox
|
|
|
|
type PodSandboxCheckpoint struct {
|
|
|
|
// Version of the pod sandbox checkpoint schema.
|
|
|
|
Version string `json:"version"`
|
2020-08-10 17:43:49 +00:00
|
|
|
// Pod name of the sandbox. Same as the pod name in the Pod ObjectMeta.
|
2019-01-12 04:58:27 +00:00
|
|
|
Name string `json:"name"`
|
2020-08-10 17:43:49 +00:00
|
|
|
// Pod namespace of the sandbox. Same as the pod namespace in the Pod ObjectMeta.
|
2019-01-12 04:58:27 +00:00
|
|
|
Namespace string `json:"namespace"`
|
|
|
|
// Data to checkpoint for pod sandbox.
|
|
|
|
Data *CheckpointData `json:"data,omitempty"`
|
|
|
|
// Checksum is calculated with fnv hash of the checkpoint object with checksum field set to be zero
|
|
|
|
Checksum checksum.Checksum `json:"checksum"`
|
|
|
|
}
|
|
|
|
|
2020-12-01 01:06:26 +00:00
|
|
|
// NewPodSandboxCheckpoint inits a PodSandboxCheckpoint with the given args
|
|
|
|
func NewPodSandboxCheckpoint(namespace, name string, data *CheckpointData) ContainerCheckpoint {
|
2019-01-12 04:58:27 +00:00
|
|
|
return &PodSandboxCheckpoint{
|
|
|
|
Version: schemaVersion,
|
|
|
|
Namespace: namespace,
|
|
|
|
Name: name,
|
|
|
|
Data: data,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-12-01 01:06:26 +00:00
|
|
|
// MarshalCheckpoint encodes the PodSandboxCheckpoint instance to a json object
|
2019-01-12 04:58:27 +00:00
|
|
|
func (cp *PodSandboxCheckpoint) MarshalCheckpoint() ([]byte, error) {
|
|
|
|
cp.Checksum = checksum.New(*cp.Data)
|
|
|
|
return json.Marshal(*cp)
|
|
|
|
}
|
|
|
|
|
2020-12-01 01:06:26 +00:00
|
|
|
// UnmarshalCheckpoint decodes the blob data to the PodSandboxCheckpoint instance
|
2019-01-12 04:58:27 +00:00
|
|
|
func (cp *PodSandboxCheckpoint) UnmarshalCheckpoint(blob []byte) error {
|
|
|
|
return json.Unmarshal(blob, cp)
|
|
|
|
}
|
|
|
|
|
2020-12-01 01:06:26 +00:00
|
|
|
// VerifyChecksum verifies whether the PodSandboxCheckpoint's data checksum is
|
|
|
|
// the same as calculated checksum
|
2019-01-12 04:58:27 +00:00
|
|
|
func (cp *PodSandboxCheckpoint) VerifyChecksum() error {
|
|
|
|
return cp.Checksum.Verify(*cp.Data)
|
|
|
|
}
|
|
|
|
|
2020-12-01 01:06:26 +00:00
|
|
|
// GetData gets the PodSandboxCheckpoint's version and some net information
|
2019-01-12 04:58:27 +00:00
|
|
|
func (cp *PodSandboxCheckpoint) GetData() (string, string, string, []*PortMapping, bool) {
|
|
|
|
return cp.Version, cp.Name, cp.Namespace, cp.Data.PortMappings, cp.Data.HostNetwork
|
|
|
|
}
|