zoukankan      html  css  js  c++  java
  • mysql存储引擎之innodb学习

    innodb引擎特点
    1、支持事务:支持4个事务隔离级别,支持多版本读。

    2、行级锁定(更新时一般是锁定当前行):通过索引实现,全表扫描仍然会是表锁,注意间隙 锁的影响

    3、读写阻塞与事务隔离级别有关

    4、具有非常高效的缓存特性,能缓存索引,也能缓存数据

    5、整个表和主键以cluster方式存储,组成一颗平衡树

    6、所有secondary index都会保存 主键信息

    7、只是分区,表空间,类似oracle数据库

    8、支持外键约束,5.5以前不支持全文索引,以后支持了

    总结最大的特点:支持事务、支持行级锁,支持外键约束

    innodb引擎适用的生产业务场景

    1、需要事务支持的业务(具有较好的事务特性)
    2、行级锁定对高并发有很好的适应能力,但需要确保查询是通过索引完成

    3、数据读写及更新都较为频繁的场景:BBS,SNS,微博,微信等

    4、数据一致性要求较高的业务,例如:充值转账。银行卡转账

    5、硬件设备内存较大,可以利用innodb较好的缓存能力来提高内存利用率,尽可能减少磁盘IO

    innodb引擎调优精要

    1、主键尽可能小,避免给secondary index带来过大的空间负担

    2、避免全表扫描,因为会使用表锁

    3、尽可能缓存所有的索引和数据,提高响应速度,减少IO消耗

    4、在大批量小插入的时候,尽量自己控制事务,而不是使用autocommit自动提交,有开关可以控制提交方式

    5、合理设置innodb_flush_log_at_trx_commit参数值,不要过度追求安全性

        如果innodb_flush_log_at_trx_commit的值为0,log buffer每秒就会被刷写日志文件到磁盘,提交事务的时候不要做任何操作。

    6、避免主键更新,因为这样会带来大量的数据移动。

  • 相关阅读:
    [LeetCode] 1898. Maximum Number of Removable Characters
    [LeetCode] 1897. Redistribute Characters to Make All Strings Equal
    [LeetCode] 1400. Construct K Palindrome Strings
    235. 二叉搜索树的最近公共祖先
    349. 两个数组的交集
    海量数据TOPK 问题
    121. 买卖股票的最佳时机
    删除数组中为0元素
    这行字符串中出现频率最高的字符
    50. Pow(x, n)
  • 原文地址:https://www.cnblogs.com/lisqiong/p/5677766.html
Copyright © 2011-2022 走看看