2019-06-17 14:47:36 +00:00
|
|
|
#!/bin/bash -x
|
|
|
|
WORK_DIR=$1
|
|
|
|
|
2019-07-30 14:33:39 +00:00
|
|
|
PLACEMENT_URL="http://127.0.0.1:8000"
|
2019-06-17 14:47:36 +00:00
|
|
|
LOG=placement-perf.txt
|
|
|
|
LOG_DEST=${WORK_DIR}/logs
|
|
|
|
# The gabbit used to create one nested provider tree. It takes
|
|
|
|
# inputs from LOADER to create a unique tree.
|
|
|
|
GABBIT=gate/gabbits/nested-perfload.yaml
|
|
|
|
LOADER=gate/perfload-nested-loader.sh
|
|
|
|
|
|
|
|
# The query to be used to get a list of allocation candidates. If
|
|
|
|
# $GABBIT is changed, this may need to change.
|
|
|
|
TRAIT="COMPUTE_VOLUME_MULTI_ATTACH"
|
2019-07-30 13:05:42 +00:00
|
|
|
TRAIT1="CUSTOM_FOO"
|
|
|
|
PLACEMENT_QUERY="resources=DISK_GB:10&required=${TRAIT}&resources_COMPUTE=VCPU:1,MEMORY_MB:256&required_COMPUTE=${TRAIT1}&resources_FPGA=FPGA:1&group_policy=none&same_subtree=_COMPUTE,_FPGA"
|
2019-06-17 14:47:36 +00:00
|
|
|
|
|
|
|
# Number of nested trees to create.
|
|
|
|
ITERATIONS=1000
|
|
|
|
|
|
|
|
# Number of times to write allocations and then time again.
|
|
|
|
ALLOCATIONS_TO_WRITE=10
|
|
|
|
|
2019-07-30 14:33:39 +00:00
|
|
|
# Apache Benchmark Concurrency
|
|
|
|
AB_CONCURRENT=10
|
|
|
|
# Apache Benchmark Total Requests
|
|
|
|
AB_COUNT=500
|
|
|
|
|
2019-06-17 14:47:36 +00:00
|
|
|
# The number of providers in each nested tree. This will need to
|
2019-07-01 11:53:09 +00:00
|
|
|
# change whenever the resource provider topology created in $GABBIT
|
|
|
|
# is changed.
|
2019-07-30 13:05:42 +00:00
|
|
|
PROVIDER_TOPOLOGY_COUNT=7
|
2019-06-17 14:47:36 +00:00
|
|
|
# Expected total number of providers, used to check that creation
|
|
|
|
# was a success.
|
|
|
|
TOTAL_PROVIDER_COUNT=$((ITERATIONS * PROVIDER_TOPOLOGY_COUNT))
|
|
|
|
|
|
|
|
trap "sudo cp -p $LOG $LOG_DEST" EXIT
|
|
|
|
|
|
|
|
function time_candidates {
|
|
|
|
(
|
|
|
|
echo "##### TIMING GET /allocation_candidates?${PLACEMENT_QUERY} twice"
|
|
|
|
time curl -s -H 'x-auth-token: admin' -H 'openstack-api-version: placement latest' "${PLACEMENT_URL}/allocation_candidates?${PLACEMENT_QUERY}" > /dev/null
|
|
|
|
time curl -s -H 'x-auth-token: admin' -H 'openstack-api-version: placement latest' "${PLACEMENT_URL}/allocation_candidates?${PLACEMENT_QUERY}" > /dev/null
|
|
|
|
) 2>&1 | tee -a $LOG
|
|
|
|
}
|
|
|
|
|
2019-07-30 14:33:39 +00:00
|
|
|
function ab_bench {
|
|
|
|
(
|
|
|
|
echo "#### Running apache benchmark"
|
|
|
|
ab -c $AB_CONCURRENT -n $AB_COUNT -H 'x-auth-token: admin' -H 'openstack-api-version: placement latest' "${PLACEMENT_URL}/allocation_candidates?${PLACEMENT_QUERY}"
|
|
|
|
) 2>&1 | tee -a $LOG
|
|
|
|
}
|
|
|
|
|
2019-06-17 14:47:36 +00:00
|
|
|
function write_allocation {
|
|
|
|
# Take the first allocation request and send it back as a well-formed allocation
|
|
|
|
curl -s -H 'x-auth-token: admin' -H 'openstack-api-version: placement latest' "${PLACEMENT_URL}/allocation_candidates?${PLACEMENT_QUERY}&limit=5" \
|
|
|
|
| jq --arg proj $(uuidgen) --arg user $(uuidgen) '.allocation_requests[0] + {consumer_generation: null, project_id: $proj, user_id: $user}' \
|
|
|
|
| curl -s -H 'x-auth-token: admin' -H 'content-type: application/json' -H 'openstack-api-version: placement latest' \
|
|
|
|
-X PUT -d @- "${PLACEMENT_URL}/allocations/$(uuidgen)"
|
|
|
|
}
|
|
|
|
|
|
|
|
function load_candidates {
|
|
|
|
time_candidates
|
|
|
|
for iter in $(seq 1 $ALLOCATIONS_TO_WRITE); do
|
|
|
|
echo "##### Writing allocation ${iter}" | tee -a $LOG
|
|
|
|
write_allocation
|
|
|
|
time_candidates
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
|
|
|
function check_placement {
|
|
|
|
local rp_count
|
|
|
|
local code
|
|
|
|
code=0
|
|
|
|
|
|
|
|
python -m virtualenv -p python3 .perfload
|
|
|
|
. .perfload/bin/activate
|
|
|
|
|
2019-07-01 11:53:09 +00:00
|
|
|
# install gabbi
|
2019-06-17 14:47:36 +00:00
|
|
|
pip install gabbi
|
|
|
|
|
|
|
|
# Create $TOTAL_PROVIDER_COUNT nested resource provider trees,
|
|
|
|
# each tree having $PROVIDER_TOPOLOGY_COUNT resource providers.
|
2019-07-30 12:46:13 +00:00
|
|
|
# LOADER is called $ITERATIONS times in parallel using 50% of
|
|
|
|
# the number of processors on the host.
|
2019-06-17 14:47:36 +00:00
|
|
|
echo "##### Creating $TOTAL_PROVIDER_COUNT providers" | tee -a $LOG
|
2019-07-30 12:46:13 +00:00
|
|
|
seq 1 $ITERATIONS | parallel -P 50% $LOADER $PLACEMENT_URL $GABBIT
|
2019-06-17 14:47:36 +00:00
|
|
|
|
|
|
|
set +x
|
|
|
|
rp_count=$(curl -H 'x-auth-token: admin' ${PLACEMENT_URL}/resource_providers |json_pp|grep -c '"name"')
|
2019-07-01 11:53:09 +00:00
|
|
|
# If we failed to create the required number of rps, skip measurements and
|
|
|
|
# log a message.
|
2019-06-17 14:47:36 +00:00
|
|
|
if [[ $rp_count -ge $TOTAL_PROVIDER_COUNT ]]; then
|
|
|
|
load_candidates
|
2019-07-30 14:33:39 +00:00
|
|
|
ab_bench
|
2019-06-17 14:47:36 +00:00
|
|
|
else
|
|
|
|
(
|
|
|
|
echo "Unable to create expected number of resource providers. Expected: ${COUNT}, Got: $rp_count"
|
2019-07-01 11:53:09 +00:00
|
|
|
echo "See job-output.txt.gz and logs/placement-api.log for additional detail."
|
2019-06-17 14:47:36 +00:00
|
|
|
) | tee -a $LOG
|
|
|
|
code=1
|
|
|
|
fi
|
|
|
|
set -x
|
|
|
|
deactivate
|
|
|
|
exit $code
|
|
|
|
}
|
|
|
|
|
|
|
|
check_placement
|