Skip to content

Commit ce605e9

Browse files
committed
modify optimizer test
1 parent 34bd531 commit ce605e9

File tree

5 files changed

+202
-5
lines changed

5 files changed

+202
-5
lines changed

.github/workflows/optimizer.yml

+60-3
Original file line numberDiff line numberDiff line change
@@ -16,6 +16,12 @@ on:
1616

1717
env:
1818
CARGO_TERM_COLOR: always
19+
REGISTRY: ghcr.io
20+
SNAPSHOTTER_CONFIG: /etc/nydus/config.toml
21+
SOURCE_SNAPSHOTTER_CONFIG: misc/optimizer/snapshotter-config.toml
22+
NYDUSD_CONFIG: /etc/nydus/nydusd-config.fusedev.json
23+
SOURCE_NYDUSD_CONFIG: misc/snapshotter/nydusd-config.fusedev.json
24+
SNAPSHOTTER_SYSTEMD_UNIT_SERVICE: misc/snapshotter/nydus-snapshotter.fusedev.service
1925

2026
jobs:
2127
run_optimizer:
@@ -58,6 +64,34 @@ jobs:
5864
sudo mkdir -p /opt/cni/bin
5965
sudo tar xzf cni-plugins-linux-amd64-v1.2.0.tgz -C /opt/cni/bin/
6066
sudo install -D -m 755 misc/example/10-containerd-net.conflist /etc/cni/net.d/10-containerd-net.conflist
67+
- name: Setup nydus-snapshotter and nydus service
68+
run: |
69+
GOOS=linux GOARCH=amd64 go build -o bin/containerd-nydus-grpc ./cmd/containerd-nydus-grpc
70+
sudo install -D -m 755 bin/containerd-nydus-grpc /usr/local/bin/containerd-nydus-grpc
71+
if [ ! -e "${{ env.NYDUSD_CONFIG }}" ]; then
72+
echo "Installing ${{ env.SOURCE_NYDUSD_CONFIG }} to ${{ env.NYDUSD_CONFIG }}"
73+
sudo install -D -m 664 "${{ env.SOURCE_NYDUSD_CONFIG }}" "${{ env.NYDUSD_CONFIG }}"
74+
fi
75+
if [ ! -e "${{ env.SNAPSHOTTER_CONFIG }}" ]; then
76+
echo "Installing ${{ env.SOURCE_SNAPSHOTTER_CONFIG }} to ${{ env.SNAPSHOTTER_CONFIG }}"
77+
sudo install -D -m 664 "${{ env.SOURCE_SNAPSHOTTER_CONFIG }}" "${{ env.SNAPSHOTTER_CONFIG }}"
78+
fi
79+
sudo ln -f -s /etc/nydus/nydusd-config.fusedev.json /etc/nydus/nydusd-config.json
80+
echo "Installing ${{ env.SNAPSHOTTER_SYSTEMD_UNIT_SERVICE }} to /etc/systemd/system/nydus-snapshotter.service"
81+
sudo install -D -m 644 "${{ env.SNAPSHOTTER_SYSTEMD_UNIT_SERVICE }}" /etc/systemd/system/nydus-snapshotter.service
82+
if command -v systemctl >/dev/null; then
83+
sudo systemctl enable /etc/systemd/system/nydus-snapshotter.service
84+
sudo systemctl restart nydus-snapshotter
85+
fi
86+
sleep 5
87+
NYDUS_VER=v$(curl -s "https://api.github.com/repos/dragonflyoss/nydus/releases/latest" | jq -r .tag_name | sed 's/^v//')
88+
wget https://github.com/dragonflyoss/nydus/releases/download/$NYDUS_VER/nydus-static-$NYDUS_VER-linux-amd64.tgz
89+
tar xzvf nydus-static-$NYDUS_VER-linux-amd64.tgz
90+
# sudo systemctl restart nydus-snapshotter.service
91+
sudo install -D -m 755 nydus-static/nydusd /usr/local/bin/nydusd
92+
sudo install -D -m 755 nydus-static/nydus-image /usr/local/bin/nydus-image
93+
sudo install -D -m 755 nydus-static/nydusctl /usr/local/bin/nydusctl
94+
6195
- name: Build and install optimizer
6296
run: |
6397
rustup component add rustfmt clippy
@@ -84,22 +118,45 @@ jobs:
84118
echo "containerd is not ready"
85119
exit 1
86120
fi
121+
- name: Setup prefetch-distribution http server
122+
run: |
123+
go build -o prefetch-distribution tools/prefetch-distribution/main.go
124+
nohup ./prefetch-distribution &
125+
sleep 5
126+
- name: Log in to container registry
127+
uses: docker/login-action@v2
128+
with:
129+
registry: ${{ env.REGISTRY }}
130+
username: ${{ github.actor }}
131+
password: ${{ secrets.GITHUB_TOKEN }}
132+
87133
- name: Generate accessed files list
88134
run: |
89135
sed -i "s|host_path: script|host_path: $(pwd)/misc/optimizer/script|g" misc/optimizer/nginx.yaml
90136
sudo crictl run misc/optimizer/nginx.yaml misc/optimizer/sandbox.yaml
91137
sleep 20
92138
sudo crictl rmp -f --all
139+
sudo crictl rmi --all
93140
tree /opt/nri/optimizer/results/
94-
count=$(cat /opt/nri/optimizer/results/library/nginx:1.23.3 | wc -l)
141+
count=$(cat /opt/nri/optimizer/results/dragonflyoss/image-service/nginx:nydus-latest | wc -l)
95142
expected=$(cat misc/optimizer/script/file_list.txt | wc -l)
96143
echo "count: $count expected minimum value: $expected"
97144
if [ $count -lt $expected ]; then
98-
echo "failed to generate accessed files list for nginx:1.23.3"
145+
echo "failed to generate accessed files list for nginx:nydus-latest"
99146
cat misc/optimizer/script/file_list.txt
100147
exit 1
101148
fi
102-
cat /opt/nri/optimizer/results/library/nginx:1.23.3.csv
149+
cat /opt/nri/optimizer/results/dragonflyoss/image-service/nginx:nydus-latest.csv
150+
- name: Transmit the prefetch list to nydusd
151+
run: |
152+
sed -i "s|host_path: script|host_path: $(pwd)/misc/optimizer/script|g" misc/optimizer/nginx.yaml
153+
sudo crictl run misc/optimizer/nginx.yaml misc/optimizer/sandbox.yaml
154+
if sudo ps aux | grep "[/]usr/local/bin/nydusd" | grep "prefetch-files"; then
155+
echo "Found --prefetch-files in running processes"
156+
else
157+
echo "Error: --prefetch-files not found in running processes"
158+
exit 1
159+
fi
103160
- name: Dump logs
104161
if: failure()
105162
continue-on-error: true

