iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >mysql内存相关的配置
  • 532
分享到

mysql内存相关的配置

mysql数据库 2023-09-10 18:09:30 532人浏览 八月长安
摘要

一、Mysql为每个链接分配的和内存 以下四个参数是为每个链接(线程)分配的大小。(一百个链接,可能会分配一百次) 1、sort_buffer_size: 排序缓冲区的大小。不管需要多少,都是一次性分配该参数值大小的内存。 max_leng

一、Mysql为每个链接分配的和内存

以下四个参数是为每个链接(线程)分配的大小。(一百个链接,可能会分配一百次)

1、sort_buffer_size:

排序缓冲区的大小。不管需要多少,都是一次性分配该参数值大小的内存。

  • max_length_for_sort_data: 用于指定排序数据的最大长度,根据需要排序的字段定义的大小总和与这个配置值进行比较。
2、join_buffer_size:

连接查询缓冲区的大小,默认值是256k。为每个连接查询分配该参数值大小的内存。

  • 较大的 join_buffer_size 可以容纳更多行,减少对被驱动表的全表扫描次数。
3、read_buffer_size:

MyISAM 表进行全表扫描时分配的查询缓冲区大小。有查询需要时分配一次性参数值大小的内存;参数值大小必须是4k的倍数。

4、read_rnd_buffer_size:

索引缓冲区的大小(回表查询 ID 的缓存)。有查询需要时分配,只分配所需的大小而非整个参数值大小。

二、InnoDB 缓冲池(Innodb_buffer_pool)

1、Innodb_buffer_pool_size:

该参数控制InnoDB 缓冲池的的大小,在mysql 5.7之前修改该值需要重启服务器

  • 对于单独的 Mysql 服务器,可以设置为:总内存 - (每个线程所需内存 * 链接数)- 系统保留内存。
  • 根据手册建议,设置为总内存的75%。
  • 当缓冲池很大时,重启服务器需要较长时间来刷新脏页。
2、Buffer Pool中的LRU链表
  • innodb_old_blocks_pc:该参数控制了InnoDB缓冲池中旧数据(已经不活跃)所占的比例。默认值为37,表示旧数据在缓冲池中的比例为37%。较低的值会导致更多的旧数据被保留在缓冲池中,可能增加缓冲池的使用率,但也可能影响新数据的读取性能。较高的值则允许更多的新数据进入缓冲池,但也可能导致频繁的缓冲池刷新和旧数据的淘汰。根据实际情况,可以适当调整这个值来平衡性能需求和缓冲池利用率。
  • innodb_old_blocks_time:该参数定义了多长时间内被认为是“旧数据”。默认值为0,表示没有时间限制。当一个页面在缓冲池中处于未被访问状态的时间超过设定的阈值时,该页面将被视为旧数据并可能被替换出缓冲池。通过设置适当的阈值,可以确保缓冲池中保留的是最常访问的数据,避免过多的旧数据占用缓冲池资源。
3、change buffer:

是一种用于提高写入性能的内存数据结构。它用于延迟和合并磁盘上的物理页更改。当进行INSERT、UPDATE或DELETE操作时,Change Buffer会将修改记录到内存中,然后再批量地将这些修改应用到磁盘上的数据页。

  • innodb_change_buffering: 这个参数控制Change Buffer的工作方式。它有三种可选值:

                all:表示所有的数据修改都会被缓冲,默认值。
                none:表示不使用Change Buffer。
                inserts:只缓冲INSERT操作。

  • innodb_change_buffer_max_siz: 这个参数定义了Change Buffer的最大大小,以字节为单位。默认值为25%的缓冲池大小。根据系统的写入负载和可用内存,可以适当调整此参数以控制Change Buffer的大小。
4、innodb_max_dirty_pages_pct:

