文档章节

InnoDB优化

枯藤KT
 枯藤KT
发布于 2015/05/29 02:29
字数 1638
阅读 13
收藏 1

原文地址

 InnoDB主索引是聚簇索引,索引与数据共用表空间,对于InnoDB而言,数据就是索引,索引就是数据。InnoDB缓存机制和MyISAM缓存机 制的最大区别就是在于,InnoDB不仅仅是缓存索引,还会是缓存数据。与MyISAM相比,InnoDB缓存可以占用更多的服务器内存缓存InnoDB 表的相关信息,提升InnoDB性能。
   1、InnoDB缓存池
      InnoDB缓存池(InnoDB  buffer pool)是InnoDB性能提升的核心,它既可以缓存数据还可以缓存索引,甚至其他管理数据(例如元数据信息,行级锁信息)。使用MySQL命 令”show variables like 'innodb%pool%';“可以查看InnoDB缓存池的相关参数信息。
    

  • InnoDB_buffer_pool_size: 用于设置InnoDB缓存池(InnoDB_buffer_pool)的大小,默认值是47MB。InnoDB缓存池的大小对InnoDB整体性能影响较 大,如果当前的MySQL服务器专门用于提供MySQL服务,应尽量增加InnoDB_buffer_pool_size的大小,把频繁访问的数据都放到 内存中来,尽可能减少InnoDB对硬盘的访问,争取将InnoDB最大化成为一个内存型存储索引的访问,争取将InnoDB最大化成为一个内存存储引 擎。

  • InnoDB_buffer_pool_instances:默认值是1,表示 InnoDB缓存池被划分到一个区域。适当地增加该参数(例如将该参数值设置为2),此时InnoDB被划分成为两个区域,可以提升InnoDB的并发性 能。如果InnoDB缓存池被划分成多个区域,建议每个区域不小于1GB的空间。

  • InnoDB_additional_mem_pool_size:指定 InnoDB用来存储数据字典和其他内部数据结构的缓存大小,默认值是2MB。InnoDB表的个数越多,该参数的值就应该设置得越大;当InnoDB用 完缓存空间时,InnoDB就会操作系统申请内存空间,并向错误日志写入一条警告信息。

   2、InnoDB缓存池内部结构
       InnoDB在内存中维护一个缓存池用于缓存数据和索引。缓存池可以被认为一条长LRU链表,该链表又分为2个子链表,一个子链表存放old pages(里面存放的是长时间未被访问的数据页),另一个子链接存放new pages(里面存放的是最近被访问的数据页面)。old pages 默认占整个列表大小的37%(InnoDB_old_blocks_pct参数的默认值为37,取值范围是5~95),其余为new pages占用,如图下图所示。靠近LRU链表头部的数据页表示最近被访问,靠近LRU链表尾部的数据页表示长时间未被访问,而这两个部分交汇处成为 midpoint。

      当用户需要访问数据时,InnoDB首先会在InnoDB缓冲池查找数据,如果缓冲池中没有数据时,InnoDB会将硬盘上的数据块插入到InnoDB缓 存池中;如果InnoDB缓冲池已满,InnoDB通过LRU算法清楚InnoDB缓存池中个别数据块。每当有新数据块需要加载到InnoDB缓冲池中 时,该数据块应变为‘‘数据页’’被插到midpoint的位置,并声明为old数据页。那么old数据页什么时候能移动到new Page链表中呢?
 (1)当InnoDB_old_blocks_time的参数值设置为0时。当old部分的数据页被访问到时,该数据页会被提升到链表的头部,并被标记为new数据页。
 (2)当InnoDB_old_blocks_time的参数值大于0时(以1000毫秒或者1秒为例)。old部分数据页插入缓冲池后,1秒之后被访 问,该数据页会被提升到链表的头部,并被标记为new数据页。在刚插入到一秒内,即便old部分的数据页被访问,该数据页也不会移动到new链表的头部。
 
   使用MySQL命令“show variables like 'innodb_old%';可以查看InnoDB缓冲池结构的参数信息。

  • innodb_old_blocks_pct:控制old page子链表在LRU链表中的长度。

  • innodb_old_blocks_time:控制old page子链表的数据页移动到new page 子链表中的时机。

    InnoDB缓存池预热

   MySQL服务启动一段时间后,InnoDB会将经常访问的数据(包括业务数据,管理数据)置入InnoDB缓冲池中,即InnoDB缓冲池保存的是频 繁访问的数据(简称热数据)。当InnoDB缓冲池的大小是几十GB甚至是几百GB时,由于某些原因(例如数据库定期维护)重启MySQL服务,如何将之 前InnoDB缓冲池中的热数据重新加载到InnoDB缓冲池中?简单地说:如何对InnoDB缓冲池进行预热,以便于MySQL服务器快速地恢复到重启 MySQL服务之前的性能状态?
  如果单靠InnoDB自身预热InnoDB缓冲池,将会是一个不短的时间周期,业务高峰时,MySQL服务器将面临着巨大考验。在MySQL5.5以及之 前的版本中,当停止MySQL服务时,所有存储在InnoDB缓冲池中的热数据将被全部清空。从5.6版本开始,MySQL支持关闭MySQL服务时将内 存中的热数据保存到硬盘,MySQL重启后首先将硬盘中的如数据加载到InnoDB缓冲池中,以便缩短warmup进程的时间,提高业务繁忙高并发时的效 率。使用MySQL命令”show variables like ‘%innodb%pool%';''可以查看有关InnoDB缓冲池预热功能参数设置。


  • innodb_buffer_dump_at_shutdown:默认为关闭OFF。如果开启该参数,停止MySQL服务时,InnoDB将InnoDB缓冲池中的热数据保存到本地硬盘。

  • innodb_buffer_pool_load_at_startup:默认为关闭OFF。如果开启该参数,启动MySQL服务时,MySQL将本地热数据加载到InnoDB缓冲池中。

  • innodb_buffer_pool_load_now:默认为关闭OFF。如果开启该参数,停止MySQL服务时,以手动方式将InnoDB缓存池中的热数据保存到本地硬盘。

  • innodb_buffer_pool_filename:如果开启InnoDB预热功能,停止MySQL服务时,MySQL将InnoDB缓冲池中的热数据保存到数据库根目录中,默认文件名为ib_buffer_pool.

  • innodb_buffer_pool_load_aborr:默认为关闭OFF。如果开启该参数,即便开启InnoDB预热功能,启动MySQL服务室,MySQL也不会将本地硬盘的热数据加载到InnoDB缓冲池中。

    开启InnoDB缓冲池预热后,使用MySQL命令''show variables like 'Innodb_buffer%’;''可以查看InnoDB缓冲池预热的状态信息。


