磁盘分区相关知识

磁盘分区相关知识

使用磁盘分区的过程
设备识别→设备分区→创建文件系统→标记文件系统→在/etc/fstab文件中创建条目→挂载新的文件系统

分区不是必须的,但是分区是必要的:
优化I/O性能
实现磁盘空间配额限制
提高修复速度
隔离系统和程序
安装多个OS
采用不同文件系统

不重启激活新添加的磁盘:echo “- – -” > /sys/class/scsi_host/host0/scan

MBR分区(Master Boot Record)

使用32位表示扇区 数,分区不超过512*2^32=2TB

0磁道0扇区(成为mbr):512bytes

446bytes: boot loader (其他分区的第一个扇区也会余出446,但是是空的不存储引导数据)

64bytes:分区表 记录分区名 分区地址 其中16bytes标识一个分区 所以最多只能划分四个分区 4个主分区;3主分区+1扩展(N个逻辑分区)

2bytes: 55AA 标识位 表示有分区的意思

新磁盘未分区的mbr全部为零 没有分区表 查看分区前512字节磁盘分区相关知识 分区结构图 磁盘分区相关知识

GPT分区(Globals Unique Identifiers)

支持128个分区,使用64位 支持8Z( 512Byte/block )或者64Z ( 4096Byte/block)

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

UEFI (统一扩展固件接口)硬件支持GPT,使操作系统启动(BIOS本身不支持GPT分区的,只能利用UEFI技术 才能启动系统UEFI+GPT=BIOS+MBR)

GPT分区结构图 磁盘分区相关知识

创建分区

列出块设备 lsblk

创建分区使用:
fdisk 创建MBR分区
gdisk 创建GPT分区
parted 高级分区操作(二者都可以)
partprobe-重新设置内存中的内核分区表版本

parted

直接输入以交互式方式进行分区操作
Parted /dev/sdb

也可以使用非交互式进行分区操作

用法:parted [选项]… [设备 [命令 [参数]…]…]
parted /dev/sdb mklabel gpt|msdos

指定用分区方式(即格式化分区)

磁盘分区相关知识

parted /dev/sdb print 显示分区表

磁盘分区相关知识

parted /dev/sdb mkpart primary 1 200 (默认M)创建分区
parted /dev/sdb rm 1
删除磁盘分区 按照编号删除
parted -l 显示磁盘分区信息 磁盘分区相关知识

GPT和MBR分区没有必要进行转换,一但转换内部信息会被破坏,因为二者分区的结构不同 磁盘分区相关知识

延伸:

对于MBR分区来说,若0磁道0扇区的mbr被破坏(即前512字节),会造成严重后果,机器无法启动。 磁盘分区相关知识

利用lsblk仍可以看到分区信息,fdisk看不到,因为分区表一份在磁盘一份在内存,二者是不同步的。
如何恢复?

  • 可以将512字节分区表提前备份到本地和其他主机

磁盘分区相关知识

  • 当磁盘的mbr分区表被破坏后,当没有重启,可以利用本地备份的分区表恢复

磁盘分区相关知识

gdisk和fdisk(交互式和非交互)

gfisk /dev/sdb 类fdisk 的GPT分区工具

交互:
fdisk /dev/sdb 管理分区

非交互:
fdisk -l [-u] [device…] 查看分区
子命令:
p 分区列表
t 更改分区类型
n 创建新分区
d 删除分区
v 校验分区
u 转换单位

Centos7默认以扇区为单位,可以选择以柱面为单位

磁盘分区相关知识

同步分区

fdisk -l /dev/磁盘名 查看磁盘真实分区信息

lsblk 或者cat /proc/partations
查看内存中分区表

通过以上两个命令可以看分区时不是已经同步

不同步解决办法

  • centos6 通知内核重新读取硬盘分区表

    新增分区后用
    partx -a /dev/DEVICE
    kpartx -a /dev/DEVICE -f: force

    删除分区后用 partx -d –nr M-N /dev/DEVICE

  • CentOS 5、7知内核重新读取硬盘分区表

    使用partprobe [/dev/DEVICE]

一旦新增和删除分区,一定要记得同步分区表

PS:LINUX小白 敬请指教

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

(0)
OscaoChaserOscaoChaser
上一篇 2017-08-20 19:49
下一篇 2017-08-20 21:28

相关推荐

  • Mariadb数据库复制系列(四):复制过滤器的实现

       实验四:复制过滤器的实现 复制过滤器的作用是让从节点仅复制主节点的指定的库,或指定数据库的指定表,而不是全部复制。其配置方式有两种,一种是在主节点上配置,通过定义主节点只记录部分库或表产生的二进制日志时间来实现;一种是通过从节点上配置,当复制了主节点的所有的二进制日志数据后,在SQL线程执行时,只执行指定的库或表相关的二进制日志时间;一般采取在从节点上…

    Linux干货 2016-11-24
  • linux 进程及作业管理

     1、Process: 运行中的程序的一个副本,是被载入内存的一个指令集合 进程ID(Process ID,PID)号码被用来标记各个进程 UID、GID、和SELinux语境决定对文件系统的存取和访问权限, 通常从执行进程的用户来继承 存在生命周期 Uninterruptible sleep: 不可中断的睡眠 Interruptible slee…

    Linux干货 2017-08-28
  • 用户和组的管理

    通过命令、passwd和shadow的格式,讲述了用户和组的管理

    Linux干货 2017-12-17
  • haproxy 简单实现80转后端8000

    一,安装 yum -y install gcc automake autoconf libtool make tar -xzf haproxy-1.6.8 cd haproxy-1.6.8 make TARGET=linux2628 make install 二,编辑配置文件 Haproxy配置中分成五部分内容,当然这些组件不是必选的,可以根据需要选择作为配…

    Linux干货 2016-09-19
  • mysql5.5.32多实例配置

    操作系统:CentOS release 6.7 (Final) 内核版本:2.6.32-573.el6.x86_64 mysql版本号:mysql-5.5.32 1)安装mysql所需的依赖包 # adduser mysql -s /sbin/nologin -M # mkdir -p&n…

    Linux干货 2016-12-05
  • 常见RAID总结

    RAID浅析 目录索引 一、定义 二、特点 三、常用RAID级别      四、RAID实现方式 五、实际环境测试 一、定义: 磁盘阵列(Redundant Arrays of Independent Disks,RAID),有“独立磁盘构成的具有冗余能力的阵列”之意。 独立磁盘冗余阵列(RAID,redundant array…

    Linux干货 2016-04-12