[why] use the special version of sysbench test mysql required by the customer. so need to use different sysbench script.
[how] add parameters to test, and use different sysbench script.
Signed-off-by: Zhang Yu 2134782174@qq.com --- tests/sysbench-mysql | 88 ++++++++++++++++++++++++++++++++------------ 1 file changed, 65 insertions(+), 23 deletions(-)
diff --git a/tests/sysbench-mysql b/tests/sysbench-mysql index 4ab5b453..106ee0b9 100755 --- a/tests/sysbench-mysql +++ b/tests/sysbench-mysql @@ -1,52 +1,94 @@ #!/bin/sh -# mysql_user -# mysql_host -# mysql_port -# mysql_db -# db_driver # - oltp_test_mode # - oltp_tables_count # - oltp_table_size +# - max_requests +# - mysql_table_engine # - nr_threads +# - rand_type +# - rand_spec_pct # - runtime # - report_interval +# - oltp_read_only +# - events +# mysql_user +# mysql_host +# mysql_port +# mysql_db +# mysql_password +# db_driver
: "${mysql_user:=root}" -: "${mysql_host:=localhost}" -: "${mysql_port:=3306}" -: "${mysql_db:=test_1000}" +: "${mysql_host:=$direct_server_ips}" +: "${mysql_port:=$mysql_port}" +: "${mysql_db:=sysbench_1}" +: "${mysql_password:=$mysql_password}" : "${db_driver:=mysql}" -: "${oltp_tables_count:=3}" -: "${oltp_table_size:=1000}" -: "${nr_threads:=64}" -: "${runtime:=120}" -: "${report_interval:=10}" +: "${oltp_test_mode:=complex}" +: "${oltp_tables_count:=1000}" +: "${oltp_table_size:=100000}" +: "${max_requests:=0}" +: "${mysql_table_engine:=innodb}" +: "${rand_type:=special}" +: "${rand_spec_pct:=100}" +: "${nr_threads:=256}" +: "${runtime:=7200}" +: "${report_interval:=1}" +: "${oltp_read_only:=off}" +: "${events:=2000000000}"
-args=( +args1=( --mysql-user=$mysql_user --mysql-host=$mysql_host --mysql-port=$mysql_port --mysql-db=$mysql_db + --oltp-test-mode=$oltp_test_mode --db-driver=$db_driver - --tables=$oltp_tables_count - --table-size=$oltp_table_size + --mysql-password=$mysql_password + --max-requests=$max_requests + --mysql-table-engine=$mysql_table_engine + --oltp-table-size=$oltp_table_size + --oltp-tables-count=$oltp_tables_count + --rand-type=$rand_type + --rand-spec-pct=$rand_spec_pct --threads=$nr_threads --time=$runtime - --report-interval=$report_interval )
+args2=( + --mysql-user=$mysql_user + --mysql-password=$mysql_password + --mysql-host=$mysql_host + --mysql-port=$mysql_port + --mysql-db=$mysql_db + --threads=$nr_threads + --oltp-read-only=$oltp_read_only + --oltp-table-size=$oltp_table_size + --oltp-tables-count=$oltp_tables_count + --report-interval=$report_interval + --time=$runtime + --events=$events +) + +stop_firewalld() +{ + systemctl stop firewalld + iptables -F +} + run_sysbench_step() { - sysbench /usr/share/sysbench/$1 "${args[@]}" $2 + lua_script=$1 + shift + sysbench /usr/local/share/sysbench/tests/include/oltp_legacy/$lua_script "$@" }
run_sysbench_mysql() { - systemctl start mysqld - mysql -e "create database test_1000;" - run_sysbench_step oltp_common.lua prepare - run_sysbench_step oltp_read_write.lua run - run_sysbench_step oltp_common.lua cleanup + run_sysbench_step parallel_prepare.lua ${args1[@]} prepare + run_sysbench_step oltp.lua ${args2[@]} run + run_sysbench_step oltp.lua ${args2[@]} cleanup }
+stop_firewalld run_sysbench_mysql
On Tue, Nov 17, 2020 at 02:11:33PM +0800, Zhang Yu wrote:
[why] use the special version of sysbench test mysql required by the customer. so need to use different sysbench script.
[how] add parameters to test, and use different sysbench script.
Signed-off-by: Zhang Yu 2134782174@qq.com
tests/sysbench-mysql | 88 ++++++++++++++++++++++++++++++++------------ 1 file changed, 65 insertions(+), 23 deletions(-)
diff --git a/tests/sysbench-mysql b/tests/sysbench-mysql index 4ab5b453..106ee0b9 100755 --- a/tests/sysbench-mysql +++ b/tests/sysbench-mysql @@ -1,52 +1,94 @@ #!/bin/sh -# mysql_user -# mysql_host -# mysql_port -# mysql_db -# db_driver # - oltp_test_mode # - oltp_tables_count # - oltp_table_size +# - max_requests +# - mysql_table_engine # - nr_threads +# - rand_type +# - rand_spec_pct # - runtime # - report_interval +# - oltp_read_only +# - events +# mysql_user +# mysql_host +# mysql_port +# mysql_db +# mysql_password +# db_driver
please keep same style:
# db_driver => # - db_driver
Thanks, Liushaofei
: "${mysql_user:=root}" -: "${mysql_host:=localhost}" -: "${mysql_port:=3306}" -: "${mysql_db:=test_1000}" +: "${mysql_host:=$direct_server_ips}" +: "${mysql_port:=$mysql_port}" +: "${mysql_db:=sysbench_1}" +: "${mysql_password:=$mysql_password}" : "${db_driver:=mysql}" -: "${oltp_tables_count:=3}" -: "${oltp_table_size:=1000}" -: "${nr_threads:=64}" -: "${runtime:=120}" -: "${report_interval:=10}" +: "${oltp_test_mode:=complex}" +: "${oltp_tables_count:=1000}" +: "${oltp_table_size:=100000}" +: "${max_requests:=0}" +: "${mysql_table_engine:=innodb}" +: "${rand_type:=special}" +: "${rand_spec_pct:=100}" +: "${nr_threads:=256}" +: "${runtime:=7200}" +: "${report_interval:=1}" +: "${oltp_read_only:=off}" +: "${events:=2000000000}"
-args=( +args1=( --mysql-user=$mysql_user --mysql-host=$mysql_host --mysql-port=$mysql_port --mysql-db=$mysql_db
--db-driver=$db_driver--oltp-test-mode=$oltp_test_mode
--tables=$oltp_tables_count
--table-size=$oltp_table_size
--mysql-password=$mysql_password
--max-requests=$max_requests
--mysql-table-engine=$mysql_table_engine
--oltp-table-size=$oltp_table_size
--oltp-tables-count=$oltp_tables_count
--rand-type=$rand_type
--threads=$nr_threads --time=$runtime--rand-spec-pct=$rand_spec_pct
--report-interval=$report_interval
)
+args2=(
- --mysql-user=$mysql_user
- --mysql-password=$mysql_password
- --mysql-host=$mysql_host
- --mysql-port=$mysql_port
- --mysql-db=$mysql_db
- --threads=$nr_threads
- --oltp-read-only=$oltp_read_only
- --oltp-table-size=$oltp_table_size
- --oltp-tables-count=$oltp_tables_count
- --report-interval=$report_interval
- --time=$runtime
- --events=$events
+)
+stop_firewalld() +{
- systemctl stop firewalld
- iptables -F
+}
run_sysbench_step() {
- sysbench /usr/share/sysbench/$1 "${args[@]}" $2
- lua_script=$1
- shift
- sysbench /usr/local/share/sysbench/tests/include/oltp_legacy/$lua_script "$@"
}
run_sysbench_mysql() {
- systemctl start mysqld
- mysql -e "create database test_1000;"
- run_sysbench_step oltp_common.lua prepare
- run_sysbench_step oltp_read_write.lua run
- run_sysbench_step oltp_common.lua cleanup
- run_sysbench_step parallel_prepare.lua ${args1[@]} prepare
- run_sysbench_step oltp.lua ${args2[@]} run
- run_sysbench_step oltp.lua ${args2[@]} cleanup
}
+stop_firewalld run_sysbench_mysql -- 2.23.0
+# - oltp_read_only +# - events +# mysql_user +# mysql_host +# mysql_port +# mysql_db +# mysql_password +# db_driver
please keep same style:
# db_driver => # - db_driver
# - db_driver ==> this style means this paremeter's value comes from job.yaml
# db_driver ==> this style means this paremeter is needed by test, but not necessary to write in job.yaml
Thanks, Zhangyu