MySQL 5.7 vs 8.0, ¿cuál tiene mejor rendimiento? ¡Los internautas son ruidosos!

  • 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)

MySQL 5.7 vs 8.0, ¿cuál tiene mejor rendimiento?  ¡Los internautas son ruidosos!

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

MySQL 5.7 vs 8.0, ¿cuál tiene mejor rendimiento?  ¡Los internautas son ruidosos!

  • 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

MySQL 5.7 vs 8.0, ¿cuál tiene mejor rendimiento?  ¡Los internautas son ruidosos!

  • 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

MySQL 5.7 vs 8.0, ¿cuál tiene mejor rendimiento?  ¡Los internautas son ruidosos!

  • 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

MySQL 5.7 vs 8.0, ¿cuál tiene mejor rendimiento?  ¡Los internautas son ruidosos!

  • 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

MySQL 5.7 vs 8.0, ¿cuál tiene mejor rendimiento?  ¡Los internautas son ruidosos!

  • 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

MySQL 5.7 vs 8.0, ¿cuál tiene mejor rendimiento?  ¡Los internautas son ruidosos!

  • 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

Supongo que te gusta

Origin blog.51cto.com/14975073/2596527
Recomendado
Clasificación