• Linux ->> 磁盘管理相关命令(df & fsck & lsblk & fdisk & mkfs & mdadm)


    df -hl

    查看磁盘空间容量大小(df命令)

    显示格式为: 

    文件系统              容量 已用 可用 已用% 挂载点 

    [root@gpslave3 ~]# df -hl
    文件系统                 容量  已用  可用 已用% 挂载点
    devtmpfs                 899M     0  899M    0% /dev
    tmpfs                    910M     0  910M    0% /dev/shm
    tmpfs                    910M  9.6M  901M    2% /run
    tmpfs                    910M     0  910M    0% /sys/fs/cgroup
    /dev/mapper/centos-root   17G  2.1G   15G   13% /
    /dev/sda1               1014M  195M  820M   20% /boot
    tmpfs                    182M     0  182M    0% /run/user/0

     加T参数可以查看具体的磁盘类型

    [root@gpslave3 ~]# df -Thl
    文件系统                类型      容量  已用  可用 已用% 挂载点
    devtmpfs                devtmpfs  899M     0  899M    0% /dev
    tmpfs                   tmpfs     910M     0  910M    0% /dev/shm
    tmpfs                   tmpfs     910M  9.6M  901M    2% /run
    tmpfs                   tmpfs     910M     0  910M    0% /sys/fs/cgroup
    /dev/mapper/centos-root xfs        17G  2.1G   15G   13% /
    /dev/sda1               xfs      1014M  195M  820M   20% /boot
    tmpfs                   tmpfs     182M     0  182M    0% /run/user/0

    fsck用于检测并修复文件系统中的错误。它类似于 Windows 操作系统中的 “chkdsk” 工具,但它是为 Linux、MacOS、FreeBSD 操作系统所准备的,FSCK 全称为 File System Consistency Check。在大多数时候,它在系统启动时运行,但是如果需要的话,它也能被超级用户手工启动。

    [root@gpslave3 ~]# fsck -N /dev/sda1
    fsck,来自 util-linux 2.23.2
    [/sbin/fsck.xfs (1) -- /boot] fsck.xfs /dev/sda1 

     lsblk命令是用来查看block设备的信息

    [root@gpslave3 ~]# lsblk -f
    NAME            FSTYPE      LABEL           UUID                                   MOUNTPOINT
    sda                                                                                
    ├─sda1          xfs                         8ea131e3-5d62-4083-bca8-f7b08744100a   /boot
    └─sda2          LVM2_member                 kRx58v-AkCs-i0om-GrJr-9z0J-ifrc-117tw3 
      ├─centos-root xfs                         40bf6ea9-ac19-42a6-9fc1-050d62c83043   /
      └─centos-swap swap                        9f4f1088-d822-47a8-97ce-38d44b96d8b3   [SWAP]
    sr0             iso9660     CentOS 7 x86_64 2020-11-04-11-36-43-00 

    fdisk 应该比较常用的命令,用来管理磁盘分区的。创建、删除和修改分区。-l查看分区情况,n创建新分区,d删除分区

    fdisk -l查看磁盘和分区情况,新添加磁盘也会显示在这里。就跟打开windows的磁盘管理器一样,显示当前系统有多少个磁盘,不管分区没分区,格式化没格式化

    [root@gpslave2 ~]# fdisk -l
    
    磁盘 /dev/sda:21.5 GB, 21474836480 字节,41943040 个扇区
    Units = 扇区 of 1 * 512 = 512 bytes
    扇区大小(逻辑/物理):512 字节 / 512 字节
    I/O 大小(最小/最佳):512 字节 / 512 字节
    磁盘标签类型:dos
    磁盘标识符:0x000097e3
    
       设备 Boot      Start         End      Blocks   Id  System
    /dev/sda1   *        2048     2099199     1048576   83  Linux
    /dev/sda2         2099200    41943039    19921920   8e  Linux LVM
    
    磁盘 /dev/mapper/centos-root:18.2 GB, 18249416704 字节,35643392 个扇区
    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 字节

    mkfs通常是配合fdisk用的,fdisk创建分区,mkfs是格式化分区的。mkfs.xfs和mkfs.ext4是最常用的两个格式化命令,前者格式化成xfs,后者格式化成ext4。加个 -f 参数强制格式化。

    关于ext4和xfs的区别,我也特地查了一下度娘。找到了几篇觉得不错的博文。不过因为我的实验环境是作为数据库,xfs的稳定性似乎是目前用于作为数据库服务器主流的文件系统格式。

    https://zhuanlan.zhihu.com/p/55159881

    https://www.jianshu.com/p/51c345716139

    [root@gpmaster media]# mkfs.xfs -f /dev/sdc2
    meta-data=/dev/sdc2              isize=512    agcount=4, agsize=655296 blks
             =                       sectsz=512   attr=2, projid32bit=1
             =                       crc=1        finobt=0, sparse=0
    data     =                       bsize=4096   blocks=2621184, imaxpct=25
             =                       sunit=0      swidth=0 blks
    naming   =version 2              bsize=4096   ascii-ci=0 ftype=1
    log      =internal log           bsize=4096   blocks=2560, version=2
             =                       sectsz=512   sunit=0 blks, lazy-count=1
    realtime =none                   extsz=4096   blocks=0, rtextents=0

     mdadm是multiple devices admin的简称,它是用来管理RAID磁盘阵列的工具,创建、删除磁盘阵列。目前MD支持linear,multipath,raid0(stripping),raid1(mirror),raid4,raid5,raid6,raid10等不同的冗余级别和级成方式,当然也能支持多个RAID陈列的层叠组成raid1 0,raid5 1等类型。对了,这个命令默认是没有安装的,需要yum install mdadm 安装一下。很快。

    mdadm -S 删除阵列

    [root@gpmaster ~]# mdadm -S /dev/md10
    mdadm: stopped /dev/md10

    创建RAID0

    [root@gpmaster ~]# mdadm -Cv /dev/md10 -l0 -n2 /dev/md1 /dev/md2
    mdadm: chunk size defaults to 512K
    mdadm: /dev/md1 appears to be part of a raid array:
           level=raid0 devices=2 ctime=Sat Sep 25 02:09:02 2021
    mdadm: /dev/md2 appears to be part of a raid array:
           level=raid0 devices=2 ctime=Sat Sep 25 02:09:02 2021
    Continue creating array? y
    mdadm: Defaulting to version 1.2 metadata
    mdadm: array /dev/md10 started.

     -D显示当前磁盘阵列的情况

    [root@gpslave1 md10]# mdadm -D /dev/md10
    /dev/md10:
               Version : 1.2
         Creation Time : Sun Sep 26 19:47:03 2021
            Raid Level : raid0
            Array Size : 20932608 (19.96 GiB 21.43 GB)
          Raid Devices : 2
         Total Devices : 2
           Persistence : Superblock is persistent
    
           Update Time : Sun Sep 26 19:47:03 2021
                 State : clean 
        Active Devices : 2
       Working Devices : 2
        Failed Devices : 0
         Spare Devices : 0
    
            Chunk Size : 512K
    
    Consistency Policy : none
    
                  Name : gpslave1:10  (local to host gpslave1)
                  UUID : aaf21926:f976e68b:32e3e687:af64c359
                Events : 0
    
        Number   Major   Minor   RaidDevice State
           0       9        1        0      active sync   /dev/md1
           1       9        2        1      active sync   /dev/md2

     说到这,磁盘阵列是有个坑啊,就是每次你创建完磁盘阵列后,已重启电脑,新建的磁盘阵列设备名称会变的。

    例如上面我们建了一个RAID0,设备名称是/dev/md10,重启后很可能就变成/dev/md127了。

    所以我在实验的时候改了/etc/fstab挂载磁盘阵列设备,结果一重启,直接加载系统的时候就报错了。

    但是我另外一台机子没有出现这个问题。后来我总结了一下:如果你创建完磁盘阵列,在没有重启的情况下把mdadm -Ds的磁盘阵列信息写入到文件/etc/mdadm.conf,如果没有写入文件直接重启,应该是linux系统启动的时候会优先去读取/etc/mdadm.conf,如果发现文件不存在,就会自己把阵列文件改掉。所以建议磁盘阵列创建完里面执行 mdadm -Ds >> /etc/mdadm.conf

    [root@gpslave2 ~]# cat /etc/fstab 
    
    #
    # /etc/fstab
    # Created by anaconda on Wed Sep  1 22:18:56 2021
    #
    # 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 0
    UUID=8ea131e3-5d62-4083-bca8-f7b08744100a /boot                   xfs     defaults        0 0
    /dev/mapper/centos-swap swap                    swap    defaults        0 0
    /dev/md10    /media/md10    xfs    defaults    0    0

    这个在下面博文可以找到一些解释。

    https://www.cnblogs.com/cishi/p/72387a607d2c523b492d4347213a9f0a.html

    先进去系统执行 mdadm -D -s或者mdadm --detail --scan, 第3行就是我们的RAID0

    [root@gpslave2 ~]# mdadm -Ds
    ARRAY /dev/md/gpslave2:2 metadata=1.2 name=gpslave2:2 UUID=90db3acd:6c678d07:84df05d6:1ebfee4c
    ARRAY /dev/md/gpslave2:1 metadata=1.2 name=gpslave2:1 UUID=1b065440:c76784ef:a80f6d0f:2dd393da
    ARRAY /dev/md/gpslave2:10 metadata=1.2 name=gpslave2:10 UUID=15d5e7e6:741c3729:66efa270:0992c3a0

    找到ARRAY后面的那个设备名称,其实这个也不是真实的设备名称,真的设备名称是127,它其实是个soft link指向了真实的设备文件

    [root@gpslave2 ~]# ll /dev/md*
    brw-rw----. 1 root disk 9,  1 9月  26 22:22 /dev/md1
    brw-rw----. 1 root disk 9, 10 9月  26 22:22 /dev/md10
    brw-rw----. 1 root disk 9,  2 9月  26 22:22 /dev/md2
    
    /dev/md:
    总用量 0
    lrwxrwxrwx. 1 root root 6 9月  26 22:22 gpslave2:1 -> ../md1
    lrwxrwxrwx. 1 root root 7 9月  26 22:22 gpslave2:10 -> ../md10
    lrwxrwxrwx. 1 root root 6 9月  26 22:22 gpslave2:2 -> ../md2
    [root@gpslave2 ~]# 

    执行 mdadm -Ds >> /etc/mdadm.conf,把这部分信息写入到配置文件,这个文件默认是不自动创建的

    [root@gpslave2 ~]# cat /etc/mdadm.conf 
    ARRAY /dev/md/gpslave2:2 metadata=1.2 name=gpslave2:2 UUID=90db3acd:6c678d07:84df05d6:1ebfee4c
    ARRAY /dev/md/gpslave2:1 metadata=1.2 name=gpslave2:1 UUID=1b065440:c76784ef:a80f6d0f:2dd393da
    ARRAY /dev/md/gpslave2:10 metadata=1.2 name=gpslave2:10 UUID=15d5e7e6:741c3729:66efa270:0992c3a0

    然后就可以修改/etc/fstab,修改完保存重启

    [root@gpslave2 ~]# cat /etc/fstab 
    
    #
    # /etc/fstab
    # Created by anaconda on Wed Sep  1 22:18:56 2021
    #
    # 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 0
    UUID=8ea131e3-5d62-4083-bca8-f7b08744100a /boot                   xfs     defaults        0 0
    /dev/mapper/centos-swap swap                    swap    defaults        0 0
    /dev/md/gpslave2:10    /media/md10    xfs    defaults    0    0

    参考:

    https://www.cnblogs.com/mafeng/p/10696956.html

    https://www.linuxprobe.com/linux-fsck-command.html

    https://jingyan.baidu.com/article/2009576162eaeb8b0721b4d2.html

    https://www.linuxprobe.com/use-lsblk-list-block.html

    https://blog.csdn.net/qq_39866513/article/details/85120338

    https://www.cnblogs.com/ariclee/p/6403396.html

  • 相关阅读:
    if 语句练习 身高体重问题
    阶乘
    if语句和switch语句
    Java 运算符
    Centos上把新安装的程序添加到系统环境变量的两种方法
    申请 Let’s Encrypt 泛域名证书 及 Nginx/Apache 证书配置
    Centos 6.5安装OpenSSL
    openssl version 查看openssl 版本出现openssl: error while loading shared libraries: libssl.so.1.1: cannot open shared object file: No such file or directory,怎么办
    ab压力测试遭遇apr_socket_recv: Connection reset by peer (104) 怎么办
    配置apache实现对网站某一目录的访问自动跳转到指定目录
  • 原文地址:https://www.cnblogs.com/jenrrychen/p/15330518.html
Copyright © 2020-2023  润新知