数据库的物理结构设计指的是什么?

如题所述

Log File物理结构

从 ib_logfile0和 ib_logfile1这两个文件的物理结构可以看出,在Log Header部分还是有些许差异的, ib_logfile0会多一些额外的信息,主要是checkpoint信息。

并且每个Block的单位是512字节,对应到磁盘每个扇区也是512字节,因此redo log写磁盘是原子写,保证能够写成功,而不像index page一样需要double write来保证安全写入。

我们依次从上到下来看每个Block的结构

Log File Header Block

    Log Goup ID,可能会配置多个redo组,每个组对应一个id,当前都是0,占用4字节

    Start LSN,这个redo log文件开始日志的lsn,占用8字节

    Log File Number,总是为0,占用4字节

    Created By,备份程序所占用的字节数,占用32字节

    另外在ib_logfile0中会有两个checkpoint block,分别是 LOG_CHECKPOINT_1/ LOG_CHECKPOINT_2,两个记录InnoDB Checkpoint信息的字段,分别从文件头的第二个和第四个block开始记录,并且只在每组log的第一个文件中存在,组内其他文件虽然没有checkpoint相关信息,但是也会预留相应的空间出来。这里为什么有两个checkpoint的呢?原因是设计为交替写入,避免因为介质失败而导致无法找到可用的checkpoint的情况。

    Log blocks

    请点击输入图片描述

    log block结构分为日志头段、日志记录、日志尾部

    Block Header,占用12字节

    Data部分

    Block tailer,占用4字节

    Block Header

    这个部分是每个Block的头部,主要记录的块的信息

    Block Number,表示这是第几个block,占用4字节,是通过LSN计算得来的,占用4字节

    Block data len,表示该block中有多少字节已经被使用了,占用2字节

    First Rec offet,表示该block中作为第一个新的mtr开始的偏移量,占用2字节

    Checkpoint number,表示该log block最后被写入时的检查点的值,占用4字节

温馨提示:答案为网友推荐,仅供参考
第1个回答  推荐于2017-09-27
  数据库的物理结构设计指的是根据数据库的逻辑结构来选定RDBMS(如Oracle、Sybase等),并设计和实施数据库的存储结构、存取方式等。
  确定数据库的物理结构包含下面四方面的内容:
  1、确定数据的存储结构;
  2、设计数据的存取路径;
  3、确定数据的存放位置;
  4、确定系统配置。
  数据库物理设计过程中需要对时间效率、空间效率、维护代价和各种用户要求进行权衡,选择一个优化方案作为数据库物理结构。在数据库物理设计中,最有效的方式是集中地存储和检索对象。
第2个回答  推荐于2017-10-10
一般开发一个数据库,要进行设计。主要步骤有需求分析,概念结构设计,逻辑结构设计,物理结构设计,数据库实施,数据库运行与维护。物理结构设计就是其中的一步。
数据库的物理结构设计是对已经确定的逻辑数据结构,利用DBMS(数据库管理系统)所提供的方法、技术,以较优的数据存储结构、数据存取路径、合理的数据存放位置以及存储分配,设计出一个高效的、可以实现的物理数据结构。通俗一点说,就是对已经设计好了的逻辑结构,设计出相应的且比较优化的物理结构,设计出的物理结构可以数据存储,该结构中要有实现数据存储、数据存取路径、数据存放位置、存储分配等几个模块。本回答被提问者和网友采纳