14.4.4 Configuring the Memory Allocator for InnoDB  InnoDB 配置内存分配器

当InnoDB 被开发, 内分配齐 提供了与操作系统和运行库往往缺乏在性能和可扩展性,

当时, 没有内存分配库调整对于多核CPUs.

因此,InnoDB实现它自己的内存分配器在内存子系统里,

这个分配器是有单个互斥锁保护的, 会成为一个瓶颈。

InnoDB也实现了一个封装的接口在系统分配器(malloc和free) ,同样是有一个单独的互斥锁保护

如今,随着多核系统已经变得越来越广泛,如今的操作系统变的成熟,

已经显著的改善了操作系统提供的内存分配器。

新的内存变的更好,比过去有更多的可扩展性。

高性能内存分配器 包含Hoard, libumem, mtmalloc, ptmalloc, tbbmalloc, and TCMalloc. 

大多数的负载,特别是那些频繁分配和释放(比如多表连接),收益于使用

一个更高度调优的内存分配器 相对于内部 InnoDB指定的内存分配器

你可以控制 InnoDB 是否使用它自己的内存分配器或者操作系统的内存分配器,

通过设置innodb_use_sys_malloc 

mysql> show variables like '%innodb_use_sys_malloc%';
+-----------------------+-------+
| Variable_name | Value |
+-----------------------+-------+
| innodb_use_sys_malloc | ON |
+-----------------------+-------+
1 row in set (0.00 sec) 如果设置为ON或者1(默认情况下),InnoDB 使用底层系统的malloc 和free 函数 而不是自身管理内存池。这个参数不是动态的, 只有在系统重启时生效, 继续使用InnoDB 内存分配器,设置innodb_use_sys_malloc to 0. 当InnoDB 内存分配器被禁用,InnoDB 忽略innodb_additional_mem_pool_size 参数的值。 InnoDB 内存分配使用一个额外的内存pool 用于满足分配请求不比再到系统内存分配器。 当 InnoDB memory allocator 被禁用, 所有这些分配请求通过系统内存分配满足 在类Unix 系统使用动态链接,更换内存分配器可以和设置环境变量LD_PRELOAD or LD_LIBRARY_PATH 指向动态库实现内存分配器 在其他系统上, 某些链接可能是必要的

14.4.4 Configuring the Memory Allocator for InnoDB InnoDB 配置内存分配器的更多相关文章

  1. 14.6.4 Configuring the Memory Allocator for InnoDB 配置InnoDB 内存分配器

    14.6.4 Configuring the Memory Allocator for InnoDB 配置InnoDB 内存分配器 当InnoDB 被开发时,内存分配提供了操作系统和 run-time ...

  2. 内存分配器 (Memory Allocator)

    对于大多数开发人员而言,系统的内存分配就是一个黑盒子,就是几个API的调用.有你就给我,没有我就想别的办法. 来UC前,我就是这样觉得的.实际深入进去时,才发现这个领域里也是百家争鸣.非常热闹.有操作 ...

  3. 14.6.11 Configuring Optimizer Statistics for InnoDB 配置优化统计信息用于InnoDB

    14.6.11 Configuring Optimizer Statistics for InnoDB 配置优化统计信息用于InnoDB 14.6.11.1 Configuring Persisten ...

  4. 14.6.8 Configuring the InnoDB Master Thread IO Rate 配置InnoDB 主线程IO 速率:

    14.6.8 Configuring the InnoDB Master Thread IO Rate 配置InnoDB 主线程IO 速率: 主线程 在InnoDB 是一个线程 执行各种任务在后台. ...

  5. 14.6.7 Configuring the Number of Background InnoDB IO Threads 配置InnoDB IO Threads的数量

    14.6.7 Configuring the Number of Background InnoDB IO Threads 配置InnoDB IO Threads的数量 InnoDB 使用后台线程来服 ...

  6. 14.6.6 Configuring Thread Concurrency for InnoDB 配置线程并发

    14.6.6 Configuring Thread Concurrency for InnoDB 配置线程并发 InnoDB 使用操作系统线程来处理请求(用户事务) 事务可能执行很多次在它们提交或者回 ...

  7. 14.6.5 Configuring InnoDB Change Buffering 配置InnoDB Change Buffering

    14.6.5 Configuring InnoDB Change Buffering 配置InnoDB Change Buffering 当插入,更新,和删除操作在表上执行, 索引列的值(特别是 se ...

  8. 14.6.2 Configuring InnoDB for Read-Only Operation

    14.6.2 Configuring InnoDB for Read-Only Operation 配置InnoDB只读操作 你可以查询InnoDB 表MySQL 数据目录是一个只读介质,通过启用 - ...

  9. 14.4.9 Configuring Spin Lock Polling 配置Spin lock 轮询:

    14.4.9 Configuring Spin Lock Polling 配置Spin lock 轮询: 很多InnoDB mutexes 和rw-locks 是保留一小段时间,在一个多核系统, 它可 ...

随机推荐

  1. CentOS6.5 服务器+apache5.3绑定多个域名+SELinux设置

    下面简单的介绍了如何通过设置Apache的http.conf文件,进行多个域名以及其相关的二级域名的绑定(假设我们要绑定的域名是minidx.com和ntt.cc,二级域名是blog.minidx.c ...

  2. vi编辑器使用介绍

    vi是linux下使用及其广泛的一个编辑器,虽然看上去很简单,但实际功能强大. 使用vi,核心就是熟悉它的一些命令.vi的命令非常多,但我们常用的实际就那几种. 下面将vi最核心的使用点介绍下. 一. ...

  3. TCP拥塞控制算法内核实现剖析(十)

    内核版本:3.2.12 主要源文件:linux-3.2.12/ net/ ipv4/ tcp_veno.c 主要内容:Veno的原理和实现 Author:zhangskd @ csdn blog 概要 ...

  4. poll调用深入解析

    poll调用深入解析http://blog.csdn.net/zmxiangde_88/article/details/8099049 poll调用和select调用实现的功能一样,都是网络IO利用的 ...

  5. C++能在三个地方创造对象,而Delphi只有一个地方

    C++能在堆栈.堆.资料区创造对象. 但是Delphi只能在堆上创造对象

  6. skip32

    在某些应用场景下,需要对数字进行加密,skip32无疑是一种很实用的算法,网上有python的源码(https://bitbucket.org/anuraguniyal/skip32.py/src/4 ...

  7. 大容量XFS异常处理

    今天在检查报警的时候发现部分数据异常,登陆备份机查看文件状态的时候发现磁盘空间已经满了,inode也已经有问题了,因此先停掉了所有的备份进程,开始检查问题. 首先是磁盘空间满了,尝试删除部分文件,发现 ...

  8. ARC内存使用注意事项

    官方介绍: https://developer.apple.com/library/mac/#documentation/Performance/Conceptual/ManagingMemory/M ...

  9. linux(readhat) yum源安装

    在安装測试环境的时候遇到了一个问题,/etc/yum/repos.d中不存在文件或目录,无法更新yum源. 解决方法: (一.配置网络yum源) 1.首先在/etc/yum/repos.d/文件夹下创 ...

  10. JSP的学习(7)——九大隐式对象之pageContext对象

    本篇来讲诉JSP中九大隐式对象中最后一个,也是最重要的一个对象——pageContext对象. pageContext对象代表了该JSP页面的运行环境,它的作用有: ① 这个对象封装了对其它八大隐式对 ...