149 lines
5.4 KiB
Bash
Executable File
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
|