AI智能
改变未来

Linux基础篇——Linux磁盘操作(磁盘基础知识、分类、分区、挂载、卸载、扩容)详解

目 录

  • 1. 概 念
  • 2. 为啥要分区
  • 3. 磁盘的结构
  • 4. 磁盘的分类
  • 4.1 IDE硬盘
  • 4.2 SCSI硬盘
  • 4.3 SATA硬盘
  • 4.4 固态硬盘
  • 5. 磁盘分区命名规则
  • 6. 磁盘分区类型及原理
    • 6.1 MBR(Master Boot Record)分区格式
    • 6.2 GPT(GUID Partition Table)分区格式
  • 7. 磁盘分区实操
    • 7.1 给虚拟机添加一块磁盘
    • 7.2 MBR方式分区实操
    • 7.2 GPT分区实操(大于2T的磁盘分区方法,小于也能用)
  • 8. 磁盘的格式化、手动挂载、自动挂载、卸载
    • 8.1 文件系统的类型
    • 8.2 格式化、手动挂载、自动挂载、卸载实操
  • 9. 两块磁盘空间合二为一,并挂载到同一目录下实现扩容
  • 10. 磁盘的查看命令
    • 10.1 df指令
    • 10.2 du指令

    1. 概 念

    图1.1 分区的概念

      假如你有个大木桶要装东西,如果木桶没有划分层,所有东西全部放入里面,虽然可以装,但是对大木桶的使用就合不合理,造成杂乱无章,寻找东西时候也耗时,甚至还有不同物品之间不能存放在一起而导致危险,那更好的做法自然是给大木桶画一下不同的区域,分成不同的层,每个层放不同的东西,即安全,寻找起来也方便;

      计算机的磁盘(也叫硬盘)也是如此,为了区分存储内容的不同,以及快速定位寻址文件,也需要采取分区的形式;

    2. 为啥要分区

      不论磁盘的分区还是数据库表的分区以及其它的分区,核心思想和分区的目的基本都一致,可以概括以下两点原因;

    • 数据的安全性隔离:因为每个分区是独立分开的,所以当你需要重现格式化或数据重新填充分区A时,分区B并不会受影响�这就是为啥你Windows重装系统的话,一般只是C盘重新载入新系统数据,而其他的D,E,F盘并不会受影响;

    • 系统的效率考虑:加快数据寻址的效率,当你只有一块分区时,找数据文件a你得重头找到尾部,但是当你分区了,操作系统会记录文件的绝对路径,你就可以直接从某个分区下去找,大大提升了速度和效率;

    3. 磁盘的结构

    图3.1 磁盘的整个组成
      如图3.1,磁盘的主要组成有:主轴(含承轴及马达),磁盘盘(可能有多个盘),磁头,磁头臂等; 主轴(含承轴及马达)负责让磁盘盘转起来,磁头负责读取数据,磁头臂负责将磁头接触到磁盘盘,当不读取数据时负责将磁头停在磁头停泊区;

      磁盘盘结构比较特殊,拿其中一块出来讲解,如图3.2;磁盘盘主要有:磁道,簇,扇面,扇区组成;一般的磁盘设计是磁头沿着磁道由外圈顺时针一直读取到内圈;将每个同心圆切割成一个个小小块,称为

    扇区

    ,

    是磁盘最小的存储单位!

    ,同心圆的扇区一起组成

    扇面

    ,而第一个扇面又显得重要些,它记录了整个磁盘的重要信息;

    3.2 磁盘盘组成示意图   刚刚说到,一般的磁盘不止一块磁盘盘,往往有多个,结构如图3.3;为了加快读写速度,也就会有多个磁头(读写头),磁头臂;同时多个磁盘盘的同一个磁道称为磁柱;

    3.3 多块磁盘盘组成示意图

    4. 磁盘的分类

    4.1 IDE硬盘

      目前(20210516)基本已经淘汰,做个大概了解,IDE即Integrated Drive Electronics,它的本意是指把控制器与盘体集成在一起的硬盘驱动器,IDE是表示硬盘的传输接口。我们常说的IDE接口,也叫ATA(Advanced Technology Attachment)、PATA接口,现在PC机使用的硬盘大多数都是IDE兼容的,只需用一根电缆将它们与主板或接口卡连起来就可以了。

    图4.1 IDE硬盘

    4.2 SCSI硬盘

      SCSI 硬盘即采用

    SCSI 接口

    的硬盘。它由于性能好、稳定性高,因此在服务器上得到广泛应用。同时其价格也不菲,正因它的价格昂贵,所以在普通PC上很少见到它的踪迹。SCSI 硬盘使用 50 针接口;

    图4.2 SCSI硬盘

    4.3 SATA硬盘

      SATA(Serial ATA)口的硬盘又叫串口硬盘,Serial ATA 采用串行连接方式,串行 ATA 总线使用嵌入式时钟信号,具备了更强的纠错能力,与以往相比其最大的区别在于能对传输指令(不仅仅是数据)进行检查,如果发现错误会自动矫正,这在很大程度上提高了数据传输的可靠性。串行接口还具有结构简单、支持热插拔的优点

    图4.3 SATA硬盘

    4.4 固态硬盘

      固态硬盘(Solid State Disk),一般称之为 SSD 硬盘,固态硬盘是用固态电子存储芯片阵列而制成的硬盘,由控制单元和存储单元(FLASH芯片、DRAM芯片)组成。其主要特点是没有传统硬盘的机械结构,读写速度非常快;其实,严格上来说固态硬盘不能算磁盘,因为他靠的存储技术是内存和闪存,而且并没有传统磁盘的组成结构,但是由于大家都叫习惯了,就采用了统一的命名;

    图4.4 固态硬盘

    5. 磁盘分区命名规则

      由于磁盘驱动的不同,磁盘可以分为IDE磁盘和SCSI硬盘,

    IDE硬盘基本已过时(对Linux服务器而言)

    ,而之前谈到的SATA、USB、SAS等硬盘的接口都是SCSI硬盘,所以这些都统称为SCSI硬盘,是目前Linux服务器的主流,在 Linux 系统中磁盘设备文件的命名规则为:
      

    主设备号 + 次设备号 + 磁盘分区号


      而Linux万物皆文件的个性,硬盘自然是映射再/dev/目录下,

    IDE硬盘

    /dev/hdx~

    ,

    SCSI硬盘

    /dev/sdx~

    ;

    • IDE硬盘 hdx~

      hd

      表明为设备类型,这里指

      IDE

      硬盘,

      x

      为盘号,值可以为a(基本盘),b(基本从属盘),c(辅助主盘),d(辅助从属盘);

      ~

      代表分区,前四个分区1-4表示,他们是主分区或者扩展分区,从5开始就是逻辑分区;例如:第一块盘hda,第二块盘hdb…第一块盘的第一个分区hda1,第二个分区hda2…

    • SCSI硬盘 sdx~

      sd

      表明为设备类型,这里指

      SCSI

      硬盘,

      x

      为盘号,值可以为a(基本盘),b(基本从属盘),c(辅助主盘),d(辅助从属盘);

      ~

      代表分区,前四个分区1-4表示,他们是主分区或者扩展分区,从5开始就是逻辑分区;例如:第一块盘sda,第二块盘sdb… 第一块盘的第一个分区sda1,第二个分区sda2…

      考虑到常用性,以下内容就以

    SCSI硬盘

    为主来讲;

    刚刚讲到的

    x

    ,那系统是怎么识别sda,sdb,sdc即磁盘1,磁盘2,磁盘3的呢?如在你的PC上,有两个SATA磁盘个一个USB磁盘,而这两个SATA磁盘分别放在SATA1和SATA5插槽上,USB磁盘则在USB接口上,那这三块磁盘的顺序是什么呢?
    其实,磁盘的顺序是靠侦测到的顺序来标识的;

    1. SATA1插槽上的为:/dev/sda
    2. SATA2插槽上的为:/dev/sdb
    3. USB(开机完成才能被系统捕捉到):/dev/sdc

    6. 磁盘分区类型及原理

    6.1 MBR(Master Boot Record)分区格式

      早期磁盘第一个扇区(

    521bytes

    )里面包含重要的信息

    MBR(Master Boot Record)

    ,其中

    446 bytes

    ,安装开机管理程序的地方;剩下的

    64bytes

    记录硬盘分区的数据,即分区表,大概示意图如图6.1;

    图6.1 MBR分区的示意图

      以下的四个分区我们并不能区分是主分区还是扩展分区,两种都有可能;

    • P1:/dev/sda1
    • P2:/dev/sda2
    • P3:/dev/sda3
    • P4:/dev/sda4

      既然第一个扇区的分区表只能记录四个分区的数据,那自然就想到用额外的扇区来 记录分区信息,这就是扩展分区的由来,如图6.2,分区情况应该为;

    图6.2 MBR分区扩展分区示意图
      以上的分区情况为如下,为啥缺少了

    /dev/sda3

    /dev/sda4

    呢,原因就是前面四个号都是预留给主分区和逻辑分区的;

    • P1:/dev/sda1 (主分区)
    • P2:/dev/sda2(扩展分区)
    • P3:/dev/sda5(逻辑分区)
    • P4:/dev/sda6(逻辑分区)
    • P5:/dev/sda7(逻辑分区)
    • P6:/dev/sda8(逻辑分区)
    • P7:/dev/sda9(逻辑分区)

      主分区、扩展分区、逻辑分区的总结内容如下;

    1. 主分区( primary)P

      1)系统中必须要存在的分区,系统盘选择主分区安装

      2)数字编号只能是1-4.sda1、sda2、sda3、sda4

      3)主分区最多四个,最少一个。

      4)能被单独格式化

    1. 扩展分区( extend)E

      1)相当于一个独立的小磁盘。独立的分区表,不能独立存在。

      2)有独立的分区表。

      3)不能独立存在,即不能直接存放数据

      4)必须在扩展分区上建立逻辑分区才能存放数据

      5)占用主分区的编号(主分区+扩展分区)之和最多4个

      6)不能被格式化

    1. 逻辑分区(1ogic)L

      1)数字编号只能是从5开始

      2)存放于扩展分区之上

      3)存放任意普通数据

      4)能被单独格式化

      5)两个独立的逻辑分区可以支持合并成一个新的逻辑分区

    1. 磁盘分区方式

      1)1~4个主分区

      2)扩展分区至多能有一个,且 2 ≤ 扩展分区+主分区≤ 4

    学习以上内容后,聊聊分区策略,举例如下;
    博主有一块硬盘,如果我想要得到6个分区,用MBR分区格式该怎么分配;
    首先主分区,扩展分区只能有4个,不够呀,那就需要用到扩展分区,可以分配为,P+P+P+E(E内包含3个逻辑分区L)即,P+P+P+E(L+L+L);当然也可以P+E(L+L+L+L+L) ,可以根据个人想法来实现即可

      

    MBR

    分区的原理清晰后,其不足的地方也暴露的无疑,因为分区表的容量16bytes有限,始终存在以下不足;

    • 操作系统无法抓取2.2T以上的磁盘容量,个人PC可能目前来说够,但是服务器已经无法满足了;
    • MBR仅有一块分区表,无法实现高可用,一旦被损坏,很难再救援恢复;
    • MBR内存放的开机管理程序也只有446bytes,也是无法容纳更多的开机程序代码的;

       你的不努力或者局限,自然就有新星的出现,于是GPT就出现了;

    6.2 GPT(GUID Partition Table)分区格式

       GPT将磁盘划分为一块块的

    逻辑区块地址(Logical Block Address,简称LBA)

    来处理,每个LBA预设计为512bytes,即一个扇区的大小;同时改进MBR之用一块扇区来标识分区表的弊端,GPT使用了前后各34个LBA来标识分区表信息(最后的34各区可以理解为备份,达到高可用),如图6.3;
    LBA的标识是从0开始的,LBA0-34共35块,这里分别阐述下其含义;

    • LBA0

      :包含两部分,一部分是类似MBR的446bytes,存储开机管理程序,第二部分则是存储一个特殊的标记,标识该磁盘为GPT格式,而看不懂GPT分区的程序则无法操作该磁盘,起到保护作用,放心,目前基本的管理程序都能识别GPT格式,所以该LBA块实际上与分区信息并无直接关联,这就是为啥不算入34LBA的原因;

    • LBA1

      :GPT的表头,记录分区本身的位置与大小,同时记录分区在备份中最后34个LBA中的位置,方便恢复;

    • LBA2-34

      :共32块LBA,每块LBA记录4笔分区表,共支持4*23=128笔分区;而每个LBA默认为512bytes,则每笔记录用到512/4=128bytes,每笔记录拿出64bytes来记录开始、结束的扇区号码,因此对一个单一分区槽而言,支持的最大容量为264∗512bytes=263∗1Kbytes=233TB=8ZB2^{64}*512bytes=2^{63}*1Kbytes=2^{33}TB=8ZB264∗512bytes=263∗1Kbytes=233TB=8ZB
      注:
      1ZB=230TB1 ZB = 2^{30} TB1ZB=230TB

    6.3 GPT分区示意图

      因此基本上GPT弥补了MBR的不足,但是GPT只是分区格式方法不同哈,以SCSI硬盘为例,磁盘的命名规则并没有大改;仍然是第一块盘sda,第二块盘sdb… 第一块盘的第一个分区sda1,第二个分区sda2等,但是GPR去除了扩展分区的概念,直接分区为主分区和逻辑分区;
       以上就是分区的理论支持,接下来进入分区实操环节;

    7. 磁盘分区实操

    7.1 给虚拟机添加一块磁盘

      这里就采用虚拟机来模拟添加磁盘,博主用的虚拟机是VMware,操作如下;

    1. 因为是添加硬件,需要先关闭虚拟机。点击
      关机

      。如图7.1;

    图7.1 关闭虚拟机

    1. 然后选中虚拟机,鼠标右键,点击
      设置

      ,如图7.2;

    图7.2 点击设置

    1. 跳转图7.3,选择
      硬盘

      ,点击

      下一步

      ;

    图7.3 添加硬盘

    1. 跳转图7.4,选择
      SCSI(S)

      ,点击

      下一步

      ;

    图7.4 选择SCSI硬盘

    1. 跳转图7.5,设置硬盘的大小,这里为了说明问题,博主就选默认的20G,点击
      下一步

      ;

    图7.5 选择硬盘大小

    1. 跳转图7.6,选择
      创建新虚拟磁盘(V)

      ,点击

      下一步

      ;

    图7.6 选择创建新虚拟磁盘

    1. 跳转图7.7,给磁盘文件命名,这个没关系,博主采用默认的,点击
      完成

      ;

    图7.7 给磁盘文件命名

    1. 跳转图7.8,点击
      确定

      完成硬盘的增加,然后记得开机;
      图7.5 选择硬盘大小

    7.2 MBR方式分区实操

      开机后利用指令

    lsblk(老师不离开)

    ,可以看到磁盘

    sdb

    就是刚刚添加的磁盘,无分区情况;

    sda

    就是之前安装虚拟机设置的磁盘,有两个分区

    sda1

    sda2

    [hadoop@node2 ~]$ lsblkNAME            MAJ:MIN RM  SIZE RO TYPE MOUNTPOINTsda               8:0    0   60G  0 disk├─sda1            8:1    0    1G  0 part /boot└─sda2            8:2    0   59G  0 part├─centos-root 253:0    0 38.3G  0 lvm  /├─centos-swap 253:1    0    2G  0 lvm  [SWAP]└─centos-home 253:2    0 18.7G  0 lvm  /homesdb               8:16   0   20G  0 disksr0              11:0    1  4.4G  0 rom# 也可以用fdisk来查看磁盘[root@node2 /]# fdisk -l磁盘 /dev/sda:64.4 GB, 64424509440 字节,125829120 个扇区Units = 扇区 of 1 * 512 = 512 bytes扇区大小(逻辑/物理):512 字节 / 512 字节I/O 大小(最小/最佳):512 字节 / 512 字节磁盘标签类型:dos磁盘标识符:0x0001d6b8设备 Boot      Start         End      Blocks   Id  System/dev/sda1   *        2048     2099199     1048576   83  Linux/dev/sda2         2099200   125829119    61864960   8e  Linux LVM磁盘 /dev/sdb:21.5 GB, 21474836480 字节,41943040 个扇区Units = 扇区 of 1 * 512 = 512 bytes扇区大小(逻辑/物理):512 字节 / 512 字节I/O 大小(最小/最佳):512 字节 / 512 字节磁盘 /dev/mapper/centos-root:41.1 GB, 41120956416 字节,80314368 个扇区Units = 扇区 of 1 * 512 = 512 bytes扇区大小(逻辑/物理):512 字节 / 512 字节I/O 大小(最小/最佳):512 字节 / 512 字节磁盘 /dev/mapper/centos-swap:2147 MB, 2147483648 字节,4194304 个扇区Units = 扇区 of 1 * 512 = 512 bytes扇区大小(逻辑/物理):512 字节 / 512 字节I/O 大小(最小/最佳):512 字节 / 512 字节磁盘 /dev/mapper/centos-home:20.1 GB, 20073938944 字节,39206912 个扇区Units = 扇区 of 1 * 512 = 512 bytes扇区大小(逻辑/物理):512 字节 / 512 字节I/O 大小(最小/最佳):512 字节 / 512 字节

      接下来开始采用MBR的方式进行分区,用到指令

    fdisk

    ;

    要求:给20G的新磁盘分区,要求为P(5G)+P(5G)+L(5G)+L(5G);
    即,两个主分区,每个5G,两个逻辑分区,每个5G,之前说过逻辑分区不能单独存在,必须搭载扩展分区,所以实际情况应该是两个主分区,每个5G,一个扩展分区10G,扩展分区里面两个逻辑分区,每个5G

      操作如下;

    # fdisk /dev/sdb指令进入分区操作的交互命令行[root@node2 hadoop]# fdisk /dev/sdb欢迎使用 fdisk (util-linux 2.23.2)。更改将停留在内存中,直到您决定将更改写入磁盘。使用写入命令前请三思。Device does not contain a recognized partition table使用磁盘标识符 0xcc9206a3 创建新的 DOS 磁盘标签。命令(输入 m 获取帮助):# 输入m活的操作提示命令操作a   toggle a bootable flagb   edit bsd disklabelc   toggle the dos compatibility flagd   delete a partitiong   create a new empty GPT partition tableG   create an IRIX (SGI) partition tablel   list known partition typesm   print this menun   add a new partitiono   create a new empty DOS partition tablep   print the partition tableq   quit without saving changess   create a new empty Sun disklabelt   change a partition's system idu   change display/entry unitsv   verify the partition tablew   write table to disk and exitx   extra functionality (experts only)# 根据提示输入n add a new partition命令(输入 m 获取帮助):nPartition type:p   primary (0 primary, 0 extended, 4 free)e   extended# 这里p是主分区,e为拓展分区,先来个主分区,选择pSelect (default p): p分区号 (1-4,默认 1):1# 这里跳转到选择分区号,之前理论讲过MBR只能有四个主或扩展分区,因为是新的分区,这里选择1即可;起始 扇区 (2048-41943039,默认为 2048):将使用默认值 2048# 这里选择起始的扇区,选择默认的即可Last 扇区, +扇区 or +size{K,M,G} (2048-41943039,默认为 41943039):+5G分区 1 已设置为 Linux 类型,大小设为 5 GiB# 这里选择结束的扇区,如果你选择默认的,那么就是将整块磁盘给到一个分区,# 这里磁盘有20G,我们可以来个5G的,选择+5G,就是给第一个分区5G空间# 这里还没完,还需要写入w,则完成分区1分区;命令(输入 m 获取帮助):wThe partition table has been altered!Calling ioctl() to re-read partition table.正在同步磁盘。# 完成同步后会自动退出,再次使用lsblk指令查看,发现已经多了sdb1[root@node2 hadoop]# lsblkNAME            MAJ:MIN RM  SIZE RO TYPE MOUNTPOINTsda               8:0    0   60G  0 disk├─sda1            8:1    0    1G  0 part /boot└─sda2            8:2    0   59G  0 part├─centos-root 253:0    0 38.3G  0 lvm  /├─centos-swap 253:1    0    2G  0 lvm  [SWAP]└─centos-home 253:2    0 18.7G  0 lvm  /homesdb               8:16   0   20G  0 disk└─sdb1            8:17   0    5G  0 partsr0              11:0    1  4.4G  0 rom# 再来创建第二个主分区[root@node2 hadoop]# fdisk /dev/sdb欢迎使用 fdisk (util-linux 2.23.2)。更改将停留在内存中,直到您决定将更改写入磁盘。使用写入命令前请三思。命令(输入 m 获取帮助):nPartition type:p   primary (1 primary, 0 extended, 3 free)e   extended# 选择p表示创建第二个主分区Select (default p): p# 这里自动选择序号2,因为1已经被第一个主分区占用分区号 (2-4,默认 2):2# 其实位置选择默认即可起始 扇区 (10487808-41943039,默认为 10487808):将使用默认值 10487808# 结束扇区依然选择5GLast 扇区, +扇区 or +size{K,M,G} (10487808-41943039,默认为 41943039):+5G分区 2 已设置为 Linux 类型,大小设为 5 GiB# w指令保存磁盘修改命令(输入 m 获取帮助):wThe partition table has been altered!Calling ioctl() to re-read partition table.正在同步磁盘。# lsblk指令得到第二块主分区sbd2[root@node2 hadoop]# lsblkNAME            MAJ:MIN RM  SIZE RO TYPE MOUNTPOINTsda               8:0    0   60G  0 disk├─sda1            8:1    0    1G  0 part /boot└─sda2            8:2    0   59G  0 part├─centos-root 253:0    0 38.3G  0 lvm  /├─centos-swap 253:1    0    2G  0 lvm  [SWAP]└─centos-home 253:2    0 18.7G  0 lvm  /homesdb               8:16   0   20G  0 disk├─sdb1            8:17   0    5G  0 part└─sdb2            8:18   0    5G  0 partsr0              11:0    1  4.4G  0 rom# 接下来是创建拓展分区和逻辑分区[root@node2 hadoop]# fdisk /dev/sdb欢迎使用 fdisk (util-linux 2.23.2)。更改将停留在内存中,直到您决定将更改写入磁盘。使用写入命令前请三思。命令(输入 m 获取帮助):nPartition type:p   primary (2 primary, 0 extended, 2 free)e   extended# 选择e表示拓展分区,编号可以选择默认的3Select (default p): e分区号 (3,4,默认 3):3# 起始扇区选择默认的位置起始 扇区 (20973568-41943039,默认为 20973568):将使用默认值 20973568# 剩下的所有磁盘分给这个拓展分区Last 扇区, +扇区 or +size{K,M,G} (20973568-41943039,默认为 41943039):将使用默认值 41943039分区 3 已设置为 Extended 类型,大小设为 10 GiB# 记得写入w保存磁盘更改命令(输入 m 获取帮助):wThe partition table has been altered!Calling ioctl() to re-read partition table.正在同步磁盘。# 之前理论说过,扩展分区是不能单独存在的,必须要有逻辑分区在里面,接下来再来两次,创建逻辑分区[root@node2 hadoop]# fdisk /dev/sdb欢迎使用 fdisk (util-linux 2.23.2)。更改将停留在内存中,直到您决定将更改写入磁盘。使用写入命令前请三思。命令(输入 m 获取帮助):n# 这里你会发现,多了个l(logic) 的选项,即逻辑分区的意思,这里记得选lPartition type:p   primary (2 primary, 1 extended, 1 free)l   logical (numbered from 5)Select (default p): l添加逻辑分区 5# 选择默认的起始扇区起始 扇区 (20975616-41943039,默认为 20975616):将使用默认值 20975616# 第一个逻辑分区为5GLast 扇区, +扇区 or +size{K,M,G} (20975616-41943039,默认为 41943039):+5G# 默认逻辑分区从编号5开始,因为1-4要预留给到主分区和扩展分区分区 5 已设置为 Linux 类型,大小设为 5 GiB# 记得保存磁盘更改,写入w;命令(输入 m 获取帮助):wThe partition table has been altered!Calling ioctl() to re-read partition table.正在同步磁盘。# 再来一次,创建 第二块逻辑分区[root@node2 hadoop]# fdisk /dev/sdb欢迎使用 fdisk (util-linux 2.23.2)。更改将停留在内存中,直到您决定将更改写入磁盘。使用写入命令前请三思。命令(输入 m 获取帮助):nPartition type:p   primary (2 primary, 1 extended, 1 free)l   logical (numbered from 5)Select (default p): l添加逻辑分区 6起始 扇区 (31463424-41943039,默认为 31463424):将使用默认值 31463424# 使用默认的结束扇区,即将剩下的扩展分区的空间全部给到第二个逻辑分区Last 扇区, +扇区 or +size{K,M,G} (31463424-41943039,默认为 41943039):将使用默认值 41943039分区 6 已设置为 Linux 类型,大小设为 5 GiB命令(输入 m 获取帮助):wThe partition table has been altered!Calling ioctl() to re-read partition table.正在同步磁盘。# 到此,主分区,扩展分区,逻辑分区的分区操作就算完了;切忌使用前还需要进行格式化,# 格式化的操作再下个小结挂载的时候再细讲# 使用lsblk查看刚刚的主分区,扩展分区,逻辑分区的分区操作的结果,# 发现完全符合之前MBR分区的理论和我们的预期[root@node2 hadoop]# lsblkNAME            MAJ:MIN RM  SIZE RO TYPE MOUNTPOINTsda               8:0    0   60G  0 disk├─sda1            8:1    0    1G  0 part /boot└─sda2            8:2    0   59G  0 part├─centos-root 253:0    0 38.3G  0 lvm  /├─centos-swap 253:1    0    2G  0 lvm  [SWAP]└─centos-home 253:2    0 18.7G  0 lvm  /homesdb               8:16   0   20G  0 disk├─sdb1            8:17   0    5G  0 part├─sdb2            8:18   0    5G  0 part├─sdb3            8:19   0    1K  0 part├─sdb5            8:21   0    5G  0 part└─sdb6            8:22   0    5G  0 partsr0              11:0    1  4.4G  0 rom# 其他重要指令# 发现分区操作失误,可以d删除指令d   delete a partition

    7.2 GPT分区实操(大于2T的磁盘分区方法,小于也能用)

      之前说过

    MBR

    分区格式,即对应的

    fdisk

    操作有局限就是大于2T的磁盘无法使用该理论和方法,那个人PC可能觉得2T完全满足,但是服务器2T肯定是不足的,因此学习下GPT的分区方法也是很有必要的,使用的指令为

    parted

    ,博主比较穷,私人是没有2T的硬盘的,这里就用一个20G的来模拟,实现以下要求;

    要求:给20G的新磁盘分区,要求为P(5G)+P(5G)+L(5G)+L(5G);
    即,两个主分区,每个5G,两个逻辑分区,每个5G,之前说过逻辑分区不能单独存在,必须搭载扩展分区,所以实际情况应该是两个主分区,每个5G,一个扩展分区10G,扩展分区里面两个逻辑分区,每个5G

      操作如下;

    # 使用lsblk查看刚刚新增的磁盘sdc[root@node2 hadoop]# lsblkNAME            MAJ:MIN RM  SIZE RO TYPE MOUNTPOINTsda               8:0    0   60G  0 disk├─sda1            8:1    0    1G  0 part /boot└─sda2            8:2    0   59G  0 part├─centos-root 253:0    0 38.3G  0 lvm  /├─centos-swap 253:1    0    2G  0 lvm  [SWAP]└─centos-home 253:2    0 18.7G  0 lvm  /homesdb               8:16   0   20G  0 disk├─sdb1            8:17   0    5G  0 part├─sdb2            8:18   0    5G  0 part├─sdb3            8:19   0    1K  0 part├─sdb5            8:21   0    5G  0 part└─sdb6            8:22   0    5G  0 partsdc               8:32   0   20G  0 disksr0              11:0    1  4.4G  0 rom# 进行parted分区# 使用parted /dev/sdc进入交互的parted命令行[root@node2 hadoop]#  parted /dev/sdcGNU Parted 3.1使用 /dev/sdcWelcome to GNU Parted! Type 'help' to view a list of commands.(parted)# 输入p查看当前分区,发现为0个分区(parted) pModel: VMware, VMware Virtual S (scsi)Disk /dev/sdc: 21.5GBSector size (logical/physical): 512B/512BPartition Table: gptDisk Flags:Number  Start  End  Size  File system  Name  标志# 将MBR磁盘格式化为GPT(parted) mklabel gpt# 创建第一个主分区(parted) mkpart primary 0 5G警告: The resulting partition is not properly aligned for best performance.忽略/Ignore/放弃/Cancel? Ignore# 查看当前磁盘分区情况,发现第一个主分区成功(parted) pModel: VMware, VMware Virtual S (scsi)Disk /dev/sdc: 21.5GBSector size (logical/physical): 512B/512BPartition Table: gptDisk Flags:Number  Start   End     Size    File system  Name     标志1      17.4kB  5000MB  5000MB               primary# 创建第二个主分区(parted) mkpart primary 5G 10G# 输入p查看第二个主分区(parted) pModel: VMware, VMware Virtual S (scsi)Disk /dev/sdc: 21.5GBSector size (logical/physical): 512B/512BPartition Table: gptDisk Flags:Number  Start   End     Size    File system  Name     标志1      17.4kB  5000MB  5000MB               primary2      5001MB  10.0GB  5000MB               primary# 创建第三个逻辑分区,理论篇说过GPT分区,逻辑分区不需要以扩展分区为载体,所以这里没有扩展分区(parted) mkpart logic 10G 15G# 输入p查看第一个个逻辑分区(parted) pModel: VMware, VMware Virtual S (scsi)Disk /dev/sdc: 21.5GBSector size (logical/physical): 512B/512BPartition Table: gptDisk Flags:Number  Start   End     Size    File system  Name     标志1      17.4kB  5000MB  5000MB               primary2      5001MB  10.0GB  5000MB               primary3      10.0GB  15.0GB  5000MB               logic# 创建第2个逻辑分区(parted) mkpart logic 15G 20G# 输入p查看当前分区(parted) pModel: VMware, VMware Virtual S (scsi)Disk /dev/sdc: 21.5GBSector size (logical/physical): 512B/512BPartition Table: gptDisk Flags:Number  Start   End     Size    File system  Name     标志1      17.4kB  5000MB  5000MB               primary2      5001MB  10.0GB  5000MB               primary3      10.0GB  15.0GB  5000MB               logic4      15.0GB  20.0GB  5000MB               logic# 也可以使用print查看当前分区(parted) printModel: VMware, VMware Virtual S (scsi)Disk /dev/sdc: 21.5GBSector size (logical/physical): 512B/512BPartition Table: gptDisk Flags:Number  Start   End     Size    File system  Name     标志1      17.4kB  5000MB  5000MB               primary2      5001MB  10.0GB  5000MB               primary3      10.0GB  15.0GB  5000MB               logic4      15.0GB  20.0GB  5000MB               logic# 退出parted交互命令行(parted) quit信息: You may need to update /etc/fstab.# 利用lsblk查看刚刚的gpt分区[root@node2 hadoop]# lsblkNAME            MAJ:MIN RM  SIZE RO TYPE MOUNTPOINTsda               8:0    0   60G  0 disk├─sda1            8:1    0    1G  0 part /boot└─sda2            8:2    0   59G  0 part├─centos-root 253:0    0 38.3G  0 lvm  /├─centos-swap 253:1    0    2G  0 lvm  [SWAP]└─centos-home 253:2    0 18.7G  0 lvm  /homesdb               8:16   0   20G  0 disk├─sdb1            8:17   0    5G  0 part├─sdb2            8:18   0    5G  0 part├─sdb3            8:19   0    1K  0 part├─sdb5            8:21   0    5G  0 part└─sdb6            8:22   0    5G  0 partsdc               8:32   0   20G  0 disk├─sdc1            8:33   0  4.7G  0 part├─sdc2            8:34   0  4.7G  0 part├─sdc3            8:35   0  4.7G  0 part└─sdc4            8:36   0  4.7G  0 partsr0              11:0    1  4.4G  0 rom# parted分区指令的其他命令# 划分所有空间到一个分区(parted) mkpart primary 0-1# 如果要反过来.将GPT磁盘转化为MBR磁盘(parted) mklable msdos

    8. 磁盘的格式化、手动挂载、自动挂载、卸载

    8.1 文件系统的类型

      Linux:存在几十个文件系统类型:ext2,ext3,ext4,xfs,brtfs等,不同文件系统采用不同的方法来管理磁盘空间,各有优劣;文件系统是具体到分区的,所以格式化针对的是分区,分区格式化是指采用指定的文件系统类型对分区空间进行登记、索引并建立相应的管理表格的过程。

    • ext2具有极快的速度和极小的CPU占用率,可用于硬盘和移动存储设备
    • ext3增加日志功能,可回溯追踪
    • ext4日志式文件系统,支持1EB(1024*1024TB),最大单文件16TB,支持连续写入可减少文件碎片。rhel6默认文件系统
    • xfs可以管理500T的硬盘。rhel7默认文件系统
    • brtfs文件系统针对固态盘做优化;

    8.2 格式化、手动挂载、自动挂载、卸载实操

      怎么多怎么记呢,其实很简单, ext一代比一代强,目前要用当然是 ext4, xfs又是更强的文件系统,CentOS7默认的文件系统,如果你的系统支持,优选xfs,再是ext4吧,当然如果是固态硬盘,可以考虑brtfs;
      磁盘的格式化,是精确到每个分区的;磁盘分区在使用前,必须先格式化以下,然后具体怎么用呢;具体步骤如下;

    1. 格式化磁盘分区
    2. 将磁盘分区挂载到一个文件夹下,其实可以理解为将文件夹映射到该分区下,当有文件存入该文件夹,则实际就存入了该磁盘的分区;
    3. 挂载分为手动挂载和自动挂载,手动挂载,则开启重启后会失效,自动挂载则在开机的时候给你挂好,让使用者无感;
    4. 有时候不需要该分区,则需要先卸载该分区对应的文件夹,再删除分区,则为卸载操作;

      下面进入实操环节;

    # 在根目录下新建一个myfile目录作为挂载的目录cd /mkdir file# 格式化sdc2分区,选用文件系统问目前最优的xfs# 注意,/dev/sdc2一定要带上2,一定要带上2,一定要带上2# 不带上什么意思,就是格式化整个磁盘,结果就是你之前做的sdc的分区全部白费了mkfs.xfs /dev/sdc2# 手动挂载[root@node2 /]# mount /dev/sdc2 file/# 查看挂载情况,发现sdc2后面已经挂在了/file[root@node2 /]# lsblkNAME            MAJ:MIN RM  SIZE RO TYPE MOUNTPOINTsda               8:0    0   60G  0 disk├─sda1            8:1    0    1G  0 part /boot└─sda2            8:2    0   59G  0 part├─centos-root 253:0    0 38.3G  0 lvm  /├─centos-swap 253:1    0    2G  0 lvm  [SWAP]└─centos-home 253:2    0 18.7G  0 lvm  /homesdb               8:16   0   20G  0 disksdc               8:32   0   20G  0 disk├─sdc1            8:33   0  4.7G  0 part├─sdc2            8:34   0  4.7G  0 part /file├─sdc3            8:35   0  4.7G  0 part└─sdc4            8:36   0  4.7G  0 partsr0              11:0    1  4.4G  0 rom# 磁盘卸载# 使用umount卸载分区时,可以指定挂载点,也可以指定挂载的路径umount /dev/sdc1# 或者等价于umount /file# 此时关机重启下,再lsblk指令,返现该手动挂载的目录失效了[root@node2 hadoop]# lsblkNAME            MAJ:MIN RM  SIZE RO TYPE MOUNTPOINTsda               8:0    0   60G  0 disk├─sda1            8:1    0    1G  0 part /boot└─sda2            8:2    0   59G  0 part├─centos-root 253:0    0 38.3G  0 lvm  /├─centos-swap 253:1    0    2G  0 lvm  [SWAP]└─centos-home 253:2    0 18.7G  0 lvm  /homesdb               8:16   0   20G  0 disksdc               8:32   0   20G  0 disk├─sdc1            8:33   0  4.7G  0 part├─sdc2            8:34   0  4.7G  0 part├─sdc3            8:35   0  4.7G  0 part└─sdc4            8:36   0  4.7G  0 partsr0              11:0    1  4.4G  0 rom# 因此要实现自动挂载# 手动挂载[root@node2 /]# mount /dev/sdc2 file/# 获取sdc1的UUID[root@node2 /]# blkid /dev/sdc2/dev/sdc2: UUID="2b9fa094-078c-4c38-8b1f-d15986f6eb96" TYPE="xfs" PARTLABEL="primary" PARTUUID="83532884-4d4b-40d0-a9b3-4b85adc2ddd3"# 编辑/etc/fstab文件,加入新的分区挂载vim /etc/fstab# 最后一行追加刚刚的磁盘挂载## /etc/fstab# Created by anaconda on Sat Apr 11 20:27:09 2020## Accessible filesystems, by reference, are maintained under '/dev/disk'# See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info#/dev/mapper/centos-root /                       xfs     defaults        0 0UUID=ee1291e7-1efb-4872-b874-c51bf0007866 /boot                   xfs     defaults        0 0/dev/mapper/centos-home /home                   xfs     defaults        0 0# 上面为系统自带,别理,下面添加这句/dev/mapper/centos-swap swap                    swap    defaults        0 0UUID=2b9fa094-078c-4c38-8b1f-d15986f6eb96 /file xfs     defaults        0 0# 注意,如果不用UUID,用磁盘设备名称也可,以下信息等价/dev/sdc1               /file                   xfs     defaults        0 0#以上就完成了磁盘的自动挂载,可以开机重启验证下

    9. 两块磁盘空间合二为一,并挂载到同一目录下实现扩容

      服务器预算中希望有个文件夹有10T,但是手上只有两块5T的磁盘,怎么办呢,能不能把两块5T的磁盘同时挂载到同一个文件夹呢?答案当然是可以的;
      那博主比较穷,自热是没有5T的磁盘,那就那两个20G的凑合下吧,实现同时挂载到一个目录下,实现该目录40G的存储空间;

    要求将两块20G的磁盘sdb,sdc,同时挂载到目录mydata下,是的目录mydata的存储空间为40G;

      下面进入实操环节;

    # 这里也采用GPT的分区方法,使用parted指令[root@node3 hadoop]# parted /dev/sdbGNU Parted 3.1使用 /dev/sdbWelcome to GNU Parted! Type 'help' to view a list of commands.# 将磁盘转换成gpt(parted) mklabel gpt#这里反正要合并,就设置一个主分区包含整个磁盘(parted) mkpart primary 0 100%警告: The resulting partition is not properly aligned for best performance.忽略/Ignore/放弃/Cancel? Ignore(parted) pModel: VMware, VMware Virtual S (scsi)Disk /dev/sdb: 21.5GBSector size (logical/physical): 512B/512BPartition Table: gptDisk Flags:Number  Start   End     Size    File system  Name     标志1      17.4kB  21.5GB  21.5GB               primary# 同理对磁盘/dev/sbc进行相同的操作[root@node3 hadoop]# parted /dev/sdcGNU Parted 3.1使用 /dev/sdcWelcome to GNU Parted! Type 'help' to view a list of commands.(parted) mklabel gpt(parted) mkpart primart 0 100%警告: The resulting partition is not properly aligned for best performance.忽略/Ignore/放弃/Cancel? I(parted) pModel: VMware, VMware Virtual S (scsi)Disk /dev/sdc: 21.5GBSector size (logical/physical): 512B/512BPartition Table: gptDisk Flags:Number  Start   End     Size    File system  Name     标志1      17.4kB  21.5GB  21.5GB               primart(parted) quit信息: You may need to update /etc/fstab.# 得到目前的磁盘分布如下[root@node3 hadoop]# lsblkNAME            MAJ:MIN RM  SIZE RO TYPE MOUNTPOINTsda               8:0    0   60G  0 disk├─sda1            8:1    0    1G  0 part /boot└─sda2            8:2    0   59G  0 part├─centos-root 253:0    0 38.3G  0 lvm  /├─centos-swap 253:1    0    2G  0 lvm  [SWAP]└─centos-home 253:2    0 18.7G  0 lvm  /homesdb               8:16   0   20G  0 disk└─sdb1            8:17   0   20G  0 partsdc               8:32   0   20G  0 disk└─sdc1            8:33   0   20G  0 partsdd               8:48   0   20G  0 disksr0              11:0    1  4.4G  0 rom# 创建物理卷的命令为pvcreate;利用该命令将希望添加到卷组的所有分区或磁盘创建为物理卷;[root@node3 hadoop]# pvcreate /dev/sdb1Physical volume "/dev/sdb1" successfully created.# 将分区/dev/sdb1和/dev/sdc1分区创建为物理卷:[root@node3 hadoop]# pvcreate /dev/sdc1Physical volume "/dev/sdc1" successfully created.#创建卷组的命令为vgcreate;用此命令将使用pvcreate建立的物理卷创建为一个完整的卷组;#将物理卷/dev/sdb1创建为一个名为vgmysql的卷组:[root@node3 hadoop]# vgcreate vgmygroup1 /dev/sdb1Volume group "vgmygroup1" successfully created#此步即为将2块磁盘空间合二为一的关键步骤;当系统中新增了磁盘或新建了物理卷,而要将其添加到已有卷组时,就可使用vgextend命令;# 将物理卷/dev/sdc1添加到vgmysql卷组中:[root@node3 hadoop]# vgextend vgmygroup1 /dev/sdc1Volume group "vgmygroup1" successfully extended# 查看卷组用vgs,从vgs命令的回显结果来看,卷组vgmysql成功添加# 并且其总空间为两块物理磁盘的总大小(因换算单位不同,所以不是精确的40G)。[root@node3 hadoop]# vgsVG         #PV #LV #SN Attr   VSize   VFreecentos       1   3   0 wz--n- <59.00g  4.00mvgmygroup1   2   0   0 wz--n-  39.99g 39.99g# 创建逻辑卷的命令为lvcreate;用此命令将在使用vgcreate建立的卷组上创建逻辑卷;# 在卷组vgmysql上创建一个名为lvmysql的逻辑卷,起大小为 39.99G;# -n:指定逻辑卷名# -L:指定逻辑卷大小[root@node3 hadoop]# lvcreate -L 39.99g -n lvmygroup vgmygroup1Rounding up size to full physical extent 39.99 GiBLogical volume "lvmygroup" created.# 将创建的lvmysql逻辑卷格式化为xfs[root@node3 hadoop]# mkfs -t xfs /dev/vgmygroup1/lvmygroupmeta-data=/dev/vgmygroup1/lvmygroup isize=512    agcount=4, agsize=2620928 blks=                       sectsz=512   attr=2, projid32bit=1=                       crc=1        finobt=0, sparse=0data     =                       bsize=4096   blocks=10483712, imaxpct=25=                       sunit=0      swidth=0 blksnaming   =version 2              bsize=4096   ascii-ci=0 ftype=1log      =internal log           bsize=4096   blocks=5119, version=2=                       sectsz=512   sunit=0 blks, lazy-count=1realtime =none                   extsz=4096   blocks=0, rtextents=0# 切换到根目录,在根目录下新建文件夹[root@node3 hadoop]# cd /[root@node3 /]# mkdir mydata# 挂载刚刚的逻辑组到新建目录下[root@node3 /]# mount /dev/vgmygroup1/lvmygroup /mydata/# 查看磁盘大小和挂载磁盘查看,目录为40G[root@node3 /]# df -h文件系统                          容量  已用  可用 已用% 挂载点devtmpfs                          475M     0  475M    0% /devtmpfs                             487M     0  487M    0% /dev/shmtmpfs                             487M  7.8M  479M    2% /runtmpfs                             487M     0  487M    0% /sys/fs/cgroup/dev/mapper/centos-root            39G  4.3G   35G   12% //dev/sda1                        1014M  137M  878M   14% /boot/dev/mapper/centos-home            19G   33M   19G    1% /hometmpfs                              98M     0   98M    0% /run/user/2000tmpfs                              98M     0   98M    0% /run/user/0/dev/mapper/vgmygroup1-lvmygroup   40G   33M   40G    1% /mydata# 创建开机自动挂载[root@node3 /]# echo /dev/mapper/vgmygroup1-lvmygroup /mydata/ xfs defaults 0 0 >/etc/fstab# 重启重新查看挂载的磁盘,确认成功自动开机挂载[root@node3 ~]# sync[root@node3 ~]# reboot# 使用df -h指令再次查看,发现完成自动挂载[root@node3 ~]# df -h文件系统                          容量  已用  可用 已用% 挂载点devtmpfs                          475M     0  475M    0% /devtmpfs                             487M     0  487M    0% /dev/shmtmpfs                             487M  7.8M  479M    2% /runtmpfs                             487M     0  487M    0% /sys/fs/cgroup/dev/mapper/centos-root            39G  4.3G   35G   12% //dev/mapper/vgmygroup1-lvmygroup   40G   33M   40G    1% /mydatatmpfs                              98M     0   98M    0% /run/user/098M     0   98M    0% /run/user/2000

    10. 磁盘的查看命令

    10.1 df指令

    df

      

    df

    命令参数功能:检查文件系统的磁盘空间占用情况。可以利用该命令来获取硬盘被占用了多少空间,目前还剩下多少空间等信息。

    语法:

    df [-ahikHTm] [目录或文件名]

      选项与参数:

    -a :列出所有的文件系统,包括系统特有的 /proc 等文件系统;-k :以 KBytes 的容量显示各文件系统;-m :以 MBytes 的容量显示各文件系统;-h :以人们较易阅读的 GBytes, MBytes, KBytes 等格式自行显示;-H :以 M=1000K 取代 M=1024K 的进位方式;-T :显示文件系统类型, 连同该 partition 的 filesystem 名称 (例如 ext3) 也列出;-i :不用硬盘容量,而以 inode 的数量来显示

      使用样例

    [root@node3 ~]# df -Th文件系统                         类型      容量  已用  可用 已用% 挂载点devtmpfs                         devtmpfs  475M     0  475M    0% /devtmpfs                            tmpfs     487M     0  487M    0% /dev/shmtmpfs                            tmpfs     487M  7.8M  479M    2% /runtmpfs                            tmpfs     487M     0  487M    0% /sys/fs/cgroup/dev/mapper/centos-root          xfs        39G  4.3G   35G   12% //dev/mapper/vgmygroup1-lvmygroup xfs        40G   33M   40G    1% /mydatatmpfs                            tmpfs      98M     0   98M    0% /run/user/0

    10.2 du指令

      

    du

    命令也是查看使用空间的,但是与df命令不同的是Linux du命令是对文件和目录磁盘使用的空间的查看,还是和df命令有一些区别的。

    语法:

    du [-ahskm] 文件或目录名称

      选项与参数:

    -a :列出所有的文件与目录容量,因为默认仅统计目录底下的文件量而已。-h :以人们较易读的容量格式 (G/M) 显示;-s :列出总量而已,而不列出每个各别的目录占用容量;-S :不包括子目录下的总计,与 -s 有点差别。-k :以 KBytes 列出容量显示;-m :以 MBytes 列出容量显示;

      使用样例;

    [root@node3 hadoop]# du -ah ./*8.0K    ./capacity-scheduler.xml4.0K    ./configuration.xsl4.0K    ./container-executor.cfg4.0K    ./core-site.xml4.0K    ./hadoop-env.cmd8.0K    ./hadoop-env.sh4.0K    ./hadoop-metrics2.properties4.0K    ./hadoop-metrics.properties12K     ./hadoop-policy.xml4.0K    ./hdfs-site.xml4.0K    ./httpfs-env.sh4.0K    ./httpfs-log4j.properties4.0K    ./httpfs-signature.secret4.0K    ./httpfs-site.xml4.0K    ./kms-acls.xml4.0K    ./kms-env.sh4.0K    ./kms-log4j.properties8.0K    ./kms-site.xml16K     ./log4j.properties4.0K    ./mapred-env.cmd4.0K    ./mapred-env.sh8.0K    ./mapred-queues.xml.template4.0K    ./mapred-site.xml4.0K    ./mapred-site.xml.template4.0K    ./slaves4.0K    ./ssl-client.xml.example4.0K    ./ssl-server.xml.example4.0K    ./yarn-env.cmd8.0K    ./yarn-env.sh8.0K    ./yarn-site.xml

      至于其他的磁盘指令

    fdisk

    ,

    lsblk

    ,

    parted

    等,已经在前面的分区地方将的十分清楚了,这里就不在累赘了;

  • 赞(0) 打赏
    未经允许不得转载:爱站程序员基地 » Linux基础篇——Linux磁盘操作(磁盘基础知识、分类、分区、挂载、卸载、扩容)详解