linux 磁盘管理

linux 磁盘管理三部曲——(1)磁盘结构,认识分区

 
分类: Linux基础篇

最近小编整理了磁盘管理的相关知识,发现还是挺多的,所有就分了三个部分来给大家分享一下:

1、磁盘结构,认识分区

2、管理分区,文件系统格式化

3、mount挂载,/etc/fstab配置文件

这篇就先以最基础的磁盘知识开始——磁盘结构,认识分区。(讲基础的会有些无聊,但是基础还是很重要,所以还是希望大家详细了解)

一、磁盘介绍

1、设备类型

(1)快设备/字符设备

块设备:block ,存取单位“块”,磁盘

字符设备:char ,存取单位“字符”,键盘

(2)机械硬盘和固态硬盘

① 机械硬盘(HDD ):即是传统普通硬盘,主要由:盘片,磁头,盘片转轴及控制电机,磁头控制器,数据转换器,接口,缓存等几个部分组成。机械硬盘中所有的盘片都装在一个旋转轴上,每张盘片

之间是平行的,在每个盘片的存储面上有一个磁头,磁头与盘片之间的距离比头发丝的直径还小,所有的磁头联在一个磁头控制器上,由磁头控制器负责各个磁头的运动。磁头可沿盘片的半径方向运动,加上盘片每分钟几千转的高速旋转,磁头就可以定位在盘片的指定位置上进行数据的读写操作。数据通过磁头由电磁流来改变极性方式被电磁流写到磁盘上,也可以通过相反方式读取。硬盘为精密设备,进入硬盘的空气必须过滤。

② 固态硬盘(SSD ):用固态电子存储芯片阵列而制成的硬盘,由控制单元和存储单元(FLASH 芯片、DRAM 芯片)组成。固态硬盘在接口的规范和定义、功能及使用方法上与普通硬盘的完全相同,

在产品外形和尺寸上也与普通硬盘一致。

③ 比较:

相较于HDD ,SSD 在防震抗摔、传输速率、功耗、重量、噪音上有明显优势,SSD 传输速率性能是HDD 的2倍

相较于SSD ,HDD 在价格、容量、使用寿命上占有绝对优势

硬盘有价,数据无价,目前SSD 不能完全取代HHD

 

2、设备文件

① 磁盘设备的设备文件命名:/dev/DEV_FILE

② 不同磁盘标识:a-z,aa,ab…

/dev/sda, /dev/sdb, ... /dev/sdaa,/dev/sdab...

同一设备上的不同分区:1,2, ...

/dev/sda1, /dev/sda5

③ 硬盘存储术语

  head :磁头

  track :磁道

  cylinder:  柱面

  secotr:  扇区,512bytes(最小单位)

 ④ HDD磁盘结构

CHS

512bytes    *   64 sector数/track    *    1024  track数/盘面       256   head磁头数(盘面数)   8G

  扇区                 扇区数/磁道                       磁道/盘面                       

( 512bytes    *   64 sector数/track    *   256 )一个柱面的大小:8M  * 1024磁道 =8G

单位:B KB MB GB TB PB EB ZB YB BB NB DB

3、如何使用分区空间?(后边会详细讲解每一步)

① 设备识别

② 设备分区

③ 文件系统类型格式化

④ 在/etc/fstab 文件中创建条目

⑤ mount 挂载新的文件系统

4、为什么分区?

① 优化I/O 性能

② 实现磁盘空间配额限制

③ 提高修复速度

④ 隔离系统和程序

⑤ 安装多个OS

⑥ 采用不同文件系统

5、两种寻址方法:CHS和LBA

 CHS:

  采用24bit 位寻址

  其中前10 位表示cylinder ,中间8 位表示head ,后面6 位表示sector。 。

  最大寻址空间8GB

LBA (logical block addressing):

  LBA 是一个整数,通过转换成CHS 格式完成磁盘具体寻址

  LBA 采用48 个bit 位寻址

  最大寻址空间128PB

由于CHS 寻址方式的寻址空间在大概8GB 以内,所以在磁盘容量小于大概8GB 时,可以使用CHS 寻址方式或是LBA 寻址方式;在磁盘容量大于大概8GB 时,则只能使用LBA 寻址方式

