14.10.2 File Space Management  文件空间管理:

数据文件 你定义在配置文件形成了InnoDB的系统表空间,

文件是逻辑连接形成表空间,没有条带化使用。

你不能定义你的表在表空间中的分配。  

为了避免执行来自所有表和索引 在系统表空间, 你可以开启 innodb_file_per_table 配置选项,

会存储新创建的表在一个单独的tablespace 文件(扩展名为.ibd).

对于这种方式存储的表, 有较少的碎片在磁盘文件,

当表被truncate时, 空间返回给操作系统而不是仍旧被保留在Innodb 在系统表空间下

Pages, Extents, Segments, and Tablespaces:

每个表空间由数据库pages组成, 每个tablespace 在MySQL 实例有相同的page size.

默认的, 所有的tablespace 的page size 是16KB,

你可以降低page size 到8KB和4KB 通过指定innodb_page_size 选项,在你创建MySQL 实例的时候

pages 是集合成extents 大小是1MB( 64个连续的16KB pages,或者128 8KB pages,或者256 4KB pages)

files 在表空间内被称为segments( 那些segments 是不同于回滚段, 实际上包含很多表空间segments)

当一个segment 在表空间里,InnoDB 分配一次分配32个pages.

在那以后,InnoDB 开始分配整个extents 给segment.

InnoDB 可以一次加到4个extents 到一个大的segment来确保良好的串行数据。

两个segments 被分配给每个index 在InnoDB里,

一个是用于B树的非叶子块的,另外一个是用于leaf nodes.

保持leaf nodes在磁盘上连续可以更好的顺序的I/O操作,因为这些leaf nodes 包含实际的数据。

一些pages 在tablespace 包含其他Pages的位图,

因此 少量的extents 在InnoDB 表空间不能被分配给segments 作为整体,但是只能是单独的pages.

当你 需要可用的空闲空间在tablespace 通过使用一个SHOW TABLE STATUS statement,

InnoDB 报告extents 明确的空闲的 在tabloespace

当你从表删除数据,InnoDB 搜索相应的B-tree indexes.

不管释放的空间变的可用对于其他用户依赖的 ,不管 删除的模式释放单独的pages或者extents 到表空间。

删除表或者删除所有的记录是保证释放空间给用户,

但是记住 删除的记录是物理的移除只有通过Puege 操作,

这个会自动发生在它们不被事务回滚或者一致性读需要时

How Pages Relate to Table Rows  页于表记录的关系:

最大的行长度,特别是对于可变长度列(VARBINARY, VARCHAR, BLOB and TEXT),

略少于数据库页的一半。

比如, 最大行长度是大约8000字节对于默认的16KB innodb_page_size setting.

14.10.2 File Space Management 文件空间管理:的更多相关文章

  1. 14.10.1 InnoDB Disk I/O

    14.10 InnoDB Disk IO and File Space Management InnoDB 磁盘IO和文件空间管理: 14.10.1 InnoDB Disk I/O 14.10.2 F ...

  2. 14.10.5 Reclaiming Disk Space with TRUNCATE TABLE 回收空间使用TRUNCATE TABLE

    14.10.5 Reclaiming Disk Space with TRUNCATE TABLE 回收空间使用TRUNCATE TABLE 回收操作系统磁盘空间当truncate 一个InnoDB ...

  3. Ubuntu 14.10 下Hive配置

    1 系统环境 Ubuntu 14.10 JDK-7 Hadoop 2.6.0 2 安装步骤 2.1 下载Hive 我第一次安装的时候,下载的是Hive-1.2.1,配置好之后,总是报错 [ERROR] ...

  4. File Space——一个java structs2.0的小栗子(DIY)

    1 概述 File Space系统适用于团体,主要提供的是团队文件分享以及个人文件的存储管理服务.分为个人文件存储管理平台和团队文件共享平台. 个人文件存储平台主要为个人提供相关的文件分类存储服务:该 ...

  5. ubuntu 14.10 lts 64-bits环境下使用Android Studio

    距离google发布android studio 1.0正式版已经两个月左右了.由于一直习惯使用eclipse+ADT的模式,而且曾在windows下试用一次Android Studio预览版,感觉卡 ...

  6. CVE-2015-1328 Ubuntu 12.04, 14.04, 14.10, 15.04 overlayfs Local Root

    catalog . 引言 . Description . Effected Scope . Exploit Analysis . Principle Of Vulnerability . Patch ...

  7. Ubuntu 14.04/14.10下安装VMware Workstation 11图文教程

    VMware workstation 是一个可以进行桌面操作的虚拟软件.它可以让我们在一台电脑或者虚拟机中运行多个虚拟机. 由VMware公司研发和维护.由于是商业软件,我们需要买他们家的许可证或者说 ...

  8. ubuntu 14.10 安装 zabbix

    在ubuntu 14.10 上部署 zabbix 2.x 基本软件包安装 既然是ubuntu系统,当然要用好apt-get神器. 参考教程 URL:http://blog.csdn.net/cloud ...

  9. Ubuntu 14.04怎样升级到Ubuntu 14.10

    Ubuntu 14.04怎样升级到Ubuntu 14.10     Ubuntu 14.10 Utopic Unicorn 将在10月23日正式发布,9月25日最终测试版本已经发布,Ubuntu 14 ...

