zoukankan      html  css  js  c++  java
  • mysql之innodb_buffer_pool

    mysql 重启之后,innodb_buffer_pool几乎是空的,没有任何的缓存数据。随着sql语句的执行,table中的数据以及index 逐渐被填充到buffer pool里面,之后的查询语句只需要在内存中操作(理想状态下),大幅度提升了mysql的性能。 这个逐渐填充的过程可能需要1-2个小时,甚至更久也说不准。此时使用的是 FREE链表

    然后在buffer pool 里使用 LRU 链表,通过最近最少使用算法区分热数据(yong)和冷数据(old). 其中old 默认占整个链表大小的3/8.

    可以通过innodb_old_blocks_pct 修改默认值.

    mysql> show variables like '%buffer_pool%' ;
    +-------------------------------------+----------------+
    | Variable_name | Value |
    +-------------------------------------+----------------+
    | innodb_buffer_pool_chunk_size | 134217728 |
    | innodb_buffer_pool_dump_at_shutdown | ON |
    | innodb_buffer_pool_dump_now | OFF |
    | innodb_buffer_pool_dump_pct | 25 |
    | innodb_buffer_pool_filename | ib_buffer_pool |
    | innodb_buffer_pool_instances | 1 |
    | innodb_buffer_pool_load_abort | OFF |
    | innodb_buffer_pool_load_at_startup | ON |
    | innodb_buffer_pool_load_now | OFF |
    | innodb_buffer_pool_size | 134217728 |
    +-------------------------------------+----------------+

    手工导出的话,可以用这个命令:

    mysql> SET innodb_buffer_pool_dump_now=ON;

    然后mysql会在innodb的数据目录中生成一个文件:ib_buffer_pool

    关闭mysql的时候,自动导出:

    mysql> SET innodb_buffer_pool_dump_at_shutdown=ON;

    FLUSH 链表 负责将内存中修改的数据,还没落盘的,脏数据刷入FLU链表.

  • 相关阅读:
    docker容器升级脚本
    Haproxy状态监控配置教程
    负载均衡之Haproxy配置详解(及httpd配置)
    升级代码脚本
    升级数据库脚本(加入事务)
    监控端口,新疆模拟用户登录脚本
    mongodb3.2系统性学习——3、update()操作
    Java Socket编程
    php错误级别设置
    php 用于绘图使用的颜色数组
  • 原文地址:https://www.cnblogs.com/vzhangxk/p/15390650.html
Copyright © 2011-2022 走看看