二、分区介绍

两种分区方式:MBR ,GPT

1、MBR

MBR: Master Boot Record ,1982年, 使用32位表示扇区数 , 分区不超过2T

(1)如何分区:按柱面

  0 磁道0 扇区:512bytes

  446bytes: boot loader

  64bytes :分区表

    16bytes:  标识一个分区

  2bytes: 55AA,结束标志

(2)4 个主分区;3 主分区+1 扩展(N 个逻辑分区)

 

(3)分区表(DPT)结构

 

(4)硬盘主引导记录MBR 主要由 3 个部分组成

① 主引导程序(偏移地址0000H--0088H ),它负责从活动分区中装载,并运行系统引导程序。

出错信息数据区,偏移地址0089H--00E1H 为出错信息,00E2H--01BDH 全为0 字节。

② 分区表(DPT,Disk Partition Table )含4 个分区项,偏移地址01BEH--01FDH, 每个分区表项长16 个字节,共64 字节为

分区项1 、分区项2 、分区项3 、分区项4

③ 结束标志字,偏移地址01FE--01FF 的2 个字节值为结束标志 55AA

 

2、GPT分区

① GPT:GUID (Globals Unique Identifiers) partitiontable  支持128个分区,使用64 位,支持8Z(512Byte/block )64Z (4096Byte/block)

使用128 位UUID(Universally Unique Identifier)  表示磁盘区 和分区 GPT 分区表自动备份在头和尾两份,并有CRC 校验位

UEFI ( 统一扩展固件接口) 硬件支持GPT ,使操作系统启动

② EFI部分又可以分为4个区域:EFI信息区(GPT头)、分区表、GPT分区、备份区域

 

  第一篇基础就这些了,下一篇就是精彩的操作了,不要错过~~~

linux 磁盘管理三部曲——(2)管理分区,文件系统类型格式化

 
分类: Linux基础篇

上篇小编给大家讲解了磁盘结构和分区的介绍,这篇小编就给大家演示如何管理分区和文件系统类型格式化。

小编上篇已经提到如何使用磁盘,今天这两步,就是其中很重要的两步。(前几天写的有点急,有点乱,今天又整理了下)

一、管理分区  

列出块设备 lsblk

         fdisk -l /dev/sda

         cat /proc/partitions

创建分区使用的命令:

(1) fdisk  创建MBR 分区(7里也可以创建GPT 分区,但不推荐,contos 6 -l 时候gpt多个分区只显示1个)

  ①  fdisk  -l  /dev/sdX 查看硬盘分区信息

     -c(centos6 默认是dos) 打开或禁用dos模式  -u  (centos6 默认是柱面为单位) 切换显示的单位(扇区/柱面)

     -c (centos7 默认是非dos) -c=dos -c=nondos  -u  (centos7 默认是扇区为单位)  -u=cylinders(柱面)  -u=sectors(扇区)

  ② fdisk /dev/sdX 进行分区(交互式),建立分区时  

   m 帮助

   n 建立分区,建立分区时先选择 p主分区primary partition 或e 选择扩展分区extended,建议前3个建立逻辑分区,最后把所有空间给4扩展分区,有扩展分区可以创建多个逻辑分区。

   d 删除分区

    p 显示分区信息

   t 转换分区类型

   a 将指定分区设置/取消 活动分区   第一位为80活动

   L 查看分区类型

   o 重建分区表

   v 验证分区表,显示剩余没有被分区划分的扇区数量

   g 创建GPT格式的分区(centos7)不推荐使用,最好用gdisk

   q 退出不保存

   w 退出并保存,不保存,所有的修改都不生效

:因为fdisk 是交互式创建分区,所以写入脚本时需要:

  echo -e "n p 1 +1G w " |fdisk /dev/sdb 来实现非交互创建分区

(2) gdisk  创建GPT 分区(用法和fdisk相似)

    n创建分区时,直接从2-128进行分区,不分主分区,扩展分区

