Jump to content

MyISAM Engine

From Wikipedia, the free encyclopedia
This is an old revision of this page, as edited by Racklever (talk | contribs) at 16:03, 18 April 2010. The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.

介绍

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应该被避免,因为当一个服务器用一个新的数据文件替代旧的之时,这并没有发送信号到其它服务器上。 总的来说,
在多服务器之间分享一个数据目录是一个坏主意。