yutian88 2012-06-28 10:44
浏览 416
已采纳

MySql如何计算Key Hitrate ,Key Buffer Used, Query Cache Hitrate??请问.

我在MySQL数据库中的information_schema 库里的GLOBAL_VARIABLES. GLOBAL_STATUS表可以取出来好多数据,比如:
•key_buffer_size
•key_cache_block_size
•query_cache_limit
•query_cache_size...等等

可是我不知道怎么计算Key Hitrate ,Key Buffer Used, Query Cache Hitrate 

希望有人可以帮到我.

  • 写回答

1条回答 默认 最新

  • 爱上一条鱼 2012-06-28 11:02
    关注

    mysql> show global status like ‘qcache%‘;
    +-------------------------------+-----------------+
    | Variable_name | Value  |
    +-------------------------------+-----------------+
    | Qcache_free_blocks  | 22756  |
    | Qcache_free_memory  | 76764704 |
    | Qcache_hits      | 213028692 |
    | Qcache_inserts     | 208894227 |
    | Qcache_lowmem_prunes | 4010916 |
    | Qcache_not_cached  | 13385031 |
    | Qcache_queries_in_cache | 43560  |
    | Qcache_total_blocks | 111212  |
    +-------------------------------+-----------------+
    Qcache_inserts应该是没命中之后插入到qcache里的次数
    查询缓存命中率 = (Qcache_hits - Qcache_inserts) / Qcache_hits * 100%

    Key Buffer Used就是key buffer已使用的大小嚒。。。

    Key Hit rate就是索引的命中率么。。

    mysql> show global status like ‘key_read%‘;

    +------------------------+-------------+

    | Variable_name  | Value |

    +------------------------+-------------+

    | Key_read_requests| 27813678764 |

    | Key_reads    | 6798830 |

    +------------------------+-------------+
    一共有27813678764个索引读取请求,有6798830个请求在内存中没有找到直接从硬盘读取索引,计算索引未命中缓存的概率:

    key_cache_miss_rate = Key_reads / Key_read_requests * 100%
    hit rate应该就是1-key_cache_miss_rate 吧。。。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥16 mybatis的代理对象无法通过@Autowired装填
  • ¥15 可见光定位matlab仿真
  • ¥15 arduino 四自由度机械臂
  • ¥15 wordpress 产品图片 GIF 没法显示
  • ¥15 求三国群英传pl国战时间的修改方法
  • ¥15 matlab代码代写,需写出详细代码,代价私
  • ¥15 ROS系统搭建请教(跨境电商用途)
  • ¥15 AIC3204的示例代码有吗,想用AIC3204测量血氧,找不到相关的代码。