mirror of
https://github.com/kata-containers/kata-containers.git
synced 2025-09-16 14:28:35 +00:00
Merge pull request #503 from egernst/kata-deploy-nemu
kata-deploy: add nemu support
This commit is contained in:
42
kata-deploy/examples/test-deploy-kata-nemu.yaml
Normal file
42
kata-deploy/examples/test-deploy-kata-nemu.yaml
Normal file
@@ -0,0 +1,42 @@
|
|||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
run: php-apache-kata-nemu
|
||||||
|
name: php-apache-kata-nemu
|
||||||
|
spec:
|
||||||
|
replicas: 1
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
run: php-apache-kata-nemu
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
run: php-apache-kata-nemu
|
||||||
|
spec:
|
||||||
|
runtimeClassName: kata-nemu
|
||||||
|
containers:
|
||||||
|
- image: k8s.gcr.io/hpa-example
|
||||||
|
imagePullPolicy: Always
|
||||||
|
name: php-apache
|
||||||
|
ports:
|
||||||
|
- containerPort: 80
|
||||||
|
protocol: TCP
|
||||||
|
resources:
|
||||||
|
requests:
|
||||||
|
cpu: 200m
|
||||||
|
restartPolicy: Always
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
name: php-apache-kata-nemu
|
||||||
|
spec:
|
||||||
|
ports:
|
||||||
|
- port: 80
|
||||||
|
protocol: TCP
|
||||||
|
targetPort: 80
|
||||||
|
selector:
|
||||||
|
run: php-apache-kata-nemu
|
||||||
|
sessionAffinity: None
|
||||||
|
type: ClusterIP
|
6
kata-deploy/k8s-1.13/kata-nemu-runtimeClass.yaml
Normal file
6
kata-deploy/k8s-1.13/kata-nemu-runtimeClass.yaml
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
---
|
||||||
|
kind: RuntimeClass
|
||||||
|
apiVersion: node.k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: kata-nemu
|
||||||
|
handler: kata-nemu
|
6
kata-deploy/k8s-1.14/kata-nemu-runtimeClass.yaml
Normal file
6
kata-deploy/k8s-1.14/kata-nemu-runtimeClass.yaml
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
---
|
||||||
|
kind: RuntimeClass
|
||||||
|
apiVersion: node.k8s.io/v1beta1
|
||||||
|
metadata:
|
||||||
|
name: kata-nemu
|
||||||
|
handler: kata-nemu
|
@@ -39,6 +39,10 @@ function configure_docker() {
|
|||||||
"kata-qemu": {
|
"kata-qemu": {
|
||||||
"path": "/opt/kata/bin/kata-runtime",
|
"path": "/opt/kata/bin/kata-runtime",
|
||||||
"runtimeArgs": [ "--kata-config", "/opt/kata/share/defaults/kata-containers/configuration-qemu.toml" ]
|
"runtimeArgs": [ "--kata-config", "/opt/kata/share/defaults/kata-containers/configuration-qemu.toml" ]
|
||||||
|
},
|
||||||
|
"kata-nemu": {
|
||||||
|
"path": "/opt/kata/bin/kata-runtime",
|
||||||
|
"runtimeArgs": [ "--kata-config", "/opt/kata/share/defaults/kata-containers/configuration-nemu.toml" ]
|
||||||
},
|
},
|
||||||
"kata-fc": {
|
"kata-fc": {
|
||||||
"path": "/opt/kata/bin/kata-runtime",
|
"path": "/opt/kata/bin/kata-runtime",
|
||||||
|
@@ -13,9 +13,12 @@ crio_conf_file_backup="${crio_conf_file}.bak"
|
|||||||
containerd_conf_file="/etc/containerd/config.toml"
|
containerd_conf_file="/etc/containerd/config.toml"
|
||||||
containerd_conf_file_backup="${containerd_conf_file}.bak"
|
containerd_conf_file_backup="${containerd_conf_file}.bak"
|
||||||
|
|
||||||
shim_binary="containerd-shim-kata-v2"
|
shims=(
|
||||||
shim_file="/usr/local/bin/${shim_binary}"
|
"qemu"
|
||||||
shim_backup="/usr/local/bin/${shim_binary}.bak"
|
"nemu"
|
||||||
|
"fc"
|
||||||
|
)
|
||||||
|
|
||||||
# If we fail for any reason a message will be displayed
|
# If we fail for any reason a message will be displayed
|
||||||
die() {
|
die() {
|
||||||
msg="$*"
|
msg="$*"
|
||||||
@@ -62,10 +65,13 @@ function configure_crio() {
|
|||||||
cp -n "$crio_conf_file" "$crio_conf_file_backup"
|
cp -n "$crio_conf_file" "$crio_conf_file_backup"
|
||||||
|
|
||||||
local kata_qemu_path="/opt/kata/bin/kata-qemu"
|
local kata_qemu_path="/opt/kata/bin/kata-qemu"
|
||||||
|
local kata_nemu_path="/opt/kata/bin/kata-nemu"
|
||||||
local kata_fc_path="/opt/kata/bin/kata-fc"
|
local kata_fc_path="/opt/kata/bin/kata-fc"
|
||||||
local kata_qemu_conf="crio.runtime.runtimes.kata-qemu"
|
local kata_qemu_conf="crio.runtime.runtimes.kata-qemu"
|
||||||
|
local kata_nemu_conf="crio.runtime.runtimes.kata-nemu"
|
||||||
local kata_fc_conf="crio.runtime.runtimes.kata-fc"
|
local kata_fc_conf="crio.runtime.runtimes.kata-fc"
|
||||||
|
|
||||||
|
# add kata-qemu config
|
||||||
if grep -q "^\[$kata_qemu_conf\]" $crio_conf_file; then
|
if grep -q "^\[$kata_qemu_conf\]" $crio_conf_file; then
|
||||||
echo "Configuration exists $kata_qemu_conf, overwriting"
|
echo "Configuration exists $kata_qemu_conf, overwriting"
|
||||||
sed -i "/^\[$kata_qemu_conf\]/,+1s#runtime_path.*#runtime_path = \"${kata_qemu_path}\"#" $crio_conf_file
|
sed -i "/^\[$kata_qemu_conf\]/,+1s#runtime_path.*#runtime_path = \"${kata_qemu_path}\"#" $crio_conf_file
|
||||||
@@ -78,6 +84,20 @@ function configure_crio() {
|
|||||||
EOT
|
EOT
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# add kata-nemu config
|
||||||
|
if grep -q "^\[$kata_nemu_conf\]" $crio_conf_file; then
|
||||||
|
echo "Configuration exists $kata_nemu_conf, overwriting"
|
||||||
|
sed -i "/^\[$kata_nemu_conf\]/,+1s#runtime_path.*#runtime_path = \"${kata_nemu_path}\"#" $crio_conf_file
|
||||||
|
else
|
||||||
|
cat <<EOT | tee -a "$crio_conf_file"
|
||||||
|
|
||||||
|
# Path to the Kata Containers runtime binary that uses the NEMU hypervisor.
|
||||||
|
[$kata_nemu_conf]
|
||||||
|
runtime_path = "${kata_nemu_path}"
|
||||||
|
EOT
|
||||||
|
fi
|
||||||
|
|
||||||
|
# add kata-fc config
|
||||||
if grep -q "^\[$kata_fc_conf\]" $crio_conf_file; then
|
if grep -q "^\[$kata_fc_conf\]" $crio_conf_file; then
|
||||||
echo "Configuration exists for $kata_fc_conf, overwriting"
|
echo "Configuration exists for $kata_fc_conf, overwriting"
|
||||||
sed -i "/^\[$kata_fc_conf\]/,+1s#runtime_path.*#runtime_path = \"${kata_fc_path}\"#" $crio_conf_file
|
sed -i "/^\[$kata_fc_conf\]/,+1s#runtime_path.*#runtime_path = \"${kata_fc_path}\"#" $crio_conf_file
|
||||||
@@ -114,12 +134,32 @@ function configure_containerd() {
|
|||||||
[plugins.cri.containerd]
|
[plugins.cri.containerd]
|
||||||
[plugins.cri.containerd.runtimes.kata]
|
[plugins.cri.containerd.runtimes.kata]
|
||||||
runtime_type = "io.containerd.kata.v2"
|
runtime_type = "io.containerd.kata.v2"
|
||||||
|
[plugins.cri.containerd.runtimes.kata.options]
|
||||||
|
ConfigPath = "/opt/kata/share/defaults/kata-containers/configuration.toml"
|
||||||
|
[plugins.cri.containerd.runtimes.kata-fc]
|
||||||
|
runtime_type = "io.containerd.kata-fc.v2"
|
||||||
|
[plugins.cri.containerd.runtimes.kata-fc.options]
|
||||||
|
ConfigPath = "/opt/kata/share/defaults/kata-containers/configuration-fc.toml"
|
||||||
|
[plugins.cri.containerd.runtimes.kata-qemu]
|
||||||
|
runtime_type = "io.containerd.kata-qemu.v2"
|
||||||
|
[plugins.cri.containerd.runtimes.kata-qemu.options]
|
||||||
|
ConfigPath = "/opt/kata/share/defaults/kata-containers/configuration-qemu.toml"
|
||||||
|
[plugins.cri.containerd.runtimes.kata-nemu]
|
||||||
|
runtime_type = "io.containerd.kata-nemu.v2"
|
||||||
|
[plugins.cri.containerd.runtimes.kata-nemu.options]
|
||||||
|
ConfigPath = "/opt/kata/share/defaults/kata-containers/configuration-nemu.toml"
|
||||||
EOT
|
EOT
|
||||||
|
|
||||||
|
|
||||||
#Currently containerd has an assumption on the location of the shimv2 implementation
|
#Currently containerd has an assumption on the location of the shimv2 implementation
|
||||||
#Until support is added (see https://github.com/containerd/containerd/issues/3073),
|
#Until support is added (see https://github.com/containerd/containerd/issues/3073),
|
||||||
#create a link in /usr/local/bin/ to the v2-shim implementation in /opt/kata/bin.
|
#create a link in /usr/local/bin/ to the v2-shim implementation in /opt/kata/bin.
|
||||||
|
|
||||||
|
mkdir -p /usr/local/bin
|
||||||
|
|
||||||
|
for shim in ${shims[@]}; do
|
||||||
|
local shim_binary="containerd-shim-kata-${shim}-v2"
|
||||||
|
local shim_file="/usr/local/bin/${shim_binary}"
|
||||||
|
local shim_backup="/usr/local/bin/${shim_binary}.bak"
|
||||||
|
|
||||||
if [ -f ${shim_file} ]; then
|
if [ -f ${shim_file} ]; then
|
||||||
echo "warning: ${shim_binary} already exists" >&2
|
echo "warning: ${shim_binary} already exists" >&2
|
||||||
if [ ! -f ${shim_backup} ]; then
|
if [ ! -f ${shim_backup} ]; then
|
||||||
@@ -128,15 +168,12 @@ EOT
|
|||||||
rm ${shim_file}
|
rm ${shim_file}
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
mkdir -p /usr/local/bin
|
|
||||||
|
|
||||||
cat << EOT | tee "$shim_file"
|
cat << EOT | tee "$shim_file"
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
KATA_CONF_FILE=/opt/kata/share/defaults/kata-containers/configuration.toml /opt/kata/bin/${shim_binary} \$@
|
KATA_CONF_FILE=/opt/kata/share/defaults/kata-containers/configuration-${shim}.toml /opt/kata/bin/containerd-shim-kata-v2 \$@
|
||||||
EOT
|
EOT
|
||||||
chmod +x $shim_file
|
chmod +x $shim_file
|
||||||
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
function remove_artifacts() {
|
function remove_artifacts() {
|
||||||
@@ -169,10 +206,19 @@ function cleanup_containerd() {
|
|||||||
|
|
||||||
#Currently containerd has an assumption on the location of the shimv2 implementation
|
#Currently containerd has an assumption on the location of the shimv2 implementation
|
||||||
#Until support is added (see https://github.com/containerd/containerd/issues/3073), we manage
|
#Until support is added (see https://github.com/containerd/containerd/issues/3073), we manage
|
||||||
# a symlink to the v2-shim implementation
|
# a reference to the v2-shim implementation
|
||||||
if [ -f "$shim_backup" ]; then
|
|
||||||
|
for shim in ${shims[@]}; do
|
||||||
|
local shim_binary="containerd-shim-kata-${shim}-v2"
|
||||||
|
local shim_file="/usr/local/bin/${shim_binary}"
|
||||||
|
local shim_backup="/usr/local/bin/${shim_binary}.bak"
|
||||||
|
|
||||||
|
rm ${shim_file} || true
|
||||||
|
|
||||||
|
if [ -f ${shim_backup} ]; then
|
||||||
mv "$shim_backup" "$shim_file"
|
mv "$shim_backup" "$shim_file"
|
||||||
fi
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user