How MySQL Opens and Closes Tables:https://dev.mysql.com/doc/refman/5.7/en/table-cache.html

其他可供参考的文章有:

关于表限制参数的使用:https://dba.stackexchange.com/questions/5232/mysql-table-cache-and-opened-tables

关于SHOW OPEN TABLES命令的使用:https://www.percona.com/blog/2008/12/14/show-open-tables-what-is-in-your-table-cache/

一、本文涉及到的系统参数有3个:

  • table_open_cache

Server层参数。

这个参数表示针对所有threads的table cache总和,5.6.7之前默认是400,5.6.8之后是2000。

这是个server层的参数,mysql不支持并行查询,mysql的会话也没有PGA的概念,一个thread引用myisam表时需要在server层上创建一个table对象(索引也需要创建一个但是是共享的,self join会创建2个,分区表每个分区按单表对待),如果同时多个会话引用一个表也会创建多个表对象,虽然会加大内存使用量,但是却极大的减少了内部表锁的争用。

这个值的数目建议设置为max_connections*你的表数目,当然你可能也需要为一些临时表等对象预留,但是这个数目已经足够大啦。

那么mysql什么时候释放这些表对象呢?

  1. 当缓冲已满,而连接想要打开一个不在缓冲中的表时。
  2. 当缓冲数目已经超过了table_open_cache设置的值,mysql开始使用LRU算法释放表对象。
  3. 当你用flush tables;语句时。
  • open_files_limit

引擎层参数。

这个参数表示mysqld可用的最大文件描述符数目,如果你遇到“Too many open files”的错误,应当考虑加大它。这个参数的默认值是0表示无限制(大于5.6.7后默认值不再为0,参考官网),但其实他的值是与操作系统相关的,在Unix系统下这个值的数目不能大于ulimit -n。

这个参数应当大于等于table_open_cache。

目前不清楚当设置了innodb_open_files后此参数是指所有存储引擎的句柄数限制,还是非innodb的句柄数限制,需要研究源码才可以理清,这里暂且认为是前者。

  • innodb_open_files

引擎层参数。

这个参数只对InnoDB存储引擎有效,它指定了mysql可以同时打开的最大.ibd文件的数目。这个参数即不影响table_open_cache也不受open_files_limit影响,是独立的只对InnoDB有效的。所以在默认为InnoDB存储引擎时可以不考虑open_files_limit只去设innodb_open_files。

这3个参数的关系可以总结如下,为保证性能,你应当设置为如下值:

max_connections*你的表数目 = table_open_cache <=open_files_limit< ulimit -n

innodb_open_files<ulimit -n

二、本文涉及到的status参数有2个:open_tables和opened_tables

其中open_tables表示当前打开的table总和,即所有connection打开的table总数。

opened_tables表示打开过的表的数量总和,只有show global status才能看到它的值。这是个计数器,Opened_tables/Uptime的值过大说明table_open_cache过小,导致一些table对象(即下文说的table对象)经常会刷出server层,需要的时候再创建,最终导致此计数过大。

 

三、相关原理图

参考:http://www.cnblogs.com/xpchild/p/3780625.html的源码解析,以innodb为例。

如下图,有个表叫xpchild(小屁孩666)库中的pp表:

table: 针对每个会话,MySQL会为join查询中涉及的每个表建一个TABLE对象,引用innodb表时会创建innodb层的handler,server层的table对象指向此handler,此handler操作文件系统底层的ibd文件。

table_share: 初次被访问时,MySQL为每一张表建立一个table_share对象,与engine层的dict_table_t中的对应表对应,这些table_share对象共同组成server层的一个table cache。

handler: 在Innodb engine层对应于每个TABLE对象,引擎创建一个或多个handler(windows叫handlers,linux叫file descriptors),当然不同存储引擎、是否分区都会影响单个table对象对应的handler个数。

dict_table_t: innodb为每一个innodb表load一个数据字典对象,这些对象的集合就是innodb中的data dictionary。

你可以将table对象看做表在server层的映射,将handler看做table对象为操作底层数据文件等磁盘文件而在engine层创建的句柄,也因此MySQL支持各种插入式engine。

flush tables with read lock:close了server层创建的所有的table_share对象(即清除了table cache),并使用一个全局的读锁锁定所有schema下的所有表。

关于flush的各种用法及解释,参考:https://dev.mysql.com/doc/refman/5.7/en/flush.html

转载于:https://www.cnblogs.com/leohahah/p/8921107.html

