-
Notifications
You must be signed in to change notification settings - Fork 209
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
tests: add smoke test for nydusd failover
Signed-off-by: loheagn <[email protected]>
- Loading branch information
Showing
11 changed files
with
413 additions
and
23 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
#!/bin/bash | ||
|
||
readonly SNAPSHOTTER_VERSION=0.13.3 | ||
readonly NERDCTL_VERSION=1.7.0 | ||
readonly CNI_PLUGINS_VERSION=1.3.0 | ||
|
||
# setup nerdctl and nydusd env | ||
sudo install -D -m 755 contrib/nydusify/cmd/nydusify /usr/local/bin | ||
sudo install -D -m 755 target/release/nydusd target/release/nydus-image /usr/local/bin | ||
wget https://github.com/containerd/nydus-snapshotter/releases/download/v$SNAPSHOTTER_VERSION/nydus-snapshotter-v$SNAPSHOTTER_VERSION-x86_64.tgz | ||
tar zxvf nydus-snapshotter-v$SNAPSHOTTER_VERSION-x86_64.tgz | ||
sudo install -D -m 755 nydus-snapshotter/containerd-nydus-grpc /usr/local/bin | ||
sudo wget https://github.com/containerd/nerdctl/releases/download/v$NERDCTL_VERSION/nerdctl-$NERDCTL_VERSION-linux-amd64.tar.gz | ||
sudo tar -xzvf nerdctl-$NERDCTL_VERSION-linux-amd64.tar.gz -C /usr/local/bin | ||
sudo mkdir -p /opt/cni/bin | ||
sudo wget https://github.com/containernetworking/plugins/releases/download/v$CNI_PLUGINS_VERSION/cni-plugins-linux-amd64-v$CNI_PLUGINS_VERSION.tgz | ||
sudo tar -xzvf cni-plugins-linux-amd64-v$CNI_PLUGINS_VERSION.tgz -C /opt/cni/bin | ||
sudo install -D misc/performance/containerd_config.toml /etc/containerd/config.toml | ||
sudo systemctl restart containerd | ||
sudo install -D misc/performance/nydusd_config.json /etc/nydus/nydusd-config.fusedev.json | ||
sudo install -D misc/failover/snapshotter_config.toml /etc/nydus/config.toml | ||
sudo install -D misc/performance/nydus-snapshotter.service /etc/systemd/system/nydus-snapshotter.service | ||
sudo systemctl start nydus-snapshotter |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,132 @@ | ||
version = 1 | ||
# Snapshotter's own home directory where it stores and creates necessary resources | ||
root = "/var/lib/containerd-nydus" | ||
# The snapshotter's GRPC server socket, containerd will connect to plugin on this socket | ||
address = "/run/containerd-nydus/containerd-nydus-grpc.sock" | ||
daemon_mode = "dedicated" | ||
# Whether snapshotter should try to clean up resources when it is closed | ||
cleanup_on_close = false | ||
|
||
[system] | ||
# Snapshotter's debug and trace HTTP server interface | ||
enable = true | ||
# Unix domain socket path where system controller is listening on | ||
address = "/run/containerd-nydus/system.sock" | ||
|
||
[system.debug] | ||
# Snapshotter can profile the CPU utilization of each nydusd daemon when it is being started. | ||
# This option specifies the profile duration when nydusd is downloading and uncomproessing data. | ||
daemon_cpu_profile_duration_secs = 5 | ||
# Enable by assigning an address, empty indicates pprof server is disabled | ||
pprof_address = "" | ||
|
||
[daemon] | ||
# Specify a configuration file for nydusd | ||
nydusd_config = "/etc/nydus/nydusd-config.fusedev.json" | ||
nydusd_path = "/usr/local/bin/nydusd" | ||
nydusimage_path = "/usr/local/bin/nydus-image" | ||
# fusedev or fscache | ||
fs_driver = "fusedev" | ||
# How to process when daemon dies: "none", "restart" or "failover" | ||
recover_policy = "failover" | ||
# Nydusd worker thread number to handle FUSE or fscache requests, [0-1024]. | ||
# Setting to 0 will use the default configuration of nydusd. | ||
threads_number = 4 | ||
# Log rotation size for nydusd, in unit MB(megabytes) | ||
log_rotation_size = 100 | ||
|
||
[cgroup] | ||
# Whether to use separate cgroup for nydusd. | ||
enable = true | ||
# The memory limit for nydusd cgroup, which contains all nydusd processes. | ||
# Percentage is supported as well, please ensure it is end with "%". | ||
# The default unit is bytes. Acceptable values include "209715200", "200MiB", "200Mi" and "10%". | ||
memory_limit = "" | ||
|
||
[log] | ||
# Print logs to stdout rather than logging files | ||
log_to_stdout = false | ||
# Snapshotter's log level | ||
level = "info" | ||
log_rotation_compress = true | ||
log_rotation_local_time = true | ||
# Max number of days to retain logs | ||
log_rotation_max_age = 7 | ||
log_rotation_max_backups = 5 | ||
# In unit MB(megabytes) | ||
log_rotation_max_size = 100 | ||
|
||
[metrics] | ||
# Enable by assigning an address, empty indicates metrics server is disabled | ||
address = ":9110" | ||
|
||
[remote] | ||
convert_vpc_registry = false | ||
|
||
[remote.mirrors_config] | ||
# Snapshotter will overwrite daemon's mirrors configuration | ||
# if the values loaded from this driectory are not null before starting a daemon. | ||
# Set to "" or an empty directory to disable it. | ||
#dir = "/etc/nydus/certs.d" | ||
|
||
[remote.auth] | ||
# Fetch the private registry auth by listening to K8s API server | ||
enable_kubeconfig_keychain = false | ||
# synchronize `kubernetes.io/dockerconfigjson` secret from kubernetes API server with specified kubeconfig (default `$KUBECONFIG` or `~/.kube/config`) | ||
kubeconfig_path = "" | ||
# Fetch the private registry auth as CRI image service proxy | ||
enable_cri_keychain = false | ||
# the target image service when using image proxy | ||
#image_service_address = "/run/containerd/containerd.sock" | ||
|
||
[snapshot] | ||
# Let containerd use nydus-overlayfs mount helper | ||
enable_nydus_overlayfs = false | ||
# Insert Kata Virtual Volume option to `Mount.Options` | ||
enable_kata_volume = false | ||
# Whether to remove resources when a snapshot is removed | ||
sync_remove = false | ||
|
||
[cache_manager] | ||
# Disable or enable recyclebin | ||
disable = false | ||
# How long to keep deleted files in recyclebin | ||
gc_period = "24h" | ||
# Directory to host cached files | ||
cache_dir = "" | ||
|
||
[image] | ||
public_key_file = "" | ||
validate_signature = false | ||
|
||
# The configuraions for features that are not production ready | ||
[experimental] | ||
# Whether to enable stargz support | ||
enable_stargz = false | ||
# Whether to enable referrers support | ||
# The option enables trying to fetch the Nydus image associated with the OCI image and run it. | ||
# Also see https://github.com/opencontainers/distribution-spec/blob/main/spec.md#listing-referrers | ||
enable_referrer_detect = false | ||
# Whether to enable authentication support | ||
# The option enables nydus snapshot to provide backend information to nydusd. | ||
enable_backend_source = false | ||
[experimental.tarfs] | ||
# Whether to enable nydus tarfs mode. Tarfs is supported by: | ||
# - The EROFS filesystem driver since Linux 6.4 | ||
# - Nydus Image Service release v2.3 | ||
enable_tarfs = false | ||
# Mount rafs on host by loopdev and EROFS | ||
mount_tarfs_on_host = false | ||
# Only enable nydus tarfs mode for images with `tarfs hint` label when true | ||
tarfs_hint = false | ||
# Maximum of concurrence to converting OCIv1 images to tarfs, 0 means default | ||
max_concurrent_proc = 0 | ||
# Mode to export tarfs images: | ||
# - "none" or "": do not export tarfs | ||
# - "layer_verity_only": only generate disk verity information for a layer blob | ||
# - "image_verity_only": only generate disk verity information for all blobs of an image | ||
# - "layer_block": generate a raw block disk image with tarfs for a layer | ||
# - "image_block": generate a raw block disk image with tarfs for an image | ||
# - "layer_block_with_verity": generate a raw block disk image with tarfs for a layer with dm-verity info | ||
# - "image_block_with_verity": generate a raw block disk image with tarfs for an image with dm-verity info | ||
export_mode = "" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,80 @@ | ||
// Copyright 2023 Nydus Developers. All rights reserved. | ||
// | ||
// SPDX-License-Identifier: Apache-2.0 | ||
|
||
package tests | ||
|
||
import ( | ||
"fmt" | ||
"net/http" | ||
"os" | ||
"testing" | ||
"time" | ||
|
||
"github.com/dragonflyoss/nydus/smoke/tests/tool" | ||
"github.com/dragonflyoss/nydus/smoke/tests/tool/test" | ||
"github.com/google/uuid" | ||
) | ||
|
||
// Environment Requirement: Containerd, nerdctl >= 0.22, nydus-snapshotter, nydusd. | ||
// Prepare: setup nydus for containerd, reference: https://github.com/dragonflyoss/nydus/blob/master/docs/containerd-env-setup.md. | ||
|
||
type FailoverTestSuit struct { | ||
t *testing.T | ||
} | ||
|
||
func (f *FailoverTestSuit) TestFailover(t *testing.T) { | ||
// prepare the basic constants | ||
snapshotter := os.Getenv("SNAPSHOTTER") | ||
if snapshotter == "" { | ||
snapshotter = defaultSnapshotter | ||
} | ||
sourceImage := os.Getenv("FAILOVER_TEST_IMAGE") | ||
if sourceImage == "" { | ||
sourceImage = "wordpress" | ||
} | ||
snapshotterSystemSock := os.Getenv("SNAPSHOTTER_SYSTEM_SOCK") | ||
if snapshotterSystemSock == "" { | ||
snapshotterSystemSock = defaultSnapshotterSystemSock | ||
} | ||
|
||
ctx := tool.DefaultContext(t) | ||
|
||
// prepare and convert image | ||
sourceImage = tool.PrepareImage(t, sourceImage) | ||
imageName := fmt.Sprintf("%s:nydus", sourceImage) | ||
tool.ConvertImage(t, ctx, sourceImage, imageName) | ||
|
||
containerName := uuid.NewString() | ||
tool.RunContainerSimple(t, imageName, snapshotter, containerName, false) | ||
defer tool.ClearContainer(t, imageName, snapshotter, containerName) | ||
|
||
snapshotterCli := tool.NewSnapshotterClient(snapshotterSystemSock) | ||
daemons, err := snapshotterCli.GetNydusDaemonInfos() | ||
if err != nil { | ||
t.Fatalf("Failed to get nydus daemon infos: %s", err.Error()) | ||
} | ||
|
||
// kill the nydus daemons | ||
for _, daemon := range daemons { | ||
killCmd := fmt.Sprintf("kill -9 %d", daemon.Pid) | ||
tool.Run(t, killCmd) | ||
} | ||
|
||
// wait for the nydus daemons recover | ||
time.Sleep(5 * time.Second) | ||
|
||
// check the container by requesting its wait url | ||
runArgs := tool.GetRunArgs(t, imageName) | ||
resp, err := http.Get(runArgs.WaitURL) | ||
if err != nil || !(resp.StatusCode >= 200 && resp.StatusCode < 300) { | ||
t.Fatal("Failed to access the wait url of the recoverd container") | ||
} | ||
} | ||
|
||
func TestFailover(t *testing.T) { | ||
if v, ok := os.LookupEnv("FAILOVER_TEST"); !ok || v != "true" { | ||
t.Skip("skipping failover test") | ||
} | ||
test.Run(t, &FailoverTestSuit{t: t}) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.