在innodb引擎中,内存的组成主要有三部分:缓冲池(buffer pool),重做日志缓存(redo log buffer),额外的内存池(additional memory pool)。

【参数1:innodb_buffer_pool_size】

主要用来缓存innodb表的索引、数据,是插入数据时的缓冲。

/*Innodb存储引擎的缓存机制和Myisam最大的区别就在于他不紧可以缓存索引,还会缓存实际的数据。所以相同的物理环境,Innodb对磁盘IO的优化会优于Myisam。*/

当系统上线后,我们可以通过Buffer Pool实时状态,来做进一步的分析:

从这里我们能看出Read命中的情况:

Read命中率=(Innodb_buffer_pool_read_requests-Innodb_buffer_pool_reads)/Innodb_buffer_pool_read_requests

配图是默认的情况,根据公式就是(该db很空闲,但参考机器性能,及mysql手册推荐值,仍可对该参数进行调整。)

Innodb_buffer_pool_reads的数值统计是通过物理读来获取的数据。

Innodb_buffer_pool_pages_free这个数值需要关注,空闲页的大小。

Innodb_buffer_pool_pages_flushed刷新页请求数量。

Innodb_buffer_pool_read_ahead预读入缓存的页数量。

Innodb_buffer_pool_wait_free等待空闲页的次数(关注)。

/*当用户需要读取一个页面,或者请求分配一个新页面进行插入,需要调用buf0flu.cc工程中的buf_LRU_get_free_block函数进行页面的分配。

首先尝试从buffer pool中的free list分配新页面,若free list中没有空闲页,同时当前系统正在进行flush,等待flush结束后进行分配;若free list中没有空闲页,不在flush,遍历LRU链表,寻找非脏页面置换到free list,然后刷新Innodb引擎统计,实现pages的释放。*/

innodb_buffer_pool_size

Innodb_buffer_pool_size默认为128M,若该物理机为mysql服务器,若使用的引擎只有innodb,可以考虑配置为物理内存的50%-70%。

在mysql的conf中进行修改

# vim /etc/my.cnf.d/server.cnf

innodb_buffer_pool_size=80G

这个值如果调整过大,带来的IO性能上的优化将不会很明显,反而会造成cpu的压力过高。

【参数2:Innodb_buffer_pool_instances】

Innodb_buffer_pool_instances将Innodb_buffer_pool划分到不同的instance中,每个instance独立进行LRU Flush,有独立的mutex控制会避免内存锁的争用(大的并发状态下优化效果明显)。

/*注:与Innodb_buffer_pool_size参数相结合,每个instance的size确保不小于1G。一般设置也参考cpu个数(小于或等于cpu个数即可)。*/

【参数3:Innodb_additional_mem_pool_size】

这个参数用来设置Innodb存储的数据的目录信息和其他内部数据结构的内存池。

/*一般来讲,应用程序常用的业务表越多,这里配的内存就应该越大,对于稳定的程序,这个参数的大小是稳定的,可以关注错误日志来进行调整。从mysql 5.6.3开始,不再需要这个参数了。

(错误日志[Warning] option 'innodb_additional_mem_pool_size': signed value 512000 adjusted to 524288)。*/

在示例中走的是默认配置,默认配置是8M。

Mysql手册中对于2G内存时推荐设置为20M。一般,设置过大会造成物理内存浪费,可以在上线一段时间内密切关注日志,进行参数调整。

在db中进行调整,调整为20M。

