Linux中的分区管理

1. 磁盘分区类型

磁盘分区主要分为两种类型:

  • MBR 
    MBR是一个比较古老的分区类型了,不支持2TB的大硬盘。在磁盘的0磁道0扇区的512字节存放的就是MBR的信息。前446字节为bootloader,后面64字节存放的是分区表,后面2字节存放的是55aa的分区标识符。MBR分区类型最多只能支持4个主分区和扩展分区,其余的分区只能是逻辑分区。
  • GPT 
    GPT分区是为了应多MBR的诸多问题而产生的。GPT里面已经没有主分区和逻辑分区的概念了。所有的都是主分区,最大支持128个主分区。

2. 分区管理命令

2.1 fdisk

fdisk:划分mbr分区
-l:用于查看磁盘的分区信息
子命令
p:分区列表
t:更改分区类型
n:创建新分区
d:删除分区
w:保存退出
q:不保存退出

2.2 gdisk

gdisk主要用于创建GPT分区,使用方法和fdisk类似

2.3 parted

parted可以用于管理mbr和gpt分区:

命令
parted /dev/sd# mklabel msdos|gpt:指定分区类型是gpt或mbr
parted /dev/sd# mkpart primary 1 200:创建id为1的200M主分区
parted /dev/sd# rm 1:删除id1分区
parted /dev/sd# print:查看分区表
parted -l:查看磁盘详细信息

注意: 
parted的所有操作都是实时生效的,所以使用的时候需要注意!

3. 创建文件系统

磁盘在创建完分区之后需要创建文件系统才能进行文件的存储。 
通过/lib/modules/`uname -r`/kernel/fs可以查看系统支持的文件系统类型。 
Linux中的分区管理

3.1 创建文件系统

创建文件系统通过mkfs命令

mke2fs
-t:指定要创建的文件系统类型
-L 卷标:指定要格式化分区的卷标名
-j:相当于创建ext3
-i #:数据空间每多少个字节创建一个inode,inode大小不应该小于block大小
-N #:为数据空间创建多少个inode
-m #:指定为管理员保留的空间大小,默认为5%
-O FEATURE[…]:启用指定的特性

3.2 查看编辑文件系统

blkid
-U:查看指定uuid的设备
-L:查看指定卷标的设备信息
e2label
管理ext系列文件系统给的卷标,如e2label /dev/sdb1 test
findfs
findfs LABEL=卷标名:根据卷标查找分区
findfs UUID=uuid号:根据uuid查找分区
tune2fs
-l:查看指定文件系统的超级块信息
-L 卷标:修改卷标
-m #:修改预留给管理员的空间
-j:将ext2升级为ext3
-O:启用或禁用文件系统属性
-o:调整文件系统的默认挂载选项
-U uuid:修改UUID号
dumpe2fs
查看超级块和分组信息
-h:只查看超级块信息,不查看分组信息

3.3 修复文件系统

文件系统有时会因为各种原因导致损坏,所以就需要修复。

fsck
-t:指定分区类型
-p:自动修复错误
-r:交互式修复
-y:自动修复

ext2和ext3的区别是ext2没有日志功能,在生产环境中,文件系统的日志功能是很重要的。

3.4 inode,datablock和superblock介绍

  • datablock 
    在ext文件系统中数据是存放在datablock中的,datablock大小有三种:1024K,2048K,4096K。一个文件可以占用多个datablock。
  • inode 
    真实的数据存放在datablock区域中,数据的元数据则存放在inode中,如数据分布在哪些datablock中,数据的大小等属性信息。每个数据占用一个inode,所以如果inode占满了,datablock还有空余的情况下也不允许在存放数据。
  • superblock 
    超级块往往存放在分组的最起始位置,其存放的内容包括inode bitmap,block bitmap,inode table等信息。如果超级块损坏,则所有数据将不可读,所有超级块还有多个备份。

4. 挂载、卸载分区

4.1 挂载分区

mount
mount /dev/sd# 挂载点:直接通过设备名挂载
mount -L 卷标|-U uuid:可以通过卷标和uuid挂载
-t:指定要挂载的分区的类型,系统现在会自动更识别,不需要指定
-r:只读挂载
-w:读写挂载
-n:挂载不更新/etc/mtab文件,mount也不可见,可以通过cat /proc/mounts看到
-a:自动挂载所有支持自动挂载并存在于/etc/fstab中的分区
-B | –bind:挂载一个目录到另外一个目录
-o 挂载选项:指定挂载时需要开启的特性:
async:异步读写
sync:同步读写模式,安全,但是降低性能
atime|noatime:访问是否允许改变atime
auto|noauto:是否支持-a自动挂载
exec|noexec:是否支持在此文件系统运行应用程序
dev|nodev:是否支持在此分区使用设备文件
suid|nosuid:是否支持suid和sgid权限,建议采用nosuid
remount:重新挂载,不需要umount
ro:只读
rw:读写
user|nouser:是否允许普通用户挂载此设备,默认只有管理员才能挂载设备
acl:是否启用分区的acl功能
defaults:相当于rw,async,dev,auto,nouser,nosuid