(3) parted  高级分区操作(创建、复制、调整大小等等)实时性,小心使用,不用再w已经保存,可以直接非交互式创建分区,aix, amiga, bsd, dvh, gpt, mac, msdos, pc98, sun, loop 都能创建。(不常用)

  parted /dev/sdX

    help 寻求帮助,有很清晰的帮助的信息。

    mklabel help 有mklabel使用帮助信息

    mklabel msdos 选择msdos 方式分区

    mkpart 开始创建分区

    rm 删除分区

    p 查看分区信息

    q 退出

(4)重置内存中分区信息(当系统正在使用的分区修改时,内存不会改变)

   partprobe   新增分区,删除分区都可以,centos 5和7可以使用,centos 6中有bug

   新增分区时,同步 partx -a /dev/sdX 或 kpartx -a /dev/sdX -f

   删除分区时,同步 partx -d /dev/sdX   所有系统都能用,centos 6也可以

 

二、文件系统

(1)查看支持的文件系统:/lib/modules/`uname –r`/kernel/fs

 

(2)文件系统类型

Linux 文件系统:ext2(Extended file system), ext3,ext4, xfs (SGI ), btrfs (Oracle ), reiserfs, jfs(AIX), swap

根据其是否支持"journal" 功能:

  日志型文件系统: ext3, ext4, xfs, ...

  非日志文件系统: ext2, vfat

光盘:iso9660

Windows :FAT32, exFAT,NTFS

Unix: FFS (fast ), UFS (unix ), JFS2

网络文件系统:NFS, CIFS

集群文件系统:GFS2, OCFS2 (oracle) 例:11.11 淘宝

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

RAW:未经处理或者未经格式化产生的文件系统

(3)创建文件系统

(1)mkfs 命令

  mkfs.   能创建很多类文件系统 例:mkfs.xfs /dev/sda1 给/dev/sda1创建xfs类型的文件系统

      ext#   xfs   btrfs   vfa

  mkfs -t 是个c写的脚本,就是调用mkfs. 命令 例:mkfs -t ext4 /dev/sda1 给/dev/sda1创建ext4类型的文件系统

           -f  强制重建,如果这个设备已经分过其他格式的文件系统了

(2)mke2fs 创建文件系统,ext系列文件系统专用管理工具,例:mke2fs -t ext4 -L test /dev/sdc1 给/dev/sdc1创建ext4卷标为test的文件系统

  -t {ext2|ext3|ext4} 格式

  -b {1024|4096} block快大小

  -L 'LABEL' 卷标

  -j: 于 相当于 -t ext3

    mkfs.ext3 = mkfs -t ext3 = mke2fs -j = mke2fs -t ext3

  -i #:  为数据空间中每多少个字节创建一个inode ;此大小不应该小于block 的大小

  -N # :指定分区中创建多少个inode

  -I  一个inode 记录占用的磁盘空间大小,128---4096

  -m #:  默认5%, 为管理人员预留空间占总空间的百分比

  -O FEATURE[,...] :启用指定特性(只能开启以下特性) -O ^FEATURE 禁用指定特性

(3)tune2fs修改文件系统信息,重新设定ext 系列文件系统可调整参数的值  例:tune2fs -o acl /dev/sdb2 开启/dev/sdb2的acl功能

  -l :查看指定文件系统超级块信息;super block

  -L 'LABEL' :修改卷标(ext)

    mkfs -L 'LABEL'  或  mke2fs -L 'LABEL' 创建时设置卷标

    e2label /dev/sd# 查看卷标

    e2label /dev/sd# 'LABEL' 重命名卷标

  -m # :修预留给管理员的空间百分比

  -j:  将ext2 升级为ext3

  -O:  文件系统属性启用或禁用, –O ^has_journal

  -o:  调整文件系统的默认挂载选项,–o ^acl (centos7里默认开启acl   6 默认不开启)

  -U UUID:  修改UUID号

 

(4)查看信息

  blkid:块设备属性信息查看(centos 7里默认显示sr0    6 里需blkid /dev/sr0显示光盘)

    -U UUID:  根据指定的UUID 来查找对应的设备

    -L LABEL :根据指定的LABEL

   findfs:查找分区(ext)

    findfs [options] LABEL=<label>

    findfs [options] UUID=<uuid>

   dumpe2fs /dev/sda# 查看文件系统信息:superblock信息及block group信息

    -h :查看超级块,不显示block group而只显示superblock 与tune2fs -l一致

