Skip to content

Commit

Permalink
refactor: make tsbs more configurable (apache#805)
Browse files Browse the repository at this point in the history
* refactor: make tsbs more configurable

* feat: run tsbs after building ceresdb-server

* fix: build release ceresdb rather than slim-release for tsbs

* fix: avoid `rm -rf` in run-tsbs.sh
  • Loading branch information
ShiKaiWi authored Apr 3, 2023
1 parent 299a82f commit aa7621c
Show file tree
Hide file tree
Showing 2 changed files with 57 additions and 18 deletions.
3 changes: 3 additions & 0 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -84,3 +84,6 @@ miri:
ensure-disk-quota:
# ensure the target directory not to exceed 40GB
python3 ./scripts/clean-large-folder.py ./target 42949672960

tsbs: build
cd $(DIR); sh scripts/run-tsbs.sh
72 changes: 54 additions & 18 deletions scripts/run-tsbs.sh
Original file line number Diff line number Diff line change
@@ -1,14 +1,25 @@
#!/usr/bin/env bash

# This bash supports these settings by enviroment variables:
# - RESULT_FILE
# - DATA_FILE
# - LOG_DIR
# - CERESDB_CONFIG_FILE
# - CERESDB_ADDR

export CURR_DIR=$(pwd)
# used to create issue in https://github.com/CeresDB/tsbs/labels
export RESULT_FILE=${CURR_DIR}/tsbs/result.md
export CONFIG_FILE=${CONFIG_FILE:-docs/minimal.toml}
export LOG_DIR=${CURR_DIR}/logs
# where generated data stored
export DEFAULT_RESULT_FILE=${CURR_DIR}/tsbs/result.md
export RESULT_FILE=${RESULT_FILE:-${DEFAULT_RESULT_FILE}}
export CERESDB_CONFIG_FILE=${CERESDB_CONFIG_FILE:-docs/minimal.toml}
export LOG_DIR=${LOG_DIR:-${CURR_DIR}/logs}
export CERESDB_ADDR=${CERESDB_ADDR:-127.0.0.1:8831}
export CERESDB_PID_FILE=${CURR_DIR}/ceresdb-server.pid
# Where generated data stored
export DATA_FILE=${DATA_FILE:-data.out}
# how many values in host tag
# How many values in host tag
export HOST_NUM=${HOST_NUM:-10000}

# Used for `generate_queries.sh` start.
export TS_START="2022-09-05T00:00:00Z"
export TS_END="2022-09-05T12:00:01Z"
export EXE_FILE_NAME=${CURR_DIR}/tsbs/tsbs_generate_queries
Expand All @@ -22,18 +33,32 @@ single-groupby-1-8-1 \
single-groupby-5-1-1 \
single-groupby-5-1-12 \
single-groupby-5-8-1"
# Used for `generate_queries.sh` end.

set -x

kill_ceresdb_server() {
if [ -f ${CERESDB_PID_FILE} ]; then
pid=$(cat ${CERESDB_PID_FILE})
if kill -0 "$pid" 2>/dev/null; then
kill "$pid"
fi
fi
}

trap cleanup EXIT
cleanup() {
ls -lha ${LOG_DIR}
ls -lha ${CURR_DIR}/tsbs
ls -lha ${BULK_DATA_DIR}

kill_ceresdb_server
}

mkdir -p ${LOG_DIR}

nohup ./target/release/ceresdb-server -c ${CONFIG_FILE} > ${LOG_DIR}/server.log &
kill_ceresdb_server
nohup ./target/release/ceresdb-server -c ${CERESDB_CONFIG_FILE} > ${LOG_DIR}/server.log & echo $! > ${CERESDB_PID_FILE}

git clone -b feat-ceresdb --depth 1 --single-branch https://github.com/CeresDB/tsbs.git

Expand All @@ -43,22 +68,33 @@ go build ./cmd/tsbs_load_ceresdb
go build ./cmd/tsbs_generate_queries
go build ./cmd/tsbs_run_queries_ceresdb

# generate benchmark data
./tsbs_generate_data --use-case="cpu-only" --seed=123 --initial-scale=${HOST_NUM} --scale=${HOST_NUM} \
--timestamp-start="${TS_START}" \
--timestamp-end="${TS_END}" \
--log-interval="60s" --format="${FORMATS}" > ${DATA_FILE}
if [ ! -f ${DATA_FILE} ]; then
# Generate benchmark data if it does not exist.
./tsbs_generate_data \
--use-case="cpu-only" \
--seed=123 \
--initial-scale=${HOST_NUM} \
--scale=${HOST_NUM} \
--timestamp-start="${TS_START}" \
--timestamp-end="${TS_END}" \
--log-interval="60s" \
--format="${FORMATS}" > ${DATA_FILE}
fi


# write data to ceresdb
./tsbs_load_ceresdb --file ${DATA_FILE} | tee ${LOG_DIR}/write.log
# Write data to ceresdb
./tsbs_load_ceresdb --ceresdb-addr=${CERESDB_ADDR} --file ${DATA_FILE} | tee ${LOG_DIR}/write.log


# generate queries
# Generate queries for query
./scripts/generate_queries.sh

# run queries against ceresdb
# Note: only run 5-8-1 now
cat ${BULK_DATA_DIR}/ceresdb-single-groupby-5-8-1-queries.gz | gunzip | ./tsbs_run_queries_ceresdb | tee ${LOG_DIR}/5-8-1.log
# Run queries against ceresdb
# TODO: support more kinds of queries besides 5-8-1.
cat ${BULK_DATA_DIR}/ceresdb-single-groupby-5-8-1-queries.gz | gunzip | ./tsbs_run_queries_ceresdb --ceresdb-addr=${CERESDB_ADDR} | tee ${LOG_DIR}/5-8-1.log

# Clean the result file
rm ${RESULT_FILE}

# Output write & query result
echo '# Write' >> ${RESULT_FILE}
Expand Down

0 comments on commit aa7621c

Please sign in to comment.