| 网管联盟 | 网管论坛 | 网管u家 | 网管博客 | 网管软件 | 网管求职 | 小游戏 | 网管搜索 | 网管原创 | 网管聚合 | 网管读摘 | 网管焦点 | 世界素材 | 会员投稿 | 会员中心 |
![]() |
| Windows Linux Cisco 网络技术 数据库 黑客攻防 DotNet Java PHP 认证 新闻资讯 服务器 存储资讯 网络设备 网管学堂 技术专题 焦点 网吧频道 |
MySQL 如何统计打开的表数量
执行命令 mysqladmin status 时,可以看到类似如下结果: 网管bitscn_com
Uptime: 426 Running threads: 1 Questions: 11082 Reloads: 1 Open tables: 12 |
网管联盟bitsCN@com
如果只有6个数据表时,Open tables 的值确实12,这可能会有些疑惑。
网管论坛bbs_bitsCN_com
MySQL是多线程的,因此可能会有多个客户端同时发起查询某个表的请求。为了最小化多个客户端线程在同一个表上的不同状态,针对每个并发的线程单独打开数据表。这会占用一些内存,但是通常会提高性能。如果是 MyISAM 表,针对每个打开数据表的客户端都要有一个额外的文件描述符打开数据文件的情况(不过索引文件的描述符则可以在所有的线程间共享)。ISAM 存储引擎则共享这些操作。 网管u家u.bitscn@com
MySQL 如何打开和关闭数据表 网管网www_bitscn_com
系统变量 table_cache, max_connections 和 max_tmp_tables 影响着服务器保持打开的文件最大数量。提高一个或多个这些变量,就可以提高操作系统在每次处理时能打开的文件描述符限制。很多操作系统都可以增加文件打开的数量限制,不过每个系统的方法都各不一样。查阅一下操作系统文档来判断是否可以提高限制以及怎么去做。 网管论坛bbs_bitsCN_com
table_cache 和 max_connections 相关。例如,有200个并发的连接,那么则必须至少有 200 * N 大小的表缓存,N 是在一个表连接中最大的表数量。同时也需要为临时表和临时文件保留一些额外的文件描述符。 网管网www_bitscn_com
请确认操作系统可以通过设定 table_cache 来处理对应数量的打开文件。如果 table_cache 设得太高了,MySQL可能会用完全部的文件描述符而拒绝新连接,就无法执行查询,变得很不可靠。因此必须要考虑到 MyISAM 存储引擎要为每个独立打开的表使用两个文件描述符。可以在启动 mysqld_safe 的时候增加 --open-files-limit 参数来提高MySQL打开文件描述符的数量。详情请看\"A.2.17 File Not Found\". 网管联盟bitsCN@com
缓存中会保存 table_cache 个打开的表会。它的默认值是64;它可以在启动 mysqld 的时候通过修改 --table_cache 参数来改变。注意,MySQL可能会临时打开比这个数更多的表来执行查询。 中国网管论坛bbs.bitsCN.com
在以下情况中,一个不用的表会被关闭并且从缓存中被删除:
网管u家u.bitscn@com
网管论坛bbs_bitsCN_com
网管联盟bitsCN@com
|
0
|
评论加载中…