misc/example/optimizer-nri-plugin.conf

+1-1
Original file line numberDiff line numberDiff line change
@@ -12,4 +12,4 @@ overwrite = false
1212
# Do not change this element.
1313
events = [ "StartContainer", "StopContainer" ]
1414
# The service url of prefetch distribution.
15-
prefetch_distribution_url = "http://localhost:1323"
15+
prefetch_distribution_url = "http://localhost:1323"

misc/optimizer/containerd-config.toml

+5
Original file line numberDiff line numberDiff line change
@@ -14,6 +14,11 @@
1414

1515
version = 2
1616

17+
[plugins."io.containerd.grpc.v1.cri"]
18+
[plugins."io.containerd.grpc.v1.cri".containerd]
19+
snapshotter = "nydus"
20+
disable_snapshot_annotations = false
21+
1722
[proxy_plugins]
1823
[proxy_plugins.nydus]
1924
type = "snapshot"

misc/optimizer/nginx.yaml

+1-1
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@ metadata:
22
name: nginx
33

44
image:
5-
image: nginx:1.23.3
5+
image: ghcr.io/dragonflyoss/image-service/nginx:nydus-latest
66

77
mounts:
88
- host_path: script
+135
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,135 @@
1+
version = 1
2+
# Snapshotter's own home directory where it stores and creates necessary resources
3+
root = "/var/lib/containerd-nydus"
4+
# The snapshotter's GRPC server socket, containerd will connect to plugin on this socket
5+
address = "/run/containerd-nydus/containerd-nydus-grpc.sock"
6+
# The nydus daemon mode can be one of the following options: multiple, dedicated, shared, or none.
7+
# If `daemon_mode` option is not specified, the default value is multiple.
8+
daemon_mode = "dedicated"
9+
# Whether snapshotter should try to clean up resources when it is closed
10+
cleanup_on_close = false
11+
12+
[system]
13+
# Snapshotter's debug and trace HTTP server interface
14+
enable = true
15+
# Unix domain socket path where system controller is listening on
16+
address = "/run/containerd-nydus/system.sock"
17+
18+
[system.debug]
19+
# Snapshotter can profile the CPU utilization of each nydusd daemon when it is being started.
20+
# This option specifies the profile duration when nydusd is downloading and uncomproessing data.
21+
daemon_cpu_profile_duration_secs = 5
22+
# Enable by assigning an address, empty indicates pprof server is disabled
23+
pprof_address = ""
24+
25+
[daemon]
26+
# Specify a configuration file for nydusd
27+
nydusd_config = "/etc/nydus/nydusd-config.fusedev.json"
28+
nydusd_path = "/usr/local/bin/nydusd"
29+
nydusimage_path = "/usr/local/bin/nydus-image"
30+
# fusedev or fscache
31+
fs_driver = "fusedev"
32+
# How to process when daemon dies: "none", "restart" or "failover"
33+
recover_policy = "restart"
34+
# Nydusd worker thread number to handle FUSE or fscache requests, [0-1024].
35+
# Setting to 0 will use the default configuration of nydusd.
36+
threads_number = 4
37+
# Log rotation size for nydusd, in unit MB(megabytes). (default 100MB)
38+
log_rotation_size = 100
39+
40+
[cgroup]
41+
# Whether to use separate cgroup for nydusd.
42+
enable = true
43+
# The memory limit for nydusd cgroup, which contains all nydusd processes.
44+
# Percentage is supported as well, please ensure it is end with "%".
45+
# The default unit is bytes. Acceptable values include "209715200", "200MiB", "200Mi" and "10%".
46+
memory_limit = ""
47+
48+
[log]
49+
# Print logs to stdout rather than logging files
50+
log_to_stdout = false
51+
dir = "/etc/nydus/logs"
52+
# Snapshotter's log level
53+
level = "info"
54+
log_rotation_compress = true
55+
log_rotation_local_time = true
56+
# Max number of days to retain logs
57+
log_rotation_max_age = 7
58+
log_rotation_max_backups = 5
59+
# In unit MB(megabytes)
60+
log_rotation_max_size = 100
61+
62+
[metrics]
63+
# Enable by assigning an address, empty indicates metrics server is disabled
64+
address = ":9110"
65+
66+
[remote]
67+
convert_vpc_registry = false
68+
69+
[remote.mirrors_config]
70+
# Snapshotter will overwrite daemon's mirrors configuration
71+
# if the values loaded from this driectory are not null before starting a daemon.
72+
# Set to "" or an empty directory to disable it.
73+
#dir = "/etc/nydus/certs.d"
74+
75+
[remote.auth]
76+
# Fetch the private registry auth by listening to K8s API server
77+
enable_kubeconfig_keychain = false
78+
# synchronize `kubernetes.io/dockerconfigjson` secret from kubernetes API server with specified kubeconfig (default `$KUBECONFIG` or `~/.kube/config`)
79+
kubeconfig_path = ""
80+
# Fetch the private registry auth as CRI image service proxy
81+
enable_cri_keychain = false
82+
# the target image service when using image proxy
83+
#image_service_address = "/run/containerd/containerd.sock"
84+
85+
[snapshot]
86+
# Let containerd use nydus-overlayfs mount helper
87+
enable_nydus_overlayfs = false
88+
# Insert Kata Virtual Volume option to `Mount.Options`
89+
enable_kata_volume = false
90+
# Whether to remove resources when a snapshot is removed
91+
sync_remove = false
92+
93+
[cache_manager]
94+
# Disable or enable recyclebin
95+
disable = false
96+
# How long to keep deleted files in recyclebin
97+
gc_period = "24h"
98+
# Directory to host cached files
99+
cache_dir = ""
100+
101+
[image]
102+
public_key_file = ""
103+
validate_signature = false
104+
105+
# The configuraions for features that are not production ready
106+
[experimental]
107+
# Whether to enable stargz support
108+
enable_stargz = false
109+
# Whether to enable referrers support
110+
# The option enables trying to fetch the Nydus image associated with the OCI image and run it.
111+
# Also see https://github.com/opencontainers/distribution-spec/blob/main/spec.md#listing-referrers
112+
enable_referrer_detect = false
113+
# Whether to enable authentication support
114+
# The option enables nydus snapshot to provide backend information to nydusd.
115+
enable_backend_source = false
116+
[experimental.tarfs]
117+
# Whether to enable nydus tarfs mode. Tarfs is supported by:
118+
# - The EROFS filesystem driver since Linux 6.4
119+
# - Nydus Image Service release v2.3
120+
enable_tarfs = false
121+
# Mount rafs on host by loopdev and EROFS
122+
mount_tarfs_on_host = false
123+
# Only enable nydus tarfs mode for images with `tarfs hint` label when true
124+
tarfs_hint = false
125+
# Maximum of concurrence to converting OCIv1 images to tarfs, 0 means default
126+
max_concurrent_proc = 0
127+
# Mode to export tarfs images:
128+
# - "none" or "": do not export tarfs
129+
# - "layer_verity_only": only generate disk verity information for a layer blob
130+
# - "image_verity_only": only generate disk verity information for all blobs of an image
131+
# - "layer_block": generate a raw block disk image with tarfs for a layer
132+
# - "image_block": generate a raw block disk image with tarfs for an image
133+
# - "layer_block_with_verity": generate a raw block disk image with tarfs for a layer with dm-verity info
134+
# - "image_block_with_verity": generate a raw block disk image with tarfs for an image with dm-verity info
135+
export_mode = ""

0 commit comments

Comments
 (0)