MySQL open_tables和opened_tables相关推荐

  1. mysql服务器端的参数有很多_但是对于大多数初学者来说_mysql优化的重要参数 key_buffer_size table_cache...

    MySQL服务器端的参数有很多,但是对于大多数初学者来说,众多的参数往往使得我们不知所措,但是哪些参数是需要我们调整的,哪些对服务器的性能影响最大呢?对于使用Myisam存储引擎来说,主要有key_b ...

  2. 利用tuning-primer脚本优化MySQL数据库

    脚本下载网址:  http://www.day32.com/MySQL/tuning-primer.sh #!/bin/sh # vim: ts=8 ######################### ...

  3. mysql的优化之table_open_cache 篇_mysql性能优化之table_open_cache

    表现:数据库查询效率慢,show processlist 发现比较多的查询正在opening table. 进一步确认,执行以下语句: mysql> show global status lik ...

  4. 8核32g mysql性能_MySQL性能优化之参数配置

    1.目的: 通过根据服务器目前状况,修改Mysql的系统参数,达到合理利用服务器现有资源,最大合理的提高MySQL性能. 2.服务器参数: 32G内存.4个CPU,每个CPU 8核. 3.MySQL目 ...

  5. 从某次测试过程中,得到的MySQL性能优化的建议,和定位问题的方法

    MySQL版本5.5 某次测试优化过程中碰到的问题和解决问题的方法,方案.以供各位参考. 一,表结构的优化 问题1,表与字段使用不同的字符集会导致索引失效 我在自己的机器上,没试出来.可能与记录数太少 ...

  6. mysql服务器配置优化

    1.在linux系统中使用which mysqld确定msyql的配置文件所在 2.配置设置都是小写的,使用下划线或破折号分割单词 3.在32位的linux操作系统上,单个进程使用的内存是2.5G-2 ...

  7. Mysql优化系列(1)--Innodb重要参数优化

    1.简单介绍 InnoDB给MySQL提供了具有提交,回滚和崩溃恢复能力的事务安全(ACID兼容)存储引擎.InnoDB锁定在行级并且也在SELECT语句提供一个Oracle风格一致的非锁定读.这些特 ...

  8. mysql优化的重要参数 key_buffer_size table_cache

    MySQL服务器端的参数有很多,但是对于大多数初学者来说,众多的参数往往使得我们不知所措,但是哪些参数是需要我们调整的,哪些对服务器的性能影响最大呢?对于使用Myisam存储引擎来说,主要有key_b ...

  9. 根据status信息对MySQL服务器进行优化-1

    网上有很多的文章教怎么配置MySQL服务器,但考虑到服务器硬件配置的不同,具体应用的差别,那些文章的做法只能作为初步设置参考,我们需要根据自己的情况进行配置优化,好的做法是MySQL服务器稳定运行了一 ...

  10. MySQL优化经验-值得细细品读

    MySQL优化经验: 同时在线访问量继续增大 对于1G内存的服务器明显感觉到吃力严重时甚至每天都会死机 或者时不时的服务器卡一下 这个问题曾经困扰了我半个多月MySQL使用是很具伸缩性的算法,因此你通 ...

最新文章

  1. DOS 循环 FOR
  2. oralce 角色 权限
  3. 洛谷 P1209 修理牛棚== Codevs 2079 修理牛棚
  4. Day4-springmvc中文乱码处理和客户端跳转
  5. C#测试数据库连接是否成功
  6. cv岗工作做什么_中字头施工单位的党建岗是做什么的?
  7. 解决github无法访问的问题
  8. flask-mail异步发送邮件_SpringBoot 2.0 集成 JavaMail ,实现异步发送邮件
  9. VxWorks嵌入式操作系统的TrueFFS文件系统驱动开发
  10. mysql show status 过滤_在线更改复制过滤选项的方法
  11. [翻译]JUnit 5 用户手册
  12. 基于QT和DCMTK的Dicom 图像浏览器---目录
  13. 狂神Mybatis笔记
  14. 无人机测量技术在房地一体项目中的应用
  15. 如何简单的管理API
  16. 如何教会爸妈用智能手机?方法比耐心重要,get这份手绘板说明书!
  17. 不写一行代码就能开发?是真的,试试应用魔方吧
  18. 【JavaScript】用户代理检测的局限性
  19. iphone开发小记
  20. python开源web项目-30 个惊艳的Python开源项目

热门文章

  1. 【一起来刷Python题】——09.解决熄灯问题
  2. 数字孪生 软著登记表 模板
  3. position: relative相对定位 ; absolute绝对定位 子绝父相 盒子居中 堆叠顺序z-index cursor光标 hover悬停 轮播图 固定定位fixed
  4. 洛谷P3456 [POI2007]GRZ-Ridges and Valleys
  5. win7声音图标不见,此图标当前处于未活动状态
  6. Flexbox布局基础入门
  7. 【本科课程学习】数据库考试复习题(带答案)
  8. 程序员,职场上请远离这种人!
  9. 真相了,原来程序员不喜欢领导改需求是这样子的!
  10. 前端项目中代码格式化配置:eslint + prettier + stylelint + pre-commit