Galera集群server.cnf参数调整--Innodb存储引擎内存相关参数(一)的更多相关文章

  1. Galera集群server.cnf参数调整--前言

    文档安排: 前言部分会简述下galera集群,正文中会针对我们线上的环境,在不断业务的情况下,进行参数调整的话,有些参数不能够进行配置,会以#***的形式写入配置文件中,文档也会进行进一步说明. 如果 ...

  2. mysql innodb存储引擎和一些参数优化

    mysql 的innodb存储引擎是事务性引擎,支持acid.innodb支持版本控制和高并发的技术是svcc:需要重点注意:myisam只缓存索引,innodb缓存索引和数据:

  3. InnoDB存储引擎内存缓冲池管理技术——LRU List、Free List、Flush List

    InnoDB是事务安全的MySQL存储引擎,野山谷OLTP应用中核心表的首选存储引擎.他是基于表的存储引擎,而不是基于数据库的.其特点是行锁设计.支持MVCC.支持外键.提供一致性非锁定读,同时被设计 ...

  4. 《MySQL技术内幕:InnoDB存储引擎(第2版)》书摘

    MySQL技术内幕:InnoDB存储引擎(第2版) 姜承尧 第1章 MySQL体系结构和存储引擎 >> 在上述例子中使用了mysqld_safe命令来启动数据库,当然启动MySQL实例的方 ...

  5. Mysql技术内幕——InnoDB存储引擎

    Mysql技术内幕——InnoDB存储引擎 http://jingyan.baidu.com/article/fedf07377c493f35ac89770c.html 一.mysql体系结构和存储引 ...

  6. MySQL InnoDB 存储引擎探秘

    在MySQL中InnoDB属于存储引擎层,并以插件的形式集成在数据库中.从MySQL5.5.8开始,InnoDB成为其默认的存储引擎.InnoDB存储引擎支持事务.其设计目标主要是面向OLTP的应用, ...

  7. 《MySQL技术内幕:InnoDB存储引擎》读书笔记

    一.Mysql体系结构和存储引擎 1. 概念:              数据库:物理操作系统文件或其他形式文件类型的集合.(是文件的集合,是依照某种数据模型组织起来并存放于二级存储器中的数据集合.) ...

  8. 【3.4】innodb存储引擎

    [1]Innodb 与 Myisam 的区别 1.InnoDB支持事物,而MyISAM不支持事物 2.InnoDB支持行级锁,而MyISAM支持表级锁 3.InnoDB支持MVCC, 而MyISAM不 ...

  9. 0728MySQL数据库InnoDB存储引擎重做日志漫游REDOLOG,UNDOLOG

    转自http://www.mysqlops.com/2012/04/06/innodb-log1.html 00 – Undo LogUndo Log 是为了实现事务的原子性,在MySQL数据库Inn ...

随机推荐

  1. ES数据-MySql处理Date类型的数据导入处理

    用ES的小伙伴们,相信大家都遇到过Mapping处理Date类型的数据头疼问题吧. 不用头疼了,我来给你提供一种解决方案: 1.Maping定义为: {  "mappings": ...

  2. OC-内存管理

    解铃还须系铃人 --1--内存管理的原理及分类 1.1 内存管理的原理 1.2 内存管理的分类 --2--手动内存管理 2.1 关闭ARC的方法 2.2 手动管理(MRC)快速入门 --3-- 内存管 ...

  3. 【转】解决eclipse新导入工程无法run as server

    转载地址:http://blog.csdn.net/huang86411/article/details/12118309 问题描述: 从SVN或者别处搞过来的web项目,利用eclipse工具,新建 ...

  4. scoi 2008 && bzoj 1076 奖励关

    传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=3223 思路:15?好,状压,OK. 这是转移方程 if((s[k]&j)==s[k] ...

  5. 移动APP项目优化

    团队计划:设计一款给用户提供就医帮助的安卓APP. 项目计划:两个月内团队成员共同开发完成此款APP,此款APP提供预约挂号,名医名院咨询,就医导航等功能. 角色职责:负责交互设计.UI界面设计.1. ...

  6. Mybatis Generator生成工具配置文件详解

    <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE generatorConfiguration ...

  7. javascript 组合

    1. 大数组中有m个元素,抽取其中的n个进行组合. var combination = function(arr, num){ var r=[]; (function f(t,a,n) { ) { r ...

  8. TortoiseSVN客户端重新设置用户名和密码

    TortoiseSVN客户端重新设置用户名和密码 在第一次使用TortoiseSVN从服务器CheckOut的时候,会要求输入用户名和密码,这时输入框下面有个选项是保存认证信息,如果选了这个选项,那么 ...

  9. QLPreViewController的初步实用

    前一阵项目需要添加一个文档文件的查看功能,于是就各种找资料,一开始想实用webView,然而webView有的格式不支持,而且占内存太大了.找着找着就找到QLPreViewController.用了一 ...

  10. Arduino入门笔记【1】

    刚刚接触这个东西只知道这是类似于单片机的开发板,可以做一些单片机实现或者不能实现的东西,但是比单片机要简单得多. Arduino到底是什么? 维基百科上的描述是:Arduino是一块开发板的微控制器和 ...