linux磁盘管理及文件系统介绍

    硬盘是计算机必备组成部分,现在的硬盘分固态硬盘和传统机械硬盘,这里要介绍的是传统机械硬盘。

    一.硬盘最基本结构

        1.硬盘是由坚硬金属材料制成的涂以磁性介质的盘片,不同容量硬盘的盘片数不等。每个盘片有两面,都可记录信息。每个磁道被分成许多扇形的区域,每个区域叫一个扇区,每个扇区可存储128×2的N次方(N=0.1.2.3)字节信息。在DOS中每扇区是128×2的2次方=512字节,盘片表面上以盘片中心为圆心,不同半径的同心圆称为磁道。硬盘中,不同盘片相同半径的磁道所组成的圆柱称为柱面,如下图所示:

blob.png

        2.MBR

        MBR:Master Boot Record,即硬盘的主引导记录,位于0磁道0扇区,大小512bytes。

        boot loader:引导加载器存放在MBR的前446bytes,用于引导操作系统。

        分区表:存放在boot loader之后的64bytes,用于存放分区信息。

        2bytes: 55AA(分区有效标识)

        

    二.磁盘的分区管理

       1. 由于分区表只有64bytes,一个分区占用大小16bytes,所以只能创建4个分区,通常使用 3主分区+1扩展(N个逻辑分区)  的分区模式。使用fdisk命令工具进行分区。

         fdisk -l [device…]   查看设备分区情况

     blob.png

        fdisk device    进入对设备磁盘进行操作

                                                                

blob.png

        常用的操作指令如下:

        d delete a partition  这是删除一个分区的动作;
        l list known partition types  是列出分区类型,以供我们设置相应分区的类型;
        m print this menu   是列出帮助信息;
        n add a new partition   添加一个分区;
        p print the partition table  列出分区表;
        q quit without saving changes  不保存退出;
        t change a partition's system id   改变分区类型;
        w write table to disk and exit  把分区表写入硬盘并退出;
      

        2.创建分区步骤:

            1).先输入n创建分区

            2).选择分区 e扩展分区 p主分区

            3).确认创建的分区号

            4).确认起始和终止柱面

            5).调整分区类型,L查看分区类型

            6).最后w把分区表写入硬盘并退出

            

         

        blob.png    

        3.把分区信息同步到内核

            partx -a /dev/DEVICE 

            blob.png

            上述错误是正常现象用cat /proc/partitions 查看内核中是否已存在该分区信息

                                                                   blob.png 

        三.文件系统

              在告知系统我的 partition 所在的起始与结束磁柱之后,之后则需要将 partition 格式化为我的操作系统认识的文件系统,常用的文件系统如下:

                Linux文件系统: ext2, ext3, ext4, xfs, btrfs, reiserfs, jfs, swap

                swap: 交换分区

                光盘:iso9660

                Windows:fat32, ntfs

                Unix: FFS, UFS, JFS2

                网络文件系统:NFS, CIFS

                集群文件系统:GFS2, OCFS2

                分布式文件系统:ceph, moosefs, mogilefs, GlusterFS, Lustre

              linux默认都支持ext文件系统,当一个 ext2 的 filesystem 被建立时, 他拥有 superblock / group description / block bitmap / inode bitmap / inode table / data             blocks 等等区域。要注意的是,每个ext2 filesystem 在被建立的时候,会依据 partition 的大小, 给予数个 block group ,而每个 block group 就有上述的这些部分。整个             filesystem 的架构可以下图展现:

            

           blob.png

                 为了简化,假设一个文件系统仅有1个blockgroup。

                  block:用来储存数据的最小单元,Block 的大小为 扇区 的 2 的次方倍数。

                  inode:每个文件都对应着一个inode,inode存储着文件的元数据

                  SuperBlock:记录整个 filesystem 相关信息,block和inode的总量和使用情况等等。

                  Group Description:记录 blockgroup 由何处开始记录。

                  Block bitmap:记录哪个 block 有没有被使用。  

                  Inode bitmap:此处记录那个 inode 有没有被使用。

                  Inode table:记录每个inode number对应文件所对应的metadata(元数据)。

                  Data Blocks: block 数据存放区。 

 

            可以通过dumpe2fs  分区  查看上述描述的信息。

            

blob.png

               

             当我们新增一个文件或目录时:

                    1. 根据 inode bitmap / block bitmap 的信息,找到尚未被使用的 inode 与 block , 进而将档案的属性与数据分别记载进 inode 与 block ;

                    2. 将刚刚被利用的 inode 与 block 的号码 (number) 告知 superblock、inode bitmap、block bitmap 等,让这些 metadata 更新信息。

 

 

                    

原创文章,作者:zxhy,如若转载,请注明出处:http://www.178linux.com/18340

(0)
zxhyzxhy
上一篇 2016-06-22
下一篇 2016-06-22

相关推荐

  • Shell脚本编程入门

    认识Shell Shell原意为贝壳 Linux系统中的shell是一个特殊的应用程序,它介于操作系统内核与用户之间,充当一个“命令解释器”的角色,负责接收用户输入的操作指令(命令)并进行解释,将需要执行的操作传递给内核执行,并输出执行结果。 可以使用命令查看当前使用的是哪种shell以及当前Linux系统中都支持哪些shell种类。   查看当前…

    Linux干货 2016-08-12
  • DNS服务器以及子域授权

    1、安装bind      [root@www ~]# yum -y install bind 2、查看安装生成的文件      [root@www ~]# rpm -ql bind | less 3、程序路径     /var/named 4、配置…

    Linux干货 2017-05-31
  • 内部命令与外部命令——Linux基本命令(3)

    1.     内部命令与外部命令 内部命令:由shell自带的,而且通过某命令形式提供 内部命令在系统启动时就调入内存,是常驻内存的,所以执行效率高。 外部命令:在文件系统路径下有对应的可执行程序文件 外部命令是系统的软件功能,用户需要时才从硬盘中读入内存。 2.     命令类…

    2017-07-13
  • wordpress和discuz的负载均衡(lvs-dr)

    wordpress和discuz的负载均衡 实验目的:利用lvs-dr模型实现wordpress和discuz的负载均衡 实验要求:客户端访问wordpress或discuz服务器时,无论被调度至哪台RS上,其会话和访问的页面都应保持一致; 实验环境:一台server用作VS,两台server用作RS,一台server用于部署mysql、NFS、wordpr…

    2017-05-13
  • Linux软件包管理与实例

    Linux系统的早期,编译是利用程序代码生成可执行文件的过程的手动编译。虽具有一定优势,但是专业知识要求高,不利于实际操作。因此出现了许多软件包管理器,最具代表的是由Red Hat 推出的RPM。Yum则有利于解决linux安装软件时的依赖性。 所谓依赖性,就是linux系统中的软件将不同的功能模块单独写入到不同的软件包中,最后将多个相互依存的软件包结合起来…

    2017-08-13
  • linux系统的路由功能

    1、概要    大家应该都明白,不同网段的报文包传播,是需要路由的转发转发功能的,那么,一个linux操作系统能不能充当路由器呢?下面不妨来验证一下。 2、网络拓扑 3、实现过程    <1>俩个centos6分别充当Router1和Router2。并添加足够的网卡。    <2&…

    Linux干货 2016-09-06