Linux磁盘及文件系统管理

 

   CPU,Memory(RAM),I/O

  

   I/O:Disks,Ethtercard

        Disk:持久存储数据

            接口类型:

                     IDE(ata):并口,133MB/s

                           SCSI:并口,Ultrascsl320,320MB/s

                           SATA:串口,6gbps

                           SAS:串口,6gbps

                           USB:串口,480MB/s

                      

                      并口:同一线缆可以接多块设备;     

                           IDE:俩个,主,从

                           SCSI:

                                 宽带:16-1

                                 窄带:8-1      

                           iops:io per second

                           串口:一个                                       

             硬盘:机械硬盘,固态硬盘:

                      机械硬盘:

                          track:磁道

                          sector:扇区,512bytes

                          cylinder:柱面:不同磁盘的同一磁道

                                          分区划分基于柱面

         平均寻道时间:

                    5400rpm,7200rpm,10000rpm,15000rpm

         Linux的哲学思想:一切皆文件:

               设备类型:

                   块(block):随机访问,数据交换单位是“块”;

                   字符(character):线性访问,数据交换单位是“字符”;

             

               设备文件:FHS

                    /dev

                     设备文件:关联至设备的驱动程序;设备的访问类型

 

               设备号:

               major:主设备号,区分设备类型;用于标明设备所需要的驱动程序

               minor:次设备号,区分同种类型下的不同设备;是特定设备的访问入口

                          

                    mknod命令:

                         make block or character special files

        

                         mknod [OPTION]...NAME TYPE [MAJOR MINOR]

                                -m MODE:创建后的设备文件的访问权限;

                    

                    设备文件名:ICANN 

                      

                    磁盘:

                         IDE: /dev/hd[a-z]

                            例如: /dev/hda   /dev/hdb                  

                         SCSI,SATA,USB,SAS:/dev/sa[a-z]

                         

                         分区:

                               /dev/hda#        

                                    /dev/hda1,...

                         注意:CentOS 6和7系统将硬盘设备标识为/dev/sd[a-z]#

                         引用设备的方式:

                                 设备文件名

                                 卷标

                                 UUID

  

                磁盘分区:MBR,GPT

                      MBR:0 sector

                      Master Boot Record

       分为三部分:

                446bytes:bootloader,程序,引导启动操作系统的程序;

                64bytes:分区表,每16bytes标识一个分区,一共只能有4个分区;

                2bytes:MBR区域的有效性标识;55AA位有效;否则为无效

                         

                           主分区和扩展分区的标识:1-4

                           逻辑分区:5+

  当我们想在系统里面新增一块硬盘时:

          1:对磁盘进行分区,以新建可用的分区

          2:对该分区进行格式化,以创建系统可用的文件系统

          3:对文件系统进行检验

          4:在Linux系统上,需要创建挂载点(目录),并且挂载上来

                    

      逻辑分区:fdisk

          1:查看磁盘的分区信息

              fdisk -l [-u] [device];列出指定磁盘设备上的分区信息

          2:管理分区

              fdisk  device

              fdisk提供了一个交互式接口来管理分区,它有许多子命令,分别用于不同的管理功能;

              所有的操作均在内存中完成,没有直接同步到磁盘,直到使用w命令保存至磁盘上           常用命令:

                n:创建新分区

                

                d: 删除已有分区

                

                t: 修改分区类型

                

                l: 查看所有已有ID

                

                w: 保存并退出

                

                q: 不保存退出

                m: 查看帮助信息

                

                p: 显示现有分区信息

                

  注意:在已经分区并且已经挂载其中某个分区的磁盘设备上创建的新分区,内核可能在创建完成后

        无法直接识别;

        

        查看磁盘分区:cat /proc/partitions

        通知内核强制重读磁盘分区表:

              CentOS 5:partprobe [device]

              CentOS 6,7:partx,kpartx

             增加分区同步      

                  partx -a  [device]

                  kpartx -af [device]

             删除分区同步

                  partx -d  --nr 7-8 [device]

             分区创建工具:

                  parted,sfdisk;

文件系统管理工具:

     创建文件系统的工具:

        mkfs

               mkfs.ext2,mkfs.ext3 mkfs.ext4 mkfs.ext4 mkfs.xfs mkfs.vfat

     检测及修复文件系统的工具:

        fsck 

               fsck.ext2等

      查看其属性的工具:

        dumpe2fs,tune2fs

      调整文件系统特性:

        tune2fs

