暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

MYSQL内存管理及优化

原创 毛毛 2020-06-07
1518

MYSQL内存管理及优化
内存是影响数据库性能的主要资源,也是mysql性能优化的一个重要方面;

内存优化的原则
将尽量多的内存分配给mysql做缓存,但是要给操作系统和其他程序的运行预留足够的内存,否则产生swap页交换,将严重影响系统性能;
myisam的数据文件读取以来操作系统自身的io缓存,如果有myisam的表,就要预留更多的内存给操作系统做io缓存;
排序区,连接区等缓存是分配给每个数据库会话session专用的,默认值的设置要根据最大的连接数据合理分配,如果设置的太大,不但浪费内存资源,在并发比较高的时候会导致物理内存耗尽;
MyISAM内存优化
MyISAM存储引擎使用 key_buffer缓存索引块,以加速MyISAM索引的读写速度。
MyISAM表的数据库,mysql没有特别的索引机制,完全依赖系统的io 缓存。

1.ey_buffer_size 设置
key_buffer_size决定MyISAM索引缓存区的大小;一般可以内存的1/4;

2.用多个索引缓存

3.整 中点插入策略

4.整 read_buffer_size 和 read_rnd_buffer_size

innodb的内存优化
innod的缓存机制
innodb用以块内存做io缓存池,该缓存池不仅用来缓存innodb的索引,而且也用来缓存innodb的数据块;
与MyISAM是不同的;

innod的缓存机制
innodb_buffer_pool_size的设置
innodb_buffer_pool_size决定InnoDB存储引擎表数据和索引数据的最大缓存区的大小;
与oracle的缓存机制很类似。
缓存区越大,缓存的命中率越高,需要的磁盘IO越少,性能越高。
在一个专用的数据库服务器上,可以将80%的物理内存分配给innodb buffer pool ,但是一定要注意设置过大导致页交换,系统或其他的程序可以内存不足;

调整old sublist 大小
old sublist的比例有innodb_old_blocks_pct决定,默认是37;
在没有比较大的表扫描或索引扫描的情况下,如果youngs的值很低,可能需要适当的增大innodb_old_blocks_pct的值,或者减少 innodb_old_blocks_time的值。

调整innodb_old_blocks_time的设置;
这个参数决定了缓存数据块由old sublist转移到young sublit的快慢;
调整缓存池的数量,减少内部对缓存池数据结构的挣用;
mysql内部不同的线程对innodb缓存池的访问在某些阶段是互斥的,这种内部的挣用现象也会产生性能问题,尤其是在搞并发和buffer pool 比较大的情况下。
通过inndb_buffer_pool_instances参数设置

控制innodb buffer刷新,延长数据缓存时间,减缓磁盘io;

innodb doublewrite

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论