zoukankan      html  css  js  c++  java
  • innodb 存储引擎特性

    使用独立表空间后,系统表空间存储什么内容呢?

     

    1.innodb 数据字典信息

      和存储引擎相关。

      frm 是服务器的数据字典和存储引擎无关。

    2. undo 回滚段。

      可以单独存储。

     

    INNODB存储引擎特性

    1.事务性存储引擎。

    2.支持ACID特性

    redo log 和 undo log

    redo log 实现事务的持久性。

    包括两部分:

    1.内存中的重做日志缓冲区。

    2.文件系统的 ib_logfilex.

    show variables like ‘innodb_log_buffer_size’ 字节为单位。

    image

    内存中 默认 16M.

    image

    数量由参数innodb_log_files_in_group决定。

    image

     

    redo log 存放的是提交的事务,undolog 存放的是未提交的事务。

    undo log 作用:

    1.用于回滚

    2.多版本并发控制 (Multi-Version Concurrency Control )

    当对表中的数据进行修改时不仅产生redolog 也会产生一定的undo log。

    使用rollback时会用到undolog。

    redo log 为顺序写入,在数据库运行时不需要读取操作。

    undo log 需要随机读写。可以存放于SSD 上提升性能。

    2.INNODB 支持行级锁。

    行级锁可以最大程度支持并发。

    行级锁在存储引擎层实现。

    什么是锁?

    锁主要作用是管理共享资源的并发访问,用于实现事务的隔离性。

    锁的类型

    共享锁(读锁)

    读锁相互不会被阻塞。

    独占锁 (写锁)

    会阻塞其他的读锁和写锁。实现事务隔离性。

    image

    锁的粒度

    1.表级锁

    lock table myinnodb write;

    这样就会阻塞其他读取。

    unlock tables;

    2.行级锁

      在存储引擎实现,不在服务器层实现。

    阻塞和死锁

    什么是阻塞?

    一个事务中的锁需要等待另外一个事务锁的资源释放。

    什么是死锁?

    相互占用对方的等待资源,可以由系统自动处理。

    1.按照相同的顺序使用资源。

    2.增加相关的索引。

    3.innodb 状态检查。

    show engine innodb status; 两次需要至少间隔30秒。

    4.适用场景

      innodb 适合大多数的OLTP应用,支持全文索引和空间函数。

     

  • 相关阅读:
    WEB版一次选择多个文件进行批量上传(swfupload)的解决方案
    WEB版一次选择多个文件进行批量上传(WebUploader)的解决方案
    WEB上传大文件解决方案
    kindeditor 富文本粘贴 图片
    Kindeditor图片粘贴上传(chrome)
    PHP超大文件下载,断点续传下载
    大文件断点上传 js+php
    常见的消息映射格式总结
    常见的消息映射格式总结
    C++项目中的extern "C" {}
  • 原文地址:https://www.cnblogs.com/yg_zhang/p/5936247.html
Copyright © 2011-2022 走看看