这个参数定义脏页在缓冲池中所允许的最大比例,以百分比表示。默认值为 75%。

  • 当脏页所占的比例超过的设定值时,InnoDB 将开始触发后台线程将脏页刷新到磁盘上的数据文件中,以确保缓冲池中的脏页数量维持在可接受的范围内。
  • 较低的 innodb_max_dirty_pages_pct 值可以使脏页更快地写入磁盘,从而减少系统崩溃或意外停机时数据丢失的风险,但可能会牺牲一些写入性能。
  • 较高的 innodb_max_dirty_pages_pct 值可以提高性能,因为不必频繁写入磁盘,但可能会增加系统恢复时间并增加数据丢失的风险。

三、 MyISAM 缓冲池

1、key_buffer_size:

该参数是 MyISAM 缓冲池的大小,只缓存索引。即使所有表都使用 InnoDB 引擎,也要设置该值,因为 MySQL 系统表仍在使用 MyISAM 引擎。

2、可以通过执行以下查询获取 MyISAM 表索引所占空间的大小:

SELECT sum(index_length) from infORMation_schema.tables where ENGINE='myisam';

来源地址:https://blog.csdn.net/jkzyx123/article/details/131574985

您可能感兴趣的文档:

--结束END--

本文标题: mysql内存相关的配置

本文链接: https://www.lsjlt.com/news/402512.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • oracle怎么查询当前用户所有的表
    要查询当前用户拥有的所有表,可以使用以下 sql 命令:select * from user_tables; 如何查询当前用户拥有的所有表 要查询当前用户拥有的所有表,可以使...
    99+
    2024-05-15
    oracle
  • oracle怎么备份表中数据
    oracle 表数据备份的方法包括:导出数据 (exp):将表数据导出到外部文件。导入数据 (imp):将导出文件中的数据导入表中。用户管理的备份 (umr):允许用户控制备份和恢复过程...
    99+
    2024-05-15
    oracle
  • oracle怎么做到数据实时备份
    oracle 实时备份通过持续保持数据库和事务日志的副本来实现数据保护,提供快速恢复。实现机制主要包括归档重做日志和 asm 卷管理系统。它最小化数据丢失、加快恢复时间、消除手动备份任务...
    99+
    2024-05-15
    oracle 数据丢失
  • oracle怎么查询所有的表空间
    要查询 oracle 中的所有表空间,可以使用 sql 语句 "select tablespace_name from dba_tablespaces",其中 dba_tabl...
    99+
    2024-05-15
    oracle
  • oracle怎么创建新用户并赋予权限设置
    答案:要创建 oracle 新用户,请执行以下步骤:以具有 create user 权限的用户身份登录;在 sql*plus 窗口中输入 create user identified ...
    99+
    2024-05-15
    oracle
  • oracle怎么建立新用户
    在 oracle 数据库中创建用户的方法:使用 sql*plus 连接数据库;使用 create user 语法创建新用户;根据用户需要授予权限;注销并重新登录以使更改生效。 如何在 ...
    99+
    2024-05-15
    oracle
  • oracle怎么创建新用户并赋予权限密码
    本教程详细介绍了如何使用 oracle 创建一个新用户并授予其权限:创建新用户并设置密码。授予对特定表的读写权限。授予创建序列的权限。根据需要授予其他权限。 如何使用 Oracle 创...
    99+
    2024-05-15
    oracle
  • oracle怎么查询时间段内的数据记录表
    在 oracle 数据库中查询指定时间段内的数据记录表,可以使用 between 操作符,用于比较日期或时间的范围。语法:select * from table_name wh...
    99+
    2024-05-15
    oracle
  • oracle怎么查看表的分区
    问题:如何查看 oracle 表的分区?步骤:查询数据字典视图 all_tab_partitions,指定表名。结果显示分区名称、上边界值和下边界值。 如何查看 Oracle 表的分区...
    99+
    2024-05-15
    oracle
  • oracle怎么导入dump文件
    要导入 dump 文件,请先停止 oracle 服务,然后使用 impdp 命令。步骤包括:停止 oracle 数据库服务。导航到 oracle 数据泵工具目录。使用 impdp 命令导...
    99+
    2024-05-15
    oracle
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作