Skip to content
Snippets Groups Projects
storage-benchmark.sbatch 1.62 KiB
Newer Older
  • Learn to ignore specific revisions
  • #!/bin/sh
    #SBATCH -J arrh-storage-benchmark
    
    usage() {
        echo "Usage: sbatch -N <number of nodes> --cpus-per-task=<threads per node> storage-benchmark.sbatch [ stream <blocksize> | iops | meta ] <directory>"
        exit 2
    }
    
    info() {
        echo "storage-benchmark.sbatch:" "$@"
    }
    
    ##
    ## Argument handling
    ##
    
    MODE=$1
    if [ "$MODE" = stream ]
    then
        BLOCKSIZE=$2
        shift
    elif [ "$MODE" = iops ] || [ "$MODE" = meta ]
    then :
    else usage
    fi
    
    DIRECTORY=$2
    if [ -z "$DIRECTORY" ]
    then usage
    fi
    
    NNODES=$SLURM_NNODES
    THREADS=$SLURM_CPUS_PER_TASK
    HOSTS=$(scontrol show hostnames | tr '\n' ',')
    
    info "Mode: $MODE"
    if [ "$BLOCKSIZE" ]
    then info "Block size: $BLOCKSIZE"
    fi
    info "Number of nodes: $NNODES"
    info "Threads per node: $THREADS"
    elbencho --version
    
    ##
    ## The benchmark
    ##
    
    info "Starting service on all nodes"
    srun --ntasks-per-node=1 elbencho --service --foreground > /dev/null &
    sleep 5  # wait for services to start
    
    info "Starting storage benchmark"
    echo
    
    if [ "$MODE" = stream ]
    then
    
        # 1024 GiB per node
        SIZE=$((1 * 1024 * 1024 * 1024 / THREADS))
        elbencho --hosts "$HOSTS" --rotatehosts=1 -t "$THREADS" \
    	-w -r -s "$SIZE"K -b "$BLOCKSIZE" -n 0 -F "$DIRECTORY"
    
    elif [ "$MODE" = iops ]
    then
    
        # 128 GiB per node
        SIZE=$((128 * 1024 * 1024 / THREADS))
        elbencho --hosts "$HOSTS" --rotatehosts=1 -t "$THREADS" \
    	-w -r -s "$SIZE"K -b 4K -n 0 -F --rand "$DIRECTORY"
    
    elif [ "$MODE" = meta ]
    then
    
        # 10M files per node
        FILES=$((10000000 / THREADS))
        elbencho --hosts "$HOSTS" --rotatehosts=1 -t "$THREADS" \
    	-d -w --stat -F -N "$FILES" -D "$DIRECTORY"
    
    fi
    
    echo
    info "Benchmark done"
    
    elbencho --hosts "$HOSTS" --quit