Files
oceanbase/unittest/share/schema/gen_ddl_sql/ddl_resolver.sh
wangzelin.wzl 93a1074b0c patch 4.0
2022-10-24 17:57:12 +08:00

149 lines
5.4 KiB
Bash
Executable File

#!/bin/sh
SRC_DIR=`pwd`/../../../../
count=50
resolve_cost=0
ddl_cost=0
local_host="`hostname --fqdn`"
local_ip=`host $local_host 2>/dev/null | awk '{print $NF}'`
function getTiming(){
start=$1
end=$2
start_s=`echo $start | cut -d '.' -f 1`
start_ns=`echo $start | cut -d '.' -f 2`
end_s=`echo $end | cut -d '.' -f 1`
end_ns=`echo $end | cut -d '.' -f 2`
time_micro=$(( (10#$end_s-10#$start_s)*1000000 + (10#$end_ns/1000 - 10#$start_ns/1000) ))
time_ms=`expr $time_micro/1000 | bc `
#echo "$time_micro microseconds"
echo $time_ms
}
function build(){
cd $SRC_DIR/rpm
source /etc/profile
dep_create oceanbase
cd $SRC_DIR
make distclean
./build.sh init
./configure --with-release --with-coverage=no --enable-buildtime=no --enable-strip-ut=no --enable-silent-rules --enable-dlink-observer=yes || return 2
cd $SRC_DIR/src
make -j20 || return 2
cd $SRC_DIR/unittest/sql
make resolver/ddl_resolver || return 2
}
function genTestsql(){
cd $SRC_DIR/unittest/share/schema/gen_ddl_sql
rm -rf trade.sql
for ((i=1;i<=$count;i++))
do
sed "s/000/$i/" $1 >> trade.sql
done
mv -f trade.sql $SRC_DIR/unittest/sql/resolver/sql/test_resolver_trade.test
}
function genDmlTestsql(){
cd $SRC_DIR/unittest/share/schema/gen_ddl_sql
rm -rf dml.sql
cat ddl.test >> dml.sql
for ((i=1;i<=$count;i++))
do
cat dml.test >> dml.sql
done
mv -f dml.sql $SRC_DIR/unittest/sql/resolver/sql/test_resolver_dml.test
}
function testResolve(){
cd $SRC_DIR/unittest/sql/resolver
resolve_cost=`./ddl_resolver -c $1 | grep -r 'use time' | awk -F ':' '{print $2}'`
echo $resolve_cost
}
function testDDL(){
cd $SRC_DIR/tools/deploy
./copy.sh
echo -e "data_dir = '~/data'\ngcfg['_verbose_'] = False\nObCfg.init_config['trace_log_slow_query_watermark']='100ms'\nob2 = OBI(server_spec='$local_ip@zone1')" > config2.py
./deploy.py ob2.reboot
begin_time=`date +%s.%N`
./deploy.py ob2.obmysql < $SRC_DIR/unittest/sql/resolver/sql/test_resolver_trade.test
end_time=`date +%s.%N`
ddl_cost=`getTiming $begin_time $end_time`
./deploy.py ob2.force_stop
echo $ddl_cost
}
genTestsql trade10.sql
case "$1" in
build)
build
;;
resolve)
#resolve_cost=`testResolve`
testResolve trade
all_tables=`expr $count*59 | bc`
ave_time=`echo "scale=4;$resolve_cost/$all_tables" | bc`
echo -e "\033[31m ===================================== \033[0m"
echo -e "\033[31m all_tables cost_all_time ave_time \033[0m"
echo -e "\033[31m $all_tables $resolve_cost us $ave_time us \033[0m"
echo -e "\033[31m ===================================== \033[0m"
genDmlTestsql
testResolve dml
all_dml_sqls=`expr $count*591 | bc`
all_sqls=`expr $all_dml_sqls+69 | bc`
ave_time=`echo "scale=4;$resolve_cost/$all_sqls" | bc`
echo -e "\033[31m ===================================== \033[0m"
echo -e "\033[31m all_sqls cost_all_time ave_time \033[0m"
echo -e "\033[31m $all_sqls $resolve_cost us $ave_time us \033[0m"
;;
ddl)
testDDL
all_tables=`expr $count*59 | bc`
ave_time=`echo "scale=4;$ddl_cost$all_tables" | bc`
echo -e "\033[31m ===================================== \033[0m"
echo -e "\033[31m all_tables cost_all_time ave_time \033[0m"
echo -e "\033[31m $all_tables $resolve_cost ms $ave_time ms \033[0m"
echo -e "\033[31m ===================================== \033[0m"
;;
*)
build
count=600
genTestsql create.sql
all_time=`testResolve trade`
all_create_tables=`expr $count*30 | bc`
ave_create_time=`echo "scale=4;$all_time/$all_create_tables" | bc`
count=400
genTestsql trade10.sql
testResolve trade
all_tables_resolve=`expr $count*59 | bc`
ave_time_resolve=`echo "scale=4;$resolve_cost/$all_tables_resolve" | bc`
count=100
genDmlTestsql
all_dml_time=`testResolve dml`
all_dml_sqls=`expr $count*591 | bc`
all_sqls=`expr $all_dml_sqls+69 | bc`
ave_dml_time=`echo "scale=4;$all_dml_time/$all_sqls" | bc`
count=50
genTestsql trade10.sql
testDDL
all_tables_ddl=`expr $count*59 | bc`
ave_time_ddl=`echo "scale=4;$ddl_cost/$all_tables_ddl" | bc`
echo "========" `date '+%Y-%m-%d %H:%M:%S'` "=========" >> ~/result
echo "$all_create_tables $all_time us $ave_create_time us" >> ~/result
echo "$all_tables_resolve $resolve_cost us $ave_time_resolve us" >> ~/result
echo "$all_sqls $all_dml_time us $ave_dml_time us" >> ~/result
echo "$all_tables_ddl $ddl_cost ms $ave_time_ddl ms" >> ~/result
echo -e "\033[31m ===========create cost============== \033[0m"
echo -e "\033[31m all_tables cost_all_time ave_time \033[0m"
echo -e "\033[31m $all_create_tables $all_time us $ave_create_time us \033[0m"
echo -e "\033[31m ===========resolve cost============== \033[0m"
echo -e "\033[31m all_tables cost_all_time ave_time \033[0m"
echo -e "\033[31m $all_tables_resolve $resolve_cost us $ave_time_resolve us \033[0m"
echo -e "\033[31m ===================================== \033[0m"
echo -e "\033[31m ===========dml resolve cost============== \033[0m"
echo -e "\033[31m all_sqls cost_all_time ave_time \033[0m"
echo -e "\033[31m $all_sqls $all_dml_time us $ave_dml_time us \033[0m"
echo -e "\033[31m =============ddl cost================ \033[0m"
echo -e "\033[31m all_tables cost_all_time ave_time \033[0m"
echo -e "\033[31m $all_tables_ddl $ddl_cost ms $ave_time_ddl ms \033[0m"
echo -e "\033[31m ===================================== \033[0m"
;;
esac