MyISAM Engine
This article needs translation into English. This article is written in a language other than English. If it is intended for readers from the community of that language, it should be contributed to the Wikipedia in that language. See the list of Wikipedias. Please see this article's entry on Pages needing translation into English for discussion. If the article is not rewritten in English within the next two weeks it will be listed for deletion and/or moved to the Wikipedia in its current language. If you have just labeled this article as needing translation, please add {{subst:uw-notenglish|1=MyISAM Engine}} ~~~~ on the talk page of the author. |
介绍
MyISAM基于ISAM代码扩展而来的,每个MyISAM在磁盘上存储成三个文件。文件的名字以表的名字开始,扩展名指出文件类型。
表定义文件: .frm
数据文件: .MYD (MYData)
索引文件: .MYI (MYIndex)
特性
- MyISAM采用[1](且为排他锁)。
- 每个MyISAM表最大索引数是64。这可以通过重新编译来改变。每个索引最大的列数是16个。
- BLOB和TEXT列可以被索引。
- 所有数字键值以高字节为先被存储以允许一个更高地索引压缩。
- 每个字符列可以又不同的字符集。
- 以把数据文件和索引文件放在不同目录,用DATA DIRECTORY和INDEX DIRECTORY选项CREATE TABLE以获得更高的速度
启动选项配置
- --myisam-recover=mode
- 设置为崩溃MyISAM表自动恢复的模式。
- --delay-key-write=ALL
- 对任何MyISAM表的写操作之间不要刷新键缓冲区。
- bulk_insert_buffer_size
- 用在块插入优化中的树缓冲区的大小。
- myisam_sort_buffer_size
- 设置恢复表之时使用的缓冲区的尺寸。
比较
<<待>>
常见问题解决方案
- 1) 损坏的MyISAM表问题
- 产生的原因:
- mysqld进程在写中间被杀掉
- 发生未预期的计算机关闭
- 硬件故障
- 正被服务器修改的表上使用外部程序(如myisamchk)
- MySQL或MyISAM代码的软件缺陷
- 错误特征:
- 当在从表中选择数据之时,你得到如下错误:
- Incorrect key file for table: '...'. Try to repair it
- 查询不能在表中找到行或返回不完全的数据。
- 当在从表中选择数据之时,你得到如下错误:
- 修复方法:
- 用CHECK TABLE statement语句来检查MyISAM表的健康,并用REPAIR TABLE修复一个损坏的MyISAM表
- 2) 未被适当关闭的表的问题
- 每个MyISAM索引文件(.MYI)在头有一个计数器,它可以被用来检查一个表是否被恰当地关闭。如果你从CHECK TABLE或myisamchk得到下列警告,意味着这个计数器已经不同步了:
- "clients are using or haven't closed the table properly", 这个警告并不是完全意味着表已被破坏,但你至少应该检查表。
- 计数器的工作方式
- 表第一次被更新,索引文件头的计数器加一
- 在未来的更新中,计数器不被改变
- 当表的最后实例被关闭(因为一个操作FLUSH TABLE或因为在表缓冲区中没有空间)之时,若表已经在任何点被更新,则计数器减一
- 当你修理或检查表并且发现表完好之时,计数器被重置为零
- 要避免与其它可能检查表的进程进行事务的问题,若计数器为零,在关闭时计数器不减一
- 计数器出现异常的情况:
- MyISAM表不随第一次发出的LOCK TABLES和FLUSH TABLES被复制
- MySQL在一次更新和最后关闭之间崩溃(注意,表可能依然完好,因为MySQL总是在每个语句之间为每件事发出写操作)
- 一个表被myisamchk --recover或myisamchk --update-state修改,同时被mysqld使用
- 多个mysqld服务器正使用表,并且一个服务器在一个表上执行REPAIR TABLE或CHECK TABLE,同时该表也被另一个服务器使用。在这个结构中,使用CHECK TABLE是安全的,
- 虽然你可能从其它服务器上得到警告。尽管如此,REPAIR TABLE应该被避免,因为当一个服务器用一个新的数据文件替代旧的之时,这并没有发送信号到其它服务器上。 总的来说,
- 在多服务器之间分享一个数据目录是一个坏主意。