14.1.3 Turning Off InnoDB 关掉InnoDB: Oracle 推荐InnoDB 作为首选的存储引擎用于典型的数据库应用,从单用户的wikis到博客, 到高端应用把性能推到极限.在MySQL 5.6中,InnoDB是新表的默认存储引擎. 如果你不需要使用InnoDB tables: 1.启动MySQL的时候带上 --innodb=OFF 或者--skip-innodb option来关闭 InnoDB 存储引擎: 注意: 在MySQL 5.6.21, --skip-inno…
14.6.1 Creating InnoDB Tables 创建InnoDB 表: 创建一个InnoDB 表,使用CREATE TABLE 语句,你不需要指定 ENGINE=InnoDB子句 如果InnoDB 定义为默认的存储引擎, 在MySQL 5.5是默认的版本. 你仍旧可以使用ENGINE=InnoDB 子句如果你计划使用mysqldump或者复制来replay CREATE TABLE 语句在一个服务器上,默认的存储引擎不是InnoDB. -- Default storage engin…
14.8.1 Creating InnoDB Tables 创建InnoDB 表 创建一个InnoDB表,使用CREATE TABLE 语句,你不需要指定ENGINE=InnoDB 子句 如果InnoDB 是定义为默认的存储引擎,在MySQL 5.5是默认为InnoDB. 你仍旧可以使用 ENGINE=InnoDB clause 如果你计划使用mysqldump或者复制 来重现CREATE TABLE 在一个server上 那个server 默认不是InnoDB 存储引擎 -- Default…
14.7.1 Resizing the InnoDB System Tablespace InnoDB 系统表空间大小 这个章节描述如何增加或者减少 InnoDB 系统表空间的大小 增加InnoDB 系统表空间的大小 最初的方式增加InnoDB 系统表空间的大小是配置他从开始就自动扩展. 指定autoextend 属性 对于最后的数据文件在表空间定义时. InnoDB 自动的增加大小 增量为64MB 当它超出时. 增量大小可以通过 the innodb_autoextend_increment…
14.6.8 Configuring the InnoDB Master Thread IO Rate 配置InnoDB 主线程IO 速率: 主线程 在InnoDB 是一个线程 执行各种任务在后台. 很多这些任务是I/O相关的, 比如flush dirty pages 从buffer pool或者写changes 从insert buffer 到相应的 secondary indexes. 主要的thread 尝试执行那些任务 不影响正常的服务器的工作. 它尝试创建可用的空闲的I/O 和调整它的…
14.6.3.5 Configuring InnoDB Buffer Pool Flushing InnoDB 执行某些任务在后台, 包括脏叶的刷新(那些已经发生改变的pages 但是没有写入到数据文件)从buffer pool InnoDB 开始刷新buffer pool pages 当脏叶的比例在buffer pool 达到 低水位设置通过innodb_max_dirty_pages_pct_lwm设置 这个选项是控制 脏页的比例在buffer pool,防止 脏叶的比例超过 innodb_…
14.6.3.4 Configuring InnoDB Buffer Pool Prefetching (Read-Ahead) 配置InnoDB Buffer pool 预取 一个预读请求是一个I/O 请求异步预取多个pages到buffer pool. 预估那些Pages 马上会被需要. 请求把所有的Pages 到一个extent. InnoDB 使用2种预读算法来改善I/O性能 线性的预读是一种技术是预测哪个page 可能马上被需要在buffer pool中被顺序访问的pages. 你控制…
14.6.3.1 The InnoDB Buffer Pool InnoDB 保持一个存储区域被称为buffer pool 用于cache数据和索引在内存里, 知道InnoDB buffer pool 如何工作,利用它来保持频繁访问的数据在内存里, 是MYSQL 调优的一个重要方面. 你可以配置InnoDB buffer pool的各个方面来改善性能: 理想情况下,你设置buffer pool的大小为实际最大值, 留下足够的内存用于其他进程在服务器上运行而没有产生分页. buffer pool越…
14.5.5.1 An InnoDB Deadlock Example 一个InnoDB 死锁实例 下面的例子演示了一个错误可以发生当一个lock 请求会导致一个死锁,例子设计2个客户端,A和B: Jekins:/root# mysql -uroot -p1234567 -e"SHOW ENGINE INNODB STATUS\G;" | grep -i dead Warning: Using a password on the command line interface can b…
14.5.5 Deadlocks in InnoDB 14.5.5.1 An InnoDB Deadlock Example 14.5.5.2 Deadlock Detection and Rollback 14.5.5.3 How to Minimize and Handle Deadlocks 死锁是一种情况 不同的事务是不能处理 因为每个持有的lock 是其他会话需要的. 因为所有事务都是等待一个资源变得可用,两者都不释放它持有的锁 一个deadlock 可以发生 当事务锁定记录在多个表(…