随机推荐

  1. POJ 1155 - TELE 树型DP(泛化背包转移)..

    dp[x][y]代表以x为根的子树..连接了y个终端用户(叶子)..所能获得的最大收益... dp[x][ ]可以看成当根为x时..有个背包空间为0~m...每个空间上记录了到到达这个空间的最大收益. ...

  2. iOS Development: Proper Use of initWithNibName:bundle: Affects UITableViewController

    Address:http://www.outofcore.com/2011/07/ios-development-proper-use-of-initwithnibnamebundle-affects ...

  3. [Swust OJ 234]--IrreducibleNumber(题意太坑)

    题目链接:http://acm.swust.edu.cn/problem/0234/ Time limit(ms): 1000 Memory limit(kb): 65535   Descriptio ...

  4. PHP中$_FILES的使用方法及注意事项说明

    $_FILES:经由 HTTP POST 文件上传而提交至脚本的变量,类似于旧数组$HTTP_POST_FILES 数组(依然有效,但反对使用)详细信息可参阅 POST方法上传 $_FILES数组内容 ...

  5. 浙江工商大学15年校赛C题 我删我删,删删删 【简单模拟】

    Description: 有一个大整数.不超过1000位.假设有N位.我想删掉其中的任意S个数字.使得删除S位后,剩下位组成的数是最小的. Input: 有多组数据数据,每组数据为两行.第一行是一个大 ...

  6. VirtualBox中的Ubuntu没有权限访问共享文件夹/media/sf_bak

    之前已经搞定可以自动共享文件夹了,但是现在发现无法去访问,非root用户下,使用“ls /media/sf_bak”提示没有权限,当然如果切换到root,是可以的. [解决过程]1.把普通用户名加入到 ...

  7. Python函数式编程:内置函数reduce 使用说明

    一.概述 reduce操作是函数式编程中的重要技术之一,其作用是通过对一个集合的操作,可以从中生成一个值.比如最常见的求和,求最大值.最小值等都是reduce操作的典型例子.python通过内置red ...

  8. 【HTTP 2】简介(Introduction)

    前情提要 在上一篇文章<[HTTP 2.0] 序言>中,我们简要介绍了 HTTP 2 协议的概要和协议状态. 在本篇文章中,我们将会了解到 HTTP 2 协议简介(Introduction ...

  9. 转:Bootstrap研究 精巧的网格布局系统

    本网格布局系统属于Scaffolding(框架,布局)部分.在Scaffolding里面有(固定)网格布局(Grid System)和流式网格布局(Fluid Grid System).本文讨论第一种 ...

  10. zk set 方法

    [root@wx03 zook]# cat a4.pl use ZooKeeper; use AnyEvent; use AE; use Data::Dumper; my $zk = ZooKeepe ...