首页 / MYSQL / 【MySQL参数优化】根据架构优化
【MySQL参数优化】根据架构优化
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了【MySQL参数优化】根据架构优化,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3785字,纯文字阅读大概需要6分钟。
内容图文
![【MySQL参数优化】根据架构优化](/upload/InfoBanner/zyjiaocheng/504/cb14fec9b152427ca99c38fbd2214ecd.jpg)
主要方面:内存,线程,磁盘文件,各级缓存
内存
一.通过配置缓冲池的各个方面来提高性能
buffer_pool配置
innodb_buffer_pool_size
- 默认值:128M ,一般调整为物理内存的50%-80%
- 含义:innodb缓存池大小
innodb_buffer_pool_instances
划分多个instance可以减少lru list,free list 和flush list 等的长度,减少缓存的争用,当较多数据加载到内存时, 使用多缓存实例能减少缓存争用情况,innodb_buffer_pool_size 大于 1GB 时, innodb_buffer_pool_instances 默认为 8。如有更多buffer pool, 平均每个instances 至少1GB。
innodb_buffer_pool_chunk_size
- 默认值为
128M
- 含义:动态调整buffer_pool时的块的大小。避免在调整大小操作期间复制所有缓冲池页面,操作以“ 块 ”执行 。默认情况下,
innodb_buffer_pool_chunk_size
为128MB(134217728字节)。块中包含的页数取决于的值innodb_page_size
。innodb_buffer_pool_chunk_size
可以以1MB(1048576字节)为单位增加或减少。
如果 初始化缓冲池时 innodb_buffer_pool_chunk_size* innodb_buffer_pool_instances大于当前缓冲池大小, innodb_buffer_pool_chunk_size 则截断为 innodb_buffer_pool_size/ innodb_buffer_pool_instances。
缓冲池大小必须始终等于innodb_buffer_pool_chunk_size * innodb_buffer_pool_instances的倍数。如果更改 innodb_buffer_pool_chunk_size, innodb_buffer_pool_size 则会自动舍入为等于innodb_buffer_pool_chunk_size * innodb_buffer_pool_instances的倍数。初始化缓冲池时会进行调整。
举例说明:
innodb_buffer_pool_size
设置为3G,innodb_buffer_pool_instances
设置为8。innodb_buffer_pool_chunk_size默认值为
128M。
3G是有效的innodb_buffer_pool_size值,因为3G是innodb_buffer_pool_instances = 8 * innodb_buffer_pool_chunk_size = 128M
的倍数
innodb_buffer_pool_size
设置为3G,innodb_buffer_pool_instances
设置为16. innodb_buffer_pool_chunk_size
为128M。
3G不是有效的innodb_buffer_pool_size值,因为3G不是innodb_buffer_pool_instances = 16 * innodb_buffer_pool_chunk_size = 128M
的倍数,可以看出innodb_buffer_pool_size
的值自动调整到4GB。
截断举例:
如果缓冲池初始化的大小为2GB
(2147483648字节), 4
缓冲池实例和块大小1GB
(1073741824字节),则块大小将截断为等于innodb_buffer_pool_size
/ 的值innodb_buffer_pool_instances
![【MySQL参数优化】根据架构优化 - 文章图片](/upload/getfiles/0001/2021/4/25/20210425041604367.jpg)
![【MySQL参数优化】根据架构优化 - 文章图片](/upload/getfiles/0001/2021/4/25/20210425041604394.jpg)
shell> mysqld --innodb-buffer-pool-size=2147483648 --innodb-buffer-pool-instances=4 --innodb-buffer-pool-chunk-size=1073741824; mysql> SELECT @@innodb_buffer_pool_size; +---------------------------+ | @@innodb_buffer_pool_size | +---------------------------+ | 2147483648 | +---------------------------+ mysql> SELECT @@innodb_buffer_pool_instances; +--------------------------------+ | @@innodb_buffer_pool_instances | +--------------------------------+ | 4 | +--------------------------------+ # Chunk size was set to 1GB (1073741824 bytes) on startup but was # truncated to innodb_buffer_pool_size / innodb_buffer_pool_instances mysql> SELECT @@innodb_buffer_pool_chunk_size; +---------------------------------+ | @@innodb_buffer_pool_chunk_size | +---------------------------------+ | 536870912 | +---------------------------------+View Code
注意:innodb_buffer_pool_chunk_size可以以1MB(1048576字节)为单位增加或减少,但只能在启动时,命令行字符串或MySQL配置文件中进行修改。为避免潜在的性能问题,块数(innodb_buffer_pool_size
/ innodb_buffer_pool_chunk_size
)不应超过1000。更改时应小心 innodb_buffer_pool_chunk_size
,因为更改此值可以自动增加缓冲池的大小。在更改之前 innodb_buffer_pool_chunk_size
,请计算它将产生的影响, innodb_buffer_pool_size
以确保生成的缓冲池大小可以接受
innodb_flush_method
参考值:O_DIRECT
写数据的时候绕过文件系统缓存,直接写入数据文件中
参数含义:https://www.cnblogs.com/asea123/p/10089763.html
innodb_read_ahead_threshold
【MySQL参数优化】根据架构优化
标签:man target method shel 速度 数据加载 执行 缓冲 使用
本文系统来源:https://www.cnblogs.com/asea123/p/10088452.html
内容总结
以上是互联网集市为您收集整理的【MySQL参数优化】根据架构优化全部内容,希望文章能够帮你解决【MySQL参数优化】根据架构优化所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。