内核级文件系统的组成部分:

      文件系统驱动:由内核提供

      文件系统管理工具: 由用户控件的应用程序提供      

创建文件系统:

     格式化:低级格式化(分区之前进行,划分磁道)

     高级格式化(分区之后对分区进行,创建文件系统)

     创建文件系统:

     linux文件系统类型:ext2  ext3 ext4 xfs relserfs iso9660 swap

       元数据区,数据区

           元数据区:

           不包含文件名

               文件元数据:inode(index node)

                     大小,权限,属主属组,时间戳,数据块指针等

 

               符号链接文件:存储数据

 

  ext系列文件系统的管理工具:

        磁盘格式化:

              mkfs -t ext3=mkfs.ext3

        在格式化为ext3中,由于我们没有详细指明文件系统的具体选项,因此系统会使用默认值来进行格式化。

        指定ext2/ext3具体选项(label,block大小或inode数量)

              mke2fs [OPTIONS] device

                 -t:指明要创建的文件系统类型

                        mkfs -t ext3=mkfs.ext3

                 -b: {1024|2048|4096}:指明文件系统的块大小

                 -j:创建有日志功能的文件系统ext3(默认是ext2)

                    make2fs -j=make2fs -t ext3=mkfs -t ext3=mkfs.ext3

                 -i #:指明inode与字节的比率;即每多少字节创建一个inode

                 -N #:直接指明要给此文件系统创建的inode的数量

                 -m #:指定预留的空间,百分比;

          卷标为:hello kitty

          block:2048

          8192bytes分配一个inode

          构建journal的ext3文件系统   

         

        e2label命令:卷标的查看与设定

               查看:e2label device

               设定:e2label device LABEL

       

         tune2fs命令:查看或修改ext系列文件系统的某些属性

         注意:块大小创建后不可修改

             

            tune2fs [OPTIONS] device

                -l:查看超级块的内容

                修改指定文件系统的属性:

                      -j:ext2 -> ext3

                      -L LABEL:修改卷标

                      -m #:调整预留空间百分比

                      -O [^]FEATHER:开启或关闭某种特性

                      -o [^]mount_options:开启或关闭某种默认挂载选项

                          acl 

                         ^acl

             dumpe2fs命令:显示ext系列文件系统的属性信息

                 dumpe2fs [-h] device

             

     fsck命令:用于实现文件系统检测的工具

因进程意外终止或系统崩溃等 原因导致定稿操作非正常终止时,可能会造成文件损坏;此时,应该检测并修复文件系统;建议,离线进行。

    

     e2fsck [options] device

            -y:对所有问题自动回答为yes;

            -f:即使文件系统处于clean状态,也要强制检测

            

            第一步:检查inode,块,大小

            第二步:检查目录结构

            第三步:检查目录连接性

            第四步:检查引用信息

            第五步:检查簇概要信息

    fsck命令: 

            -t fstype:指明文件系统类型;

                  fsck -t ext4=fsck.ext4

            -a :无须交互而自动修复所有错误;

            -r :交互式修复

    blkid命令:查询设备上所采用系统类型,UUID

          blkid device

          blkid  -L LABEL:根据LABEL定位设备

          blkid  -U UUID: 根据UUID定位设备      

    

    swap文件系统:

        Linux上的交换分区必须使用独立的文件系统;

             且文件系统的System ID必须为82;

        创建swap设备:mkswap命令

           mkswap [options] device

              -L LABEL:指明卷标

              -f:强制

Windows无法识别Linux的文件系统;因此,存储设备需要在俩中系统之间交叉使用时,应该使用windows和Linux同时支持的文件系统:fat32(vfat)

   # mkfs.vfat device