小知识:超级块就是文件系统的内置,指定文件系统类型

    block group 0里有super block ,后奇数组都有备份,能用于修复

(5)文件系统检测和修复

  常发生于死机或者非正常关机之后,挂载为文件系统有几率标记为“no clean” ”

 注意:一定不要在挂载状态下修复(centos6,7都禁止挂载下修复,5里可以修复)

fsck(都可用) / e2fsck(ext)先卸载再修复(6里默认交互式修复,7非交互)

  -y 自动回答yes

  -t filetype  指定文件系统类型

  -f 强制修复(当破坏太小时,强制扫描一遍修复)

 

 这篇的东西有些多,但其实经常用的命令也就:fdisk/gdisk、mkfs./mke2fs/tune2fs、blkid 这几个命令。下一篇就是磁盘管理最重要的一步了,mount挂载,敬请期待!!

linux 磁盘管理三部曲——(3)mount挂载,/etc/fstab配置文件

 
分类: Linux基础篇

当我们分完区,并做好文件系统格式化,就到了最后的挂载mount了,挂载完毕就可以使用磁盘设备了。

一、什么是挂载,卸载

任何块设备都不能直接访问,需挂载在目录上访问

挂载: 将额外文件系统与根文件系统某现存的目录建立起关联关系,进而使得此目录做为其它文件访问入口的行为(挂载的设备必须有文件系统)

卸载:为解除此关联关系的过程

mount [-选项] DEVICE(设备) MOUNT_POINT(挂载点)

(1)device :指明要挂载的设备

  ① 设备文件:例如/dev/sda5

  ② 卷标:-L 'LABEL', 如 例如 -L mage

  ③ UUID, -U 'UUID'

(2)挂载点下原有文件在挂载完成后会被临时隐藏

  若事先存在:建议使用空目录,进程正在使用中的设备无法被卸载

(3)/etc/mtab: 文件显示当前已挂载的所有设备(在centos 7中,是/proc/mounts的软连接,查看结果一样,centos 6中,ASCII text,查询结果和/proc/mounts不一样)

二、mount:挂载常用命令选项(下面有具体的用法示例)

1、查看挂载情况

① findmnt  查看所有设备挂载情况(树状结构显示)

  findmnt 设备   查看单个设备的挂载情况

② mount :查看所有设备挂载情况

③ cat /proc/mounts:查看内核追踪到的已挂载的所有设备

2、mount 语法

mount -选项 设备 挂载点

  -t:vsftype :指定要挂载的设备上的文件系统类型(不常用,不加-t默认自带自己的文件系统类型),有时,系统报错提示,没指定文件系统类型,-t指定后,仍然有错。(注释1)

  -r:readonly ,只读挂载,不能进行其他操作,和权限无关,介质只能读,多用于冷备份。在mount 查询时时显示 ro

  -w:read and write,  读写挂载(defaults默认)

  -n:隐藏挂载信息不显示 ,但在/proc/mounts可以查到,卸载只能 umount /app/sdb2(挂载点)

  -a:自动挂载/etc/fstab文件没有挂载的设备( 定义在了/etc/fstab文件中,且挂载选项中有auto 功能,默认中包括) ,不看已挂载过的设备,如果在/etc/fstab里挂载过的设备修改了设置,不刷新;

如果想刷新修改过已挂载的设备,mount -o remount /dev/sdX(挂载点)

  -L 'LABEL': 以卷标指定挂载设备

  -U 'UUID':以UUID 指定要挂载的设备

  -B  --bind:绑定目录到另一个目录上,