4.2 查看挂载情况

findmnt 挂载点:查看挂载情况
lsof 挂载点:查看正在访问指定文件系统的进程
fuser -v 挂载点:查看正在访问指定文件系统的进程和用户
furer -km 挂载点:踢出所有正在访问的进程和用户

4.3 取消挂载

umount 设备名:通过设备名取消挂载
umount 挂载点:通过挂载点取消挂载

5. /etc/fstab介绍

默认所有的分区在系统开机之后是不会自动挂载的,此时需要把挂载信息添加到/etc/fstab中 
/etc/fstab分6个字段:

  1. 设备名,卷标名,uuid,因为设备名和卷标名都会改变,建议采用uuid
  2. 挂载点
  3. 文件系统类型,光盘ISO9660,swap分区为swap
  4. 挂载选项:defaults,rw,async等参数
  5. 是否定时备份分区,0为不备份
  6. 开机是否检测分区,0为不检测,此处数字代表优先级

6. swap分区

swap交换分区用于内存不够用时临时把内存不用的数据存放到swap交换分区上,所以建议swap分区采用高速磁盘。

mkswap 设备名:创建swap交换分区
swapon swap分区名:挂载swap分区
swapon -s:查看swap分区挂载情况;swap分区有优先级之分,可以通过调整优先级来调整swap分区的使用优先顺序
swapoff swap分区名:卸载是swap分区

以上是对Linux分区管理的总结,LInux磁盘高级管理部分后续再补充。

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

(1)
王子豪王子豪
上一篇 2017-04-21
下一篇 2017-04-22

相关推荐

  • keepalived实现nginx的高可用-实战可用

    Keepalived.conf解析 三大部分: 全局定义块、VRRP 实例定义块及虚拟服务器定义块 实例剖析 ! Configuration File for keepalived   global_defs {    notification_email {…

    Linux干货 2015-04-14
  • 20160804课堂练习

    grep正则表达式课堂练习 1、找出ifconfig命令结果中本机的所有IPv4地址 # ifconfig | head -2 | cut -dt -f2 | cut -dn -f1 | tail -1 2、  查出分区空间使用率的最大百分比值 # df | cut -c56-58 | sort -n | tail -1 3、  查出用户…

    Linux干货 2016-08-05
  • 网络管理(二)之IP地址划分子网、多块网卡共用单一IP

    网络管理(二)IP地址   一、认识学习IP地址的组成: 1、它们可唯一标识IP 网络中的每台设备 2、IP地址由两部分组成: 网络ID:标识网络;每个网段分配一个网络ID 主机ID:标识单个主机;由组织分配给各设备 3、点分十进制计法表示IPv4地址: 4、如下图,将系统中的IP地址用二进制表示,再通过转换合成的十进制数,使用ping命令可得出:…

    Linux干货 2016-09-05
  • sed工具 vim编辑器

    sed工具:    用法:           sed [option]… 'script' inputfile…      常用选项:           &nbs…

    Linux干货 2016-08-12
  • 文件管理和用户组权限管理小结

    文件管理 文件系统结构 /boot: 引导文件存放目录,内核文件,引导加载器都存放在此目录 /bin:供所有用户使用的基本命令,不能关联至独立分区,os启动即会用到的程序 /sbin:管理类的基本命令:不能关联至独立分区,os启动即会用到的程序 /etc:配置文件目录 /home:普通用户家目录 /root:管理员的家目录 /dev: 设备文件及特殊文件存储…

    2017-07-23
  • NET25-第11周作业

    1、详细描述一次加密通讯的过程,结合图示最佳。 第一步:他们需要实现协商好对称加密算法,单向加密算法,公钥加密算法,交换公钥等。 第二步:B用户想要将数据传给A,首先需要使用单向加密算法取出数据的特征码,并用自己的私钥对这段特征码进行加密(数字签名),B用户生成临时对称密钥,并用对称密钥加密整段数据,B用户使用 A用户的公钥加密一次性对称密钥,附加在整段数据…

    Linux干货 2017-05-15

评论列表(1条)

  • renjin
    renjin 2017-04-28 11:03

    主要对linux的分区管理进行了详细的介绍,内容总结的很详细,排版也很好,可以把博客的数量再往上提一下了!