文件系统的使用:

   首先要“挂载”:mount命令和umount命令

                         

   根文件系统之外的其他文件系统要想能够被访问,都必须通过“关联”至跟文件系统上的某个目录来实习,此关联操作即为“挂载”;此目录即为“挂载点”;

    挂载点:mount_point,用于作为另一个文件系统的访问入口;

   (1)事先存在;

   (2)应该使用未被或不会被其他进程使用到的目录

   (3)挂载点下原有的文件将会被隐藏

    mount命令:

         mount [-nrw] [-t 文件系统] [-L LABEL] [-o options] device dir

           命令选项:

                -r:readonly,只读挂载;

                -w:read and write,读写挂载;

                -n:默认情况下,设备挂载或卸载的操作会同步更新在/etc/mtab中;用于禁于此操作

                -t vfstype:指明要挂载的设备上的文件系统的类型;多数情况下可省略

                            此时mount会根据blkid来判断要挂载的设备的文件类型

                -L LABEL:挂载时以卷标的方式指明设备

          

                 -U UUID:挂载时以UUID的方式指明设备

          

       -o options:挂载选项

          sync/async:同步/异步操作;(同步:内存和磁盘同时写入);

          atime/noatiome:文件或目录被访问时是否更新访问时间戳;

          diratime/nodiratime:目录被访问时是否更新访问时间戳;

          remount:重新挂载;

          acl:支持使用facl功能;

          例:没有加acl,不支持操作(不支持设定访问控制功能)

          

          mount下发现只有读写权限

          

          我们用mount重新挂载,加入acl选项

          

          再次进入/mnt 查看是否具有访问控制功能

          

          acl默认我们是不支持的,太危险了,你懂得,没必要给自己挖坑

          第二种方法:

                   tune2fs -o acl /dev/sda6 启用acl

                   tune2fs -l /dev/sda6 查看acl是否启用

          ro:只读

          rw:读写

          dev/nodev:此设备上是否允许使用设备文件;

         exec/noexec:是否允许运行此设备上的程序文件;

         auto/noauto:是否允许普通用户挂载此文件系统;

         suid/nosuid:是否允许程序文件上的suid和sgid特殊权限生效

         defaults: Use default options()默认选项):

         rw, suid, dev, exec, auto, nouser, async, and relatime

   一个使用技巧:

         可以实现将目录绑定至另一个目录上,作为临时访问路口;

            mount --bind 源目录 目标目录

         查看当前系统所有已挂在的设备;

           # mount

           # cat /etc/mtab

           # cat /proc/mounts 

         挂载光盘:

            mount -r /dev/cdrom  mount_point(挂载点)

         

         挂在U盘:

             事先识别U盘的设备文件;

          

         挂载本地的回环设备:

             mount -o loop /PATH/TO/SOME_LOOP_FILE MOUNT_POINT

   umount命令:

        umount  device | dir

 

           注意:正在被进程访问到的挂载点无法被卸载;  

                 查看被哪个或者哪些进程所占用:

                     # lsof MOUNT_POINT或#fuser -v MOUNT_POINT

                 终止所有正在访问某挂载点的进程:

                     # fuser -km  MOUNT_POINT 强行T掉

                     # umount MOUNT_POINT 再取消挂载

    交换分区的启用:

           创建交换分区的命令:mkswap

 

           启用:swapon

                   swapon [OPTION][DEVICE]

                     -a:定义在/etc/fstab文件中所有swap设备;

           禁用:swapoff

                   swapoff DEVICE

      设定除根文件系统以外的其他文件系统能够开机时自动挂载:/etc/fstab文件

           

   每行定义一个要挂载的文件系统及相关属性:

        6个字段

           (1)要挂在的设备:

                   设备文件;

                   LABEL

                   UUID

                   伪文件系统:如sysfs,proc,tmpfs等

           (2)挂载点

                swap类型的设备的挂载点为swap;

           (3)文件系统类型;

           (4)挂载选项

                defaults:使用默认挂载选项;

                如果要同时使用多个挂载选项,彼此间以逗号分隔即可

                 例: defaults,acl,noatime,noexc

           (5)转储频率

                 0:从不备份;

                 1:每天备份;

                 2:每隔一天备份;

            (6)自检次序

                 0:不自检;

                 1:首先自检,通常只是根文件系统可用1;

                 2:次级自检

                 ...

       mount -a:可自动挂载定义在此文件中的所有支持自动挂载的设备;

      (1)用LABEL自动挂载

          

        

      (2)用device自动挂载

           

       

俩个命令:df和du

       df命令:

           df [OPTION][FILE]

               -l:仅显示本地文件的相关信息;

               -h:human—readable

               -l:显示inode使用状态而非blocks

       du命令:

            du [OPTION][FILE]

              -s:sumary

              -h:human-readble

    Lunix磁盘及文件管理系统博主就总结到这里,今天是星期日,博主从下午开始总结到写博客,中间断断续续,现在已经感觉有一种精尽人亡的感觉了!那我们下节再见,我的心愿是世上再无心机婊。