diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-21 11:54:28 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-21 11:54:28 +0000 |
commit | e6918187568dbd01842d8d1d2c808ce16a894239 (patch) | |
tree | 64f88b554b444a49f656b6c656111a145cbbaa28 /src/script/run-cbt.sh | |
parent | Initial commit. (diff) | |
download | ceph-e6918187568dbd01842d8d1d2c808ce16a894239.tar.xz ceph-e6918187568dbd01842d8d1d2c808ce16a894239.zip |
Adding upstream version 18.2.2.upstream/18.2.2
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/script/run-cbt.sh')
-rwxr-xr-x | src/script/run-cbt.sh | 148 |
1 files changed, 148 insertions, 0 deletions
diff --git a/src/script/run-cbt.sh b/src/script/run-cbt.sh new file mode 100755 index 000000000..ad7e0ce2e --- /dev/null +++ b/src/script/run-cbt.sh @@ -0,0 +1,148 @@ +#!/bin/sh + +usage() { + prog_name=$1 + shift + cat <<EOF +usage: + $prog_name [options] <config-file>... + +options: + -a,--archive-dir directory in which the test result is stored, default to $PWD/cbt-archive + --build-dir directory where CMakeCache.txt is located, default to $PWD + --cbt directory of cbt if you have already a copy of it. ceph/cbt:master will be cloned from github if not specified + -h,--help print this help message + --source-dir the path to the top level of Ceph source tree, default to $PWD/.. + --use-existing do not setup/teardown a vstart cluster for testing + +example: + $prog_name --cbt ~/dev/cbt -a /tmp ../src/test/crimson/cbt/radosbench_4K_read.yaml +EOF +} + +prog_name=$(basename $0) +archive_dir=$PWD/cbt-archive +build_dir=$PWD +source_dir=$(dirname $PWD) +use_existing=false +classical=false +opts=$(getopt --options "a:h" --longoptions "archive-dir:,build-dir:,source-dir:,cbt:,help,use-existing,classical" --name $prog_name -- "$@") +eval set -- "$opts" + +while true; do + case "$1" in + -a|--archive-dir) + archive_dir=$2 + shift 2 + ;; + --build-dir) + build_dir=$2 + shift 2 + ;; + --source-dir) + source_dir=$2 + shift 2 + ;; + --cbt) + cbt_dir=$2 + shift 2 + ;; + --use-existing) + use_existing=true + shift + ;; + --classical) + classical=true + shift + ;; + -h|--help) + usage $prog_name + return 0 + ;; + --) + shift + break + ;; + *) + echo "unexpected argument $1" 1>&2 + return 1 + ;; + esac +done + +if test $# -gt 0; then + config_files="$@" +else + echo "$prog_name: please specify one or more .yaml files" 1>&2 + usage $prog_name + return 1 +fi + +if test -z "$cbt_dir"; then + cbt_dir=$PWD/cbt + git clone --depth 1 -b master https://github.com/ceph/cbt.git $cbt_dir +fi + +# store absolute path before changing cwd +source_dir=$(readlink -f $source_dir) +if ! $use_existing; then + cd $build_dir || exit + # seastar uses 128*8 aio in reactor for io and 10003 aio for events pooling + # for each core, if it fails to enough aio context, the seastar application + # bails out. and take other process into consideration, let's make it + # 32768 per core + max_io=$(expr 32768 \* "$(nproc)") + if test "$(/sbin/sysctl --values fs.aio-max-nr)" -lt $max_io; then + sudo /sbin/sysctl -q -w fs.aio-max-nr=$max_io + fi + if $classical; then + MDS=0 MGR=1 OSD=3 MON=1 $source_dir/src/vstart.sh -n -X \ + --without-dashboard + else + MDS=0 MGR=1 OSD=3 MON=1 $source_dir/src/vstart.sh -n -X \ + --without-dashboard --cyanstore \ + -o "memstore_device_bytes=34359738368" \ + --crimson --nodaemon --redirect-output \ + --osd-args "--memory 4G" + fi + cd - || exit +fi + +# i need to read the performance events, +# see https://www.kernel.org/doc/Documentation/sysctl/kernel.txt +if /sbin/capsh --supports=cap_sys_admin; then + perf_event_paranoid=$(/sbin/sysctl --values kernel.perf_event_paranoid) + if test $perf_event_paranoid -gt 0; then + sudo /sbin/sysctl -q -w kernel.perf_event_paranoid=0 + fi +else + echo "without cap_sys_admin, $(whoami) cannot read the perf events" +fi + +for config_file in $config_files; do + echo "testing $config_file" + cbt_config=$(mktemp $config_file.XXXX.yaml) + python3 $source_dir/src/test/crimson/cbt/t2c.py \ + --build-dir $build_dir \ + --input $config_file \ + --output $cbt_config + python3 $cbt_dir/cbt.py \ + --archive $archive_dir \ + --conf $build_dir/ceph.conf \ + $cbt_config + rm -f $cbt_config +done + +if test -n "$perf_event_paranoid"; then + # restore the setting + sudo /sbin/sysctl -q -w kernel.perf_event_paranoid=$perf_event_paranoid +fi + +if ! $use_existing; then + cd $build_dir || exit + if $classical; then + $source_dir/src/stop.sh + else + $source_dir/src/stop.sh --crimson + fi +fi |