本文转载自:

共有 人打赏支持
枯藤KT

枯藤KT

粉丝 4
博文 101
码字总数 61046
作品 0
昌平
程序员
私信 提问
MySQL 8.0 首个自适应参数横空出世

|什么是自适应参数 MySQL8.0推出一个号称可以自适应服务器的参数,保证在各种不同的服务器、虚拟机、容器下自动适配服务器资源,让我们一起来看看到底它能做到什么地步。 |自适应参数是如何...

数据浮云
06/28
0
0
MySQL Innodb 存储引擎参数优化

介绍: InnoDB给MySQL提供了具有提交,回滚和崩溃恢复能力的事务安全(ACID兼容)存储引擎。InnoDB锁定在行级并且也在SELECT语句提供一个Oracle风格一致的非锁定读。这些特色增加了多用户部署...

山哥
2011/11/16
0
0
我们需要MySQL5.0拥有5.4的性能吗?

带有Innodb 引擎的MySQL 5.4 看起来要比MySQL5.0的性能好很多-这是由于这个版本来自google集成的locking 和 IO Patchs(类似Percona patches),一些特别的修善比如不同的innodb_thread_con...

老枪
2009/05/03
1K
0
MySQL数据库优化思路之配置文件优化

mysql配置文件官方地址如下:https://dev.mysql.com/doc/refman/5.6/en/option-files.html mysql读取配置文件的先后顺序如下: File Name Purpose Global options Global options Global opt......

zyx870805
05/03
0
0
MySQL衍生版 Percona Server 5.5.8 Beta

Percona Server 发布了 5.5.8-20.0 版本,这是对 MySQL 5.5.8 正式版的第一个增强版本,主要亮点有: 通过对服务器和存储引擎的改善提升了性能和可伸缩性 优化闪存存储,例如 SSD, Virident,...

红薯
2011/02/17
1K
1

没有更多内容

加载失败,请刷新页面

加载更多

oh-my-zsh 自定义

GitHub 地址 基于 oh-my-zsh 的自定义配置,增加了一些个人常用插件与皮肤。 采用的是 git submodule 来维护,包括 oh-my-zsh,之所以这么搞,主要是手头有多台 linux 需要维护, 每台机器、...

郁也风
今天
6
0
Docker安装踩坑:E_FAIL 0x80004005的解决

参考 菜鸟教程--Windows Docker 安装 http://www.runoob.com/docker/windows-docker-install.html 官方文档-Install Docker Toolbox on Windows https://docs.docker.com/toolbox/toolbox_in......

karma123
今天
5
0
js垃圾回收机制和引起内存泄漏的操作

JS的垃圾回收机制了解吗? Js具有自动垃圾回收机制。垃圾收集器会按照固定的时间间隔周期性的执行。 JS中最常见的垃圾回收方式是标记清除。 工作原理:是当变量进入环境时,将这个变量标记为“...

Jack088
昨天
17
0
大数据教程(10.1)倒排索引建立

前面博主介绍了sql中join功能的大数据实现,本节将继续为小伙伴们分享倒排索引的建立。 一、需求 在很多项目中,我们需要对我们的文档建立索引(如:论坛帖子);我们需要记录某个词在各个文...

em_aaron
昨天
27
0
"errcode": 41001, "errmsg": "access_token missing hint: [w.ILza05728877!]"

Postman获取微信小程序码的时候报错, errcode: 41001, errmsg: access_token missing hint 查看小程序开发api指南,原来access_token是直接当作parameter的(写在url之后),scene参数一定要...

两广总督bogang
昨天
33
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部