zoukankan      html  css  js  c++  java
  • mysql5.7.23性能调优之innodb_buffer_pool_size

     

    前言

          我的数据库版本是5.7.23,最近发现执行SQL越来越慢,一条SQL语句执行需要将近30s。

        对于原因,查询资料, https://www.cnblogs.com/qwangxiao/p/8921196.html一文中写道:

    导致SQL执行慢的原因:

    1. 硬件问题。如网络速度慢,内存不足,I/O吞吐量小,磁盘空间满了等。

    我查询内存、磁盘利用率如下:

    2. 没有索引或者索引失效。(一般在互联网公司,DBA会在半夜把表锁了,重新建立一遍索引,因为当你删除某个数据的时候,索引的树结构就不完整了。所以互联网公司的数据做的是假删除.一是为了做数据分析,二是为了不破坏索引 )

    我们所有数据都是做的假删除,索引也建了的。

    3. 数据过多(分库分表)

     数据量确实比较大,所以我们也是选择的分表。

    4. 服务器调优及各个参数设置(调整my.cnf)

    调整参数innodb_buffer_pool_size 

      以上三点,检查基本过关,那就只剩最后一点了,对应调整my.cnf的参数,我首先想到的是innodb_buffer_pool_size ,对于这个参数https://blog.csdn.net/kk185800961/article/details/79378313/一文中提到:用于缓存 索引 和 数据的内存大小, 这个当然是越多越好, 数据读写在内存中非常快, 减少了对磁盘的读写。 当数据提交或满足检查点条件后才一次性将内存数据刷新到磁盘中。然而内存还有操作系统或数据库其他进程使用, 一般设置 buffer pool 大小为总内存的  3/4 至 4/5。 

      并提出:较优设置:假设系统内存 = 128 GB, buffer pool 大小预计100GB(128GB*80%)

    innodb_buffer_pool_instances = 8                #默认值,或者逻辑CPU数量
    innodb_buffer_pool_chunk_size = 128MB    #默认值
    innodb_buffer_pool_size = 100 GB               # N*8*128MG = N GB ,N 刚好为正整数。设 N=100使得 buffer pool 为总内存的 3/4 至 4/5。


      我的服务器逻辑CPU数量为4,内存是15G。

     cat /proc/cpuinfo | grep "processor" |wc -l
    free -h

     当前innodb_buffer_pool_instances = 1,innodb_buffer_pool_chunk_size 和innodb_buffer_pool_size =134217728,也就是128M。

     

     我将上面的参数都提高4倍。

      SET GLOBAL innodb_buffer_pool_size=536870912‬;
      SET GLOBAL innodb_buffer_pool_chunk_size =536870912‬;
    SELECT
        @@innodb_buffer_pool_instances,
        @@innodb_buffer_pool_chunk_size,
        @@innodb_buffer_pool_size

    看到SQL执行快了7s

     于是我继续改配置:

     

     这时速度提升了一半。后经过反复测试,发现以下配置,速度最快,所以三个参数最终的的配置(/etc/my.cnf里)是:

    innodb_buffer_pool_size = 1280M
    innodb_buffer_pool_chunk_size= 1280M
    innodb_buffer_pool_instances=1

     

     开启独立空间参数global innodb_file_per_table

        SET global innodb_file_per_table=1;

    开启之后,快了一点点

     

     其他优化,参考:

    https://www.cnblogs.com/erisen/p/6068265.html



  • 相关阅读:
    QT 十六进制字符串转化为十六进制编码
    C语言中函数有输出参数
    QT 字符串相等间距字符间增加字符
    CRC校验算法
    QT 环境下开发socketCan接口程序
    QT 十六进制整数变为字符串自动补0 && 十进制补零
    C语言函数返回数组
    JNI文件中命名类与JAVA文件中匹配
    mini6410-JNI-led
    gis 出现问题解决办法
  • 原文地址:https://www.cnblogs.com/yybrhr/p/11445748.html
Copyright © 2011-2022 走看看