build: run perf test queries only on specific datasets (#22480)

* build: run perf test queries only on specific datasets

* fix: use new aliases to fix group window transpose
pull/22502/head
William Baker 2021-09-16 09:41:06 -06:00 committed by GitHub
parent c66a059101
commit 33afff378c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 129 additions and 124 deletions

View File

@ -177,48 +177,18 @@ force_compaction() {
# must be provided to both the data generation and query generation commands # must be provided to both the data generation and query generation commands
# and must be the same to ensure that the queries cover the data range. # and must be the same to ensure that the queries cover the data range.
start_time() { start_time() {
case $1 in # All queries and datasets can start at the same time. Certain queries and
iot|window-agg|group-agg|bare-agg) # datasets will use case-dependent end-times.
echo 2018-01-01T00:00:00Z echo 2018-01-01T00:00:00Z
;;
group-window-transpose)
cardinality=$(echo $2 | cut -d '-' -f2)
if [ "$cardinality" = "low" ]; then
echo 2018-01-01T00:00:00Z
else
echo 2019-01-01T00:00:00Z
fi
;;
metaquery)
echo 2019-01-01T00:00:00Z
;;
multi-measurement)
echo 2017-01-01T00:00:00Z
;;
*)
echo "unknown use-case: $1"
exit 1
;;
esac
} }
end_time() { end_time() {
case $1 in case $1 in
iot|window-agg|group-agg|bare-agg) iot|window-agg|group-agg|bare-agg|group-window-transpose-low-card)
echo 2018-01-01T12:00:00Z echo 2018-01-01T12:00:00Z
;; ;;
group-window-transpose) multi-measurement|metaquery|group-window-transpose-high-card)
cardinality=$(echo $2 | cut -d '-' -f2) echo 2019-01-01T00:00:00Z
if [ "$cardinality" = "low" ]; then
echo 2018-01-01T12:00:00Z
else
echo 2020-01-01T00:00:00Z
fi
;;
metaquery)
echo 2020-01-01T00:00:00Z
;;
multi-measurement)
echo 2018-01-01T00:00:00Z
;; ;;
*) *)
echo "unknown use-case: $1" echo "unknown use-case: $1"
@ -227,9 +197,94 @@ end_time() {
esac esac
} }
# Run and record tests query_types() {
case $1 in
window-agg|group-agg|bare-agg|group-window-transpose-low-card|group-window-transpose-high-card)
echo min mean max first last count sum
;;
iot)
echo fast-query-small-data standalone-filter aggregate-keep aggregate-drop sorted-pivot
;;
metaquery)
echo field-keys tag-values
;;
multi-measurement)
echo multi-measurement-or
;;
*)
echo "unknown use-case: $1"
exit 1
;;
esac
}
# Generate and ingest bulk data. Record the time spent as an ingest test. # Many of the query generator use-cases have aliases to make reporting more
# clear. This function will translate the aliased query use cases to their
# dataset use cases. Effectively this means "for this query use case, run the
# queries against this dataset use case".
query_usecase_alias() {
case $1 in
window-agg|group-agg|bare-agg|group-window-transpose|iot|group-window-transpose-low-card)
echo iot
;;
metaquery|group-window-transpose-high-card)
echo metaquery
;;
multi-measurement)
echo multi-measurement
;;
*)
echo "unknown use-case: $1"
exit 1
;;
esac
}
org_flag() {
case $1 in
flux-http)
echo -organization=$TEST_ORG
;;
http)
echo -use-compatibility=true
;;
*)
echo echo "unknown query format: $1"
exit 1
;;
esac
}
create_dbrp() {
curl -XPOST -H "Authorization: Token ${TEST_TOKEN}" \
-d "{\"org\":\"${TEST_ORG}\",\"bucketID\":\"$(bucket_id)\",\"database\":\"$db_name\",\"retention_policy\":\"autogen\"}" \
http://${NGINX_HOST}:8086/api/v2/dbrps
}
##########################
## Run and record tests ##
##########################
# Generate queries to test.
query_files=""
for usecase in window-agg group-agg bare-agg group-window-transpose-low-card group-window-transpose-high-card iot metaquery multi-measurement; do
for type in $(query_types $usecase); do
query_fname="${TEST_FORMAT}_${usecase}_${type}"
$GOPATH/bin/bulk_query_gen \
-use-case=$usecase \
-query-type=$type \
-format=influx-${TEST_FORMAT} \
-timestamp-start=$(start_time $usecase) \
-timestamp-end=$(end_time $usecase) \
-queries=$queries \
-scale-var=$scale_var > \
${DATASET_DIR}/$query_fname
query_files="$query_files $query_fname"
done
done
# Generate and ingest bulk data. Record the time spent as an ingest test if
# specified, and run the query performance tests for each dataset.
for usecase in iot metaquery multi-measurement; do for usecase in iot metaquery multi-measurement; do
data_fname="influx-bulk-records-usecase-$usecase" data_fname="influx-bulk-records-usecase-$usecase"
$GOPATH/bin/bulk_data_gen \ $GOPATH/bin/bulk_data_gen \
@ -253,78 +308,24 @@ for usecase in iot metaquery multi-measurement; do
$GOPATH/bin/bulk_load_influx $load_opts | \ $GOPATH/bin/bulk_load_influx $load_opts | \
jq ". += {branch: \"$INFLUXDB_VERSION\", commit: \"$TEST_COMMIT\", time: \"$datestring\", i_type: \"$DATA_I_TYPE\", use_case: \"$usecase\"}" > ${out} jq ". += {branch: \"$INFLUXDB_VERSION\", commit: \"$TEST_COMMIT\", time: \"$datestring\", i_type: \"$DATA_I_TYPE\", use_case: \"$usecase\"}" > ${out}
# Cleanup # Cleanup from the data generation and loading.
force_compaction force_compaction
rm ${DATASET_DIR}/$data_fname rm ${DATASET_DIR}/$data_fname
done
query_types() { # Generate a DBRP mapping for use by InfluxQL queries.
case $1 in create_dbrp
window-agg|group-agg|bare-agg)
echo min mean max first last count sum
;;
group-window-transpose)
echo min-high-card mean-high-card max-high-card first-high-card last-high-card count-high-card sum-high-card min-low-card mean-low-card max-low-card first-low-card last-low-card count-low-card sum-low-card
;;
iot)
echo fast-query-small-data standalone-filter aggregate-keep aggregate-drop sorted-pivot
;;
metaquery)
echo field-keys tag-values
;;
multi-measurement)
echo multi-measurement-or
;;
*)
echo "unknown use-case: $1"
exit 1
;;
esac
}
# Generate queries to test. # Run the query tests applicable to this dataset.
query_files="" for query_file in $query_files; do
for usecase in window-agg group-agg bare-agg group-window-transpose iot metaquery multi-measurement; do
for type in $(query_types $usecase); do
query_fname="${TEST_FORMAT}_${usecase}_${type}"
$GOPATH/bin/bulk_query_gen \
-use-case=$usecase \
-query-type=$type \
-format=influx-${TEST_FORMAT} \
-timestamp-start=$(start_time $usecase $type) \
-timestamp-end=$(end_time $usecase $type) \
-queries=$queries \
-scale-var=$scale_var > \
${DATASET_DIR}/$query_fname
query_files="$query_files $query_fname"
done
done
org_flag() {
case $1 in
flux-http)
echo -organization=$TEST_ORG
;;
http)
echo -use-compatibility=true
;;
*)
echo echo "unknown query format: $1"
exit 1
;;
esac
}
# Generate a DBRP mapping for use by InfluxQL queries.
curl -XPOST -H "Authorization: Token ${TEST_TOKEN}" \
-d "{\"org\":\"${TEST_ORG}\",\"bucketID\":\"$(bucket_id)\",\"database\":\"$db_name\",\"retention_policy\":\"autogen\"}" \
http://${NGINX_HOST}:8086/api/v2/dbrps
# Run the query benchmarks
for query_file in $query_files; do
format=$(echo $query_file | cut -d '_' -f1) format=$(echo $query_file | cut -d '_' -f1)
usecase=$(echo $query_file | cut -d '_' -f2) query_usecase=$(echo $query_file | cut -d '_' -f2)
type=$(echo $query_file | cut -d '_' -f3) type=$(echo $query_file | cut -d '_' -f3)
# Only run the query tests for queries applicable to this dataset.
if [ "$usecase" != "$(query_usecase_alias $query_usecase)" ]; then
continue
fi
${GOPATH}/bin/query_benchmarker_influxdb \ ${GOPATH}/bin/query_benchmarker_influxdb \
-file=${DATASET_DIR}/$query_file \ -file=${DATASET_DIR}/$query_file \
-urls=http://${NGINX_HOST}:8086 \ -urls=http://${NGINX_HOST}:8086 \
@ -337,13 +338,17 @@ for query_file in $query_files; do
-benchmark-duration=$duration | \ -benchmark-duration=$duration | \
jq '."all queries"' | \ jq '."all queries"' | \
jq -s '.[-1]' | \ jq -s '.[-1]' | \
jq ". += {use_case: \"$usecase\", query_type: \"$type\", branch: \"$INFLUXDB_VERSION\", commit: \"$TEST_COMMIT\", time: \"$datestring\", i_type: \"$DATA_I_TYPE\", query_format: \"$format\"}" > \ jq ". += {use_case: \"$query_usecase\", query_type: \"$type\", branch: \"$INFLUXDB_VERSION\", commit: \"$TEST_COMMIT\", time: \"$datestring\", i_type: \"$DATA_I_TYPE\", query_format: \"$format\"}" > \
$working_dir/test-query-$format-$usecase-$type.json $working_dir/test-query-$format-$query_usecase-$type.json
# restart daemon # Restart daemon between query tests.
systemctl stop influxdb systemctl stop influxdb
systemctl unmask influxdb.service systemctl unmask influxdb.service
systemctl start influxdb systemctl start influxdb
done
# Delete DB to start anew.
curl -X DELETE -H "Authorization: Token ${TEST_TOKEN}" http://${NGINX_HOST}:8086/api/v2/buckets/$(bucket_id)
done done
echo "Using Telegraph to report results from the following files:" echo "Using Telegraph to report results from the following files:"