zoukankan      html  css  js  c++  java
  • mysql ibdata1

    • ibdata1是什么?

    Mysql ibdata1即Innodb data1缩写,是innodb引擎的表空间,用于存放

    1. 数据字典Data dictionary:  只读的表,存储对象的相关信息,如占用空间,列的缺省值,约束信息,用户名,权限,审计信息等;
    2. 双写缓冲区 Double write buffer:; Innodb写入数据默认是16k/pages为一个单位写入,而磁盘是4k/page一个单位,为了防止写入一半,断电无法恢复数据的情况发生,引入了double writer buffer机制;double write buffer是一段连续空间,大小2M(128 page),数据写入的时候先写到doublewrite空间,然后再写入到磁盘,如果发生写入了一个page一半的时候断电,恢复后会自动从doublewrite中恢复;
    3. 插入缓冲区INSERT BUFFER:针对辅助索引(非unique),插入数据的时候,先将插入的数据在buffer中根据辅助索引叶子节点的Page_no排序,而后按照Page_no分批次插入,提高性能;
    4. 回滚日志rollback segment: 用于存储未提交事物,便于用户rollback,当commit后,数据即被标记无效;
    5. undo空间 用于存放undo 日志的;用于记录事物变更前的状态,如果未commit,其他session可以查看到变更前状态
    6. 如果innodb_file_per_table=0,则Innodb的数据和索引也存储在ibdata中; (如果为1,则存储在表名相同的ibd和frm文件中); 如果表数据存储在ibdata中的话,那么删除表是不会释放空间;

    ibdata 路径和大小设置:

    mysql>  show variables like 'innodb_data_%';
    +-----------------------+--------------------------------------------+
    | Variable_name         | Value                                      |
    +-----------------------+--------------------------------------------+
    | innodb_data_file_path | ibdata1:76M;ibdata2:10M:autoextend:max:50M |
    | innodb_data_home_dir  | /export/data/mysql                         |
    +-----------------------+--------------------------------------------+
    2 rows in set (0.00 sec)

    ibdata1:76M;ibdata2:10M:autoextend:max:50M含义是:生成2个表空间文件,第一个名字ibdata1,76M大小,第二个ibdata2,10M大小,当第一个达到最大值的时候,开始存储如第二个表空间,切第二个表空间可以自动增长,每次增长8M,增长的上限是50M;

    • 为什么ibdata1增长非常快速?

     因为里面有UNDO LOG,尤其是如果你的DB有大量写入的情况下,UNDO LOG会格外地多;

    • 如何查看ibdata1?
    • 有什么方法可以回收空间?
  • 相关阅读:
    题解 P3960 【列队】
    题解 P3825 【[NOI2017]游戏】
    题解 P3385 【【模板】负环】
    luoguP1555 尴尬的数字(暴力+map)
    luogu P1775 古代人的难题_NOI导刊2010提高(02)(斐波纳契+数学)
    luogu P1405 苦恼的小明(欧拉定理)
    luogu P2117 小Z的矩阵(结论题)
    BZOJ2870 最长道路tree(并查集+LCA)
    BZOJ 4668 冷战(按秩合并并查集+LCA)
    BZOJ 3376 [Usaco2004 Open]Cube Stacking 方块游戏(带权并查集)
  • 原文地址:https://www.cnblogs.com/grasp/p/10308805.html
Copyright © 2011-2022 走看看