例: mount -B /var/ftp/pub /app/apache     /app/apache就是显示 /var/ftp/pub目录的东西

   -o options:( 挂载文件系统的选项) ,多个选项使用逗号分隔

    async(defaults),sync  异步,同步,内存更改时,同时写磁盘(可以用于重要数据)

    atime(defaults),noatime  是否在读访问时更新atime

    diratime(defaults),nodiratime  目录的访问时间戳

    auto(defaults)/noauto 写在/etc/fstab当中的分区,是否在mount -a时被挂载

    exec(defatuls)/noexec 在该分区所挂载的目录中的脚本是否可以执行。

    dev(defaults)/nodev:是否支持在此文件系统上使用设备文件

    suid(defaults)/nosuid:是否支持suid和sgid权限

    ro:只读 rw:读写(defaults)

    nouser(defaults)/user:是否允许普通用户挂载此设备,默认管理员才能挂载

    acl(centos 7)/^acl(centos 6以下):启用/禁用此文件系统上的acl功能

    defaults 默认,见以上中的(defaults)

  -o remount,选项:重新挂载,修改功能选项(和/etc/fstab选项冲突,则覆盖,不冲突就增加)  例:mount -o remount,ro /dev/sdb1

例:mount -r /dev/sdb1 /app/sdb1 将/dev/sdb1只读挂载到/app/sdb上

三、umount 卸载

卸载时,若有正在进行的进程,不能卸载

查看正在访问指定文件系统的进程:

  lsof 设备或挂载点都可以

  fuser -v 挂载点

终止所有在正访问指定的文件系统的进程:

  fuser -km 设备或挂载点都可以

 终止完所有进程就可以卸载: umount DEVICE

四、/etc/fstab 文件挂载配置文件

(1)/etc/fstab 每行定义一个要挂载的文件系统

mount -a 自动挂载/etc/fstab文件没有挂载的设备,不管已挂载过的设备

  如果想刷新修改过已挂载的设备,mount -o remount /dev/sdX(或挂载点)

swpon -a 自动激活/etc/fstab文件没有激活的交换(扩展)空间 ,不管已激活的扩展空间

  如果想刷新修改过已激活的扩展设备,mount -o remount /dev/sdX(或挂载点)

系统重启开机时读取此文件,可以开机自动开启文件中的设置

(2)格式(6列):

① 要挂载的设备或伪文件系统:设备名称,LABEL,UUID,伪文件系统名称

② 挂载点(扩展为swap)

③ 文件系统类型(auto 寻找默认的),

  普通设备挂载:ext#/xfs 等文件系统类型

  交换分区 swap:swap

  网络挂载地址 linux之间:nfs,windos挂载:cifs

  光盘 iso9660,文件 cifs

④ 挂载选项:defaults 有需要的功能可以添加,不能为空

⑤ 转储频率: 0:不做备份 1:每天转储 2:每隔一天转储

⑥ 开机时自检(非0),自检次序:(如果开机系统自检不过,就无法正常开机)

0:不自检 1:最先自检,一般为/ 2...:数越小优先级最大

问题:如果设备不小心被破坏,开机自检不过,无法正常启用,该怎么办?

原理很简单,只需要修复一下文件系统就好了,(如果不能修复,可以去/etc/fstab中把自检改为0)具体操作如下:

① 手动破坏设备 dd if=/dev/zero of=/dev/sdc1 bs=1 count=2048

② 开机过程,遇到错误提示

③ 进入shell 操作,进行修复

五、实验:迁移/home 家目录

到此我们已经对磁盘管理了解的差不多了,我们可以做个小实验,迁移 /home ,从 / 下移到另一个磁盘,如/dev/sda6

① init 1 进入单用户模式,防止自己在迁移时,其他用户进行操作,导致迁移后缺失东西。

② 分区 /dev/sda6   fdisk

③ 文件系统格式化 mkfs.ext4 /dev/sda6

④ 挂载在临时目录上/mnt ,把/home 下东西cp -a 到/mnt 目录

⑤ 把现有/home 东西移走,卸载 /mnt ,把/dev/sda6 挂到 /home 下,并写入/etc/fstab,开机自动挂载。

  UUID=328a3f17-3e4e-426d-9538-c44be3e6465b   /home    ext4    defaults        0  2

⑥ reboot或init 5 完成/home 搬迁

 到这里关于磁盘管理的过程就全部讲完了。

原文地址:https://www.cnblogs.com/dengbingbing/p/10390382.html