-
antecedentes
-
premisa
-
alrededores
-
prueba
-
En modo doble 1
-
0 2 modo
- En conclusión
antecedentes
Pruebe el rendimiento de mysql5.7 y mysql8.0 en diferentes situaciones de simultaneidad en los modos lectura-escritura, solo lectura y solo escritura (tps, qps)
premisa
-
La versión de prueba es mysql5.7.22 y mysql8.0.15
-
Antes de la prueba sysbench, reinicie el servicio mysql y borre el caché del sistema operativo (para evitar golpear el caché durante múltiples pruebas)
-
Cada vez que se realiza la prueba, los nuevos datos de prueba se generan antes de la prueba de mysql5.7 y mysql8.0
-
Asegúrese de que los parámetros de configuración de mysql5.7 y mysql8.0 sean consistentes durante cada prueba
- Organizó un documento PDF MySQL de 328 páginas
alrededores
Máquina cat / etc / redhat-release | xargs echo'version '&& dmidecode -s system-product-name | xargs echo'whether virtualized' && cat / proc / cpuinfo | grep "procesador" | wc -l | xargs echo ' Número de núcleos de cpu versión CentOS Linux versión 7.5.1804 (Core) Ya sea para virtualizar el núcleo de CPU KVM número 4
myql5.7.22
5.7.22-log
innodb_buffer_pool_size 128M
innodb_log_buffer_size 64M
innodb_log_file_size 48M
binlog_format ROW
log_bin ON
transaction_isolation REPEATABLE-READ
mysql8.0.15
8.0.15
innodb_buffer_pool_size 128M
innodb_log_buffer_size 64M
innodb_log_file_size 48M
binlog_format ROW
log_bin ON
transaction_isolation REPEATABLE-READ
sysbench
sysbench -V
sysbench 1.1.0 (using bundled LuaJIT 2.1.0-beta3)
prueba
-
Rendimiento de mysql5.7 y mysql8.0 en modo lectura-escritura, modo de solo lectura y modo de solo escritura (oltp_read_write, oltp_read_only, oltp_write_only) bajo diferentes estrategias de persistencia (binlog, redo log persistence)
-
El tiempo de prueba del sysbench es de 60 segundos y el número de tablas probadas es de 20
- Las pruebas se realizaron en modo dual 1 (seguridad) y modo 0 2 (alto rendimiento)
En modo doble 1
SHOW GLOBAL VARIABLES WHERE Variable_name IN('sync_binlog','innodb_flush_log_at_trx_commit');
+--------------------------------+-------+
| Variable_name | Value |
+--------------------------------+-------+
| innodb_flush_log_at_trx_commit | 1 |
| sync_binlog | 1 |
+--------------------------------+-------+
El rendimiento de mysql5.7 y mysql8.0 en modo lectura-escritura
- Configuración doble 1, en modo lectura-escritura, el rendimiento de mysql5.7.22 y mysql8.0.15 tps y qps es casi el mismo. Cuando mysql8.0.15 tiene 120 subprocesos concurrentes, el rendimiento disminuye la fluctuación
El rendimiento de mysql5.7 y mysql8.0 en modo de solo lectura
- Configuración doble 1, en modo de solo lectura, los tps y qps de mysql5.7.22 son aproximadamente 1/3 mejores que mysql8.0.15; después de que aumenta el número de subprocesos concurrentes, tps y qps no aumentan, pero muestran una tendencia a la baja
El rendimiento de mysql5.7 y mysql8.0 en modo de solo escritura
- Configuración doble 1, en modo de solo escritura, con el aumento en el número de simultaneidad, el rendimiento de mysql5.7.22 es aproximadamente 1/4 mejor que mysql8.0.15
0 2 modo
SHOW GLOBAL VARIABLES WHERE Variable_name IN('sync_binlog','innodb_flush_log_at_trx_commit');
+--------------------------------+-------+
| Variable_name | Value |
+--------------------------------+-------+
| innodb_flush_log_at_trx_commit | 2 |
| sync_binlog | 0 |
+--------------------------------+-------+
El rendimiento de mysql5.7 y mysql8.0 en modo lectura-escritura
- 0 2, en modo lectura-escritura, cuando el número de concurrencia es bajo, el rendimiento de mysql5.7.22 es mejor que mysql8.0.15; cuando el número de concurrencia es relativamente alto, el rendimiento de mysql8.0.15 es mejor que mysql5.7.22; cuando el número de subprocesos concurrentes es superior a 80, el rendimiento comienza disminución
El rendimiento de mysql5.7 y mysql8.0 en modo de solo lectura
- 0 2, en modo de solo lectura, el rendimiento de mysql5.7.22 es aproximadamente 1/3 mejor que el de mysql8.0.15; a medida que aumenta el número de concurrentes, el rendimiento no aumenta, pero tiene una tendencia a la baja.
El rendimiento de mysql5.7 y mysql8.0 en modo de solo escritura
- 0 2 Configuración, en modo de solo escritura, el jitter tps de mysql5.7.22 es relativamente grande; el qps de mysql5.7.22 es aproximadamente 1/3 mejor que mysql8.0.15
En conclusión
-
En general, mysql5.7.22 supera a mysql8.0.15 en modo de lectura y escritura, modo de solo lectura y modo de solo escritura
-
A medida que aumenta el número de paralelos, el rendimiento no aumentará y disminuirá
- Los resultados de esta prueba se realizaron con una configuración muy baja, lo que no significa absoluta
注意 sysbench 需要 设置 --db-ps-mode = disable 禁用 预 编译 语句 , 不然 并发 测试 线程 多时 会 报 下面 的 错误 FATAL: mysql_stmt_prepare () failed FATAL: MySQL error: 1461 "No se pueden crear más declaraciones que max_prepared_stmt_count ( valor actual: 16382) "FATAL: mysql_stmt_prepare () falló FATAL: Error de MySQL: 1461" No se pueden crear más declaraciones de max_prepared_stmt_count (valor actual: 16382) "FATAL: la función thread_init 'falló: / usr / local / share / sysbench / oltp_common.lua: 288: SQL API error FATAL: mysql_stmt_prepare () falló FATAL: MySQL error: 1461 "No se pueden crear más declaraciones de max_prepared_stmt_count (valor actual: 16382)" FATAL: la función thread_init 'falló: / usr / local / share /sysbench/oltp_common.lua:288: Error de API de SQL FATAL: mysql_stmt_prepare () falló
Organizó un documento PDF MySQL de 328 páginas
Usar script
cat sysbench_test_mysql5.7_8.0_tps_qps.sh
#!/bin/bash
#用于sysbench 测试在读写模式、只读模式、只写模式下 mysql5.7和mysql8.0 的tps,qps
#nohup bash $0 >/tmp/sysbench_test 2>& 1 &
#
user=admin
passwd=admin
ports="8015 57222"
host=127.0.0.1
sysbench_test_mode="oltp_read_write oltp_read_only oltp_write_only"
sysbench_test_info_path=/tmp/sysbench-test
function red_echo () {
local what="$*"
echo -e "$(date +%F-%T) \e[1;31m ${what} \e[0m"
}
function check_las_comm(){
if [ $1 -ne 0 ];then
red_echo $2
exit 1
fi
}
function restart_mysqld(){
service mysqld${1} restart
sleep 2
}
function purge_binlog(){
port=$1
mysql -u$user -p$passwd -P$port -h$host<<EOF
purge binary logs before now();
EOF
}
function clean_os_cache(){
echo 3 > /proc/sys/vm/drop_caches
}
function sysbench_with_diff_thread(){
thread_num=$1
port=$2
order=$3
test_mode=$4
sysbench /usr/local/share/sysbench/${test_mode}.lua --mysql_storage_engine=innodb --table-size=100000 --tables=20 --mysql-db=test_1 --mysql-user=$user --mysql-password=$passwd --mysql-port=$port --mysql-host=$host --threads=$thread_num --time=60 --report-interval=2 --db-ps-mode=disable --events=0 --db-driver=mysql $order
}
function main(){
for test_mode in $sysbench_test_mode;do
for port in $ports;do
for thread_num in {5,10,20,30,40,80,120,200};do
restart_mysqld "$port"
check_las_comm "$?" "restart mysqld${port} failed "
clean_os_cache
purge_binlog "$port"
red_echo "sysbench $thread_num threads cleanup mysqld${port}"
sysbench_with_diff_thread "$thread_num" "$port" "cleanup" "$test_mode">/dev/null
red_echo "sysbench $thread_num threads prepare mysqld${port}"
sysbench_with_diff_thread "$thread_num" "$port" "prepare" "$test_mode">/dev/null
mkdir -p $sysbench_test_info_path
red_echo "sysbench $thread_num threads run mysqld${port} $test_mode"
sysbench_with_diff_thread "$thread_num" "$port" "run" "$test_mode" > $sysbench_test_info_path/${test_mode}_${thread_num}_$port
# service mysqld{port} stop
done
done
done
}
main