Linux磁盘管理和lvm

磁盘管理

硬盘接口和硬盘种类

从整体的角度上,硬盘接口分为IDE、SATA、SCSI和SAS四种,IDE接口硬盘多用于家用产品中,也部分应用于服务器,SCSI接口的硬盘则主要应用于服务器市场,而SAS只在高端服务器上,价格昂贵

SATA硬盘:  

  用SATA接口的硬盘又叫串口硬盘,是以后PC机的主流发展方向,因为其有较强的纠错能力,错误一经发现能自动纠正,这样就大大的提高了数据传输的安全性。新的SATA 使用了差动信号系统"differential-signal-amplified-system"。这种系统能有效的将噪声从正常讯号中滤除,良好的噪声滤除能力使得SATA只要使用低电压操作即可,和 Parallel ATA 高达5V的传输电压相比,SATA 只要0.5V(500mv) 的峰对峰值电压即可操作于更高的速度之上。"比较正确的说法是:峰对峰值'差模电压'"。一般转速可达7200转/分。

SCSI硬盘:

  SCSI硬盘即采用SCSI接口的硬盘。 优点:SCSI接口具有应用范围广、多任务、带宽大、CPU占用率低,以及热插拔等。它由于性能好、稳定性高,因此在服务器上得到广泛应用。缺点:由于SCSI硬盘价格非常昂贵,所以一般的PC是不会使用SCSI硬盘。 一般转速可达10000转/分。

SAS硬盘:

  SAS(Serial Attached SCSI)即串行连接SCSI,是新一代的SCSI技术,和现在流行的Serial ATA(SATA)硬盘相同,都是采用串行技术以获得更高的传输速度,并通过缩短连结线改善内部空间等。改善存储系统的效能、可用性和扩充性。 一般转速可达15000转/分,甚至更高。

磁盘分区

目前的磁盘主要有 MBR 以及 GPT 两种格式,这节我们主要谈 MBR

  MBR的意思是“主引导记录”,最早在1983年在IBM PC DOS 2.0中提出。之所以叫“主引导记录”,是因为它是存在于驱动器开始部分的一个特殊的启动扇区。这个扇区包含了驱动器的分区信息(64个字节,大小固定,一个分区用16个字节记录)和已安装的操作系统的启动加载器(446字节)和2个字节的结束标志,所以这个扇区的大小是512个字节。。所谓启动加载器,是一小段代码,用于加载驱动器上其他分区上更大的加载器。如果你安装了Windows,Windows启动加载器的初始信息就放在这个区域里——如果MBR的信息被覆盖导致Windows不能启动,你就需要使用Windows的MBR修复功能来使其恢复正常。如果你安装了Linux,则位于MBR里的通常会是GRUB加载器。MBR支持最大2TB磁盘,它无法处理大于2TB容量的磁盘。MBR还只支持最多4个主分区——如果你想要更多分区,你需要创建所谓“扩展分区”,并在其中创建逻辑分区。

分区符

  盘的0柱面、0磁头、1扇区称为主引导扇区(也叫主引导记录MBR)。它由三个部分组成,主引导程序、硬盘分区表DPT(Disk Partition table)和分区有效标志(55AA)。在总共512字节的主引导扇区里主引导程序(boot loader)占446个字节,第二部分是Partition table区(分区表),即DPT,占64个字节,硬盘中分区有多少以及每一分区的大小都记在其中。第三部分是魔数magic number,占2个字节,固定为5AA。

分区编号:主分区1-4 ,逻辑分区5……

LINUX规定:逻辑分区必须建立在扩展分区之上,而不是建立在主分区上

分区作用:

主分区:主要是用来启动操作系统的,它主要放的是操作系统的启动或引导程序,/boot分区最好放在主分区上

扩展分区不能使用的,它只是做为逻辑分区的容器存在的,先创建一个扩展分区,在拓展分区之上创建逻辑分区;我们真正存放数据的是主分区和逻辑分区,大量数据都放在逻辑分区中。

使用分区工具fdisk对磁盘进行操作,分区,格式化

主分区+扩展分区 最多只能有4个

扩展分区可以是0个,最多是1个

扩展分区不能直接使用,扩展分区必须首先创建成逻辑分区才能使用

逻辑分区可以是0个 1个 多个

 

命名方式: /dev/sd{a-z}n——a代表第一块,b表示第二块,以此类推

n  表示每块磁盘上划分的磁盘分区编号

文件系统

文件系统的特征:我们都知道磁盘分区完毕后还需要进行格式化(format),之后操作系统才能使用这个文件系统。为什么要格式化?这是因为每种操作系统所设置的文件属性/权限并不相同,为了存放所需的数据就需要将分区进行格式化,以成为操作系统能够利用的文件系统格式(filesystem)。

用户在硬件存储设备中执行的文件建立、写入、读取、修改、转存与控制等操作都是依靠文件系统来完成的。文件系统的作用是合理规划硬盘,以保证用户正常的使用需求。Linux系统支持数十种的文件系统,而最常见的文件系统如下所示。

Ext3

  是一款日志文件系统,能够在系统异常宕机时避免文件系统资料丢失,并能自动修复数据的不一致与错误。然而,当硬盘容量较大时,所需的修复时间也会很长,而且也不能百分之百地保证资料不会丢失。它会把整个磁盘的每个写入动作的细节都预先记录下来,以便在发生异常宕机后能回溯追踪到被中断的部分,然后尝试进行修复。

Ext4

  Ext3的改进版本,作为RHEL 6系统中的默认文件管理系统,它支持的存储容量高达1EB(1EB=1,073,741,824GB),且能够有无限多的子目录。另外,Ext4文件系统能够批量分配block块,从而极大地提高了读写效率。

XFS

  是一种高性能的日志文件系统,而且是RHEL 7中默认的文件管理系统,它的优势在发生意外宕机后尤其明显,即可以快速地恢复可能被破坏的文件,而且强大的日志功能只用花费极低的计算和存储性能。并且它最大可支持的存储容量为18EB,这几乎满足了所有需求。

fdisk磁盘分区管理

作用:对磁盘进行操作,分区,格式化

语法:fdisk  [选项]  device

  常用选项  -i  查看磁盘分区表

使用方法

  fdisk  /dev/sda

  1. 输入 m 显示所有命令列示。

  2. 输入 p 显示硬盘分割情形。

  3. 输入 a 设定硬盘启动区。

  4. 输入 n 设定新的硬盘分割区。

    4.1. 输入 e 硬盘为[延伸]分割区(extend)。

    4.2. 输入 p 硬盘为[主要]分割区(primary)。默认不输入为p

  5. 输入 t 改变硬盘分割区属性。(制作交换分区时会用到)

  6. 输入 d 删除硬盘分割区属性。

  7. 输入 q 结束不存入硬盘分割区属性。

  8. 输入 w 结束并写入硬盘分割区属性。

添加主分区

首先添加一块新的硬盘(要注意要在虚拟机关机的前提下才能对磁盘进行添加)

第一步查看磁盘   ls  /dev/sd*

  

 

[root@localhost ~]# ls /dev/sd*
/dev/sda  /dev/sda1  /dev/sda2  /dev/sdb  /dev/sdc

lsblk -f 也可以查看磁盘,这个命令还可以查看每个磁盘上面安装的文件系统,这个命令很重要哦

[root@localhost ~]# lsblk -f
NAME        FSTYPE      LABEL UUID                                   MOUNTPOINT
sda                                                                  
├─sda1      xfs               19cc0cdc-62b9-4e32-b5ac-c946e7ed608a   /boot
└─sda2      LVM2_member       BgwSVO-gUJY-gioG-uUWY-OgtR-hdHR-cbKwLk 
  ├─cl-root xfs               27369bc8-d775-4805-8896-7f7dd5762b06   /
  └─cl-swap swap              319fd4ba-62a8-4be2-bc04-2caded22ecfe   [SWAP]
sdb                                                                  
└─sdb1      xfs               f0ea650e-357b-4fa1-a8f6-be95982866b4   
sdc                                                                  

 

 

第二步 对sdb分配一个100M的空间

  


  root@localhost ~]# fdisk /dev/sdb              #进入磁盘管理
  欢迎使用 fdisk (util-linux 2.23.2)。

更改将停留在内存中,直到您决定将更改写入磁盘。
使用写入命令前请三思。

Device does not contain a recognized partition table
使用磁盘标识符 0xcf5dbbb2 创建新的 DOS 磁盘标签。

命令(输入 m 获取帮助):m
命令操作
   a   toggle a bootable flag
   b   edit bsd disklabel
   c   toggle the dos compatibility flag
   d   delete a partition
   g   create a new empty GPT partition table
   G   create an IRIX (SGI) partition table
   l   list known partition types
   m   print this menu
   n   add a new partition
   o   create a new empty DOS partition table
   p   print the partition table
   q   quit without saving changes
   s   create a new empty Sun disklabel
   t   change a partition's system id
   u   change display/entry units
   v   verify the partition table
   w   write table to disk and exit
   x   extra functionality (experts only)

命令(输入 m 获取帮助):p

磁盘 /dev/sdb:21.5 GB, 21474836480 字节,41943040 个扇区
Units = 扇区 of 1 * 512 = 512 bytes
扇区大小(逻辑/物理):512 字节 / 512 字节
I/O 大小(最小/最佳):512 字节 / 512 字节
磁盘标签类型:dos
磁盘标识符:0xcf5dbbb2

   设备 Boot      Start         End      Blocks   Id  System

命令(输入 m 获取帮助):n                    #建立一个新的分区
Partition type:
   p   primary (0 primary, 0 extended, 4 free)
   e   extended
Select (default p): p                    #默认为p,直接回车即可
分区号 (1-4,默认 1):
起始 扇区 (2048-41943039,默认为 2048):
将使用默认值 2048
Last 扇区, +扇区 or +size{K,M,G} (2048-41943039,默认为 41943039):+100M
分区 1 已设置为 Linux 类型,大小设为 100 MiB

命令(输入 m 获取帮助):
命令(输入 m 获取帮助):p                     #查看已经分好的磁盘

磁盘 /dev/sdb:21.5 GB, 21474836480 字节,41943040 个扇区
Units = 扇区 of 1 * 512 = 512 bytes
扇区大小(逻辑/物理):512 字节 / 512 字节
I/O 大小(最小/最佳):512 字节 / 512 字节
磁盘标签类型:dos
磁盘标识符:0xcf5dbbb2

   设备 Boot      Start         End      Blocks   Id  System
/dev/sdb1            2048      206847      102400   83  Linux

命令(输入 m 获取帮助):w                       #保存并退出,如果不想保存选择 q
The partition table has been altered!

Calling ioctl() to re-read partition table.
正在同步磁盘。

 

第三步  格式化

格式化即给新建的磁盘分区添加一个文件系统,现在常用的为 XFS文件系统  

   mkfs.xfs  /dev/sdb1

[root@localhost ~]# mkfs.xfs /dev/sdb1
mkfs.xfs: /dev/sdb1 appears to contain an existing filesystem (xfs).
mkfs.xfs: Use the -f option to force overwrite.

第四步  挂载

在挂载之前要新建一个文件夹来作为挂载点

 mkdir  /test

mount  /dev/sdb1  /test

[root@localhost /]# mkdir /test      
[root@localhost /]# mount /dev/sdb1 /test                    #挂载
[root@localhost /]# df -h                              #查看磁盘分配空间
文件系统             容量  已用  可用 已用% 挂载点
/dev/mapper/cl-root   17G  5.2G   12G   31% /
devtmpfs             473M     0  473M    0% /dev
tmpfs                489M  144K  489M    1% /dev/shm
tmpfs                489M  7.1M  482M    2% /run
tmpfs                489M     0  489M    0% /sys/fs/cgroup
/dev/sda1           1014M  173M  842M   18% /boot
tmpfs                 98M   20K   98M    1% /run/user/0
/dev/sdb1             97M  5.2M   92M    6% /test

 第五步  写入系统文件开机自启

echo  “/dev/sdb1  /test  xfs  defaults  0   0 ” >>  /etc/fstab

/dev/sdb1 ——要挂载的分区设备

/test——挂载点

xfs——文件系统类型

第一个 0 ——是否备份

第二个 0 ——是否检测

defaults——挂载选项

 

添加交换分区

  SWAP(交换)分区是一种通过在硬盘中预先划分一定的空间,然后将把内存中暂时不常用的数据临时存放到硬盘中,以便腾出物理内存空间让更活跃的程序服务来使用的技术,其设计目的是为了解决真实物理内存不足的问题。但由于交换分区毕竟是通过硬盘设备读写数据的,速度肯定要比物理内存慢,所以只有当真实的物理内存耗尽后才会调用交换分区的资源。

第一步  新建磁盘分区

fdisk  /dev/sdb

命令(输入 m 获取帮助):n
Partition type:
   p   primary (1 primary, 0 extended, 3 free)
   e   extended
Select (default p): 
Using default response p
分区号 (2-4,默认 2):
起始 扇区 (10487808-41943039,默认为 10487808):
将使用默认值 10487808
Last 扇区, +扇区 or +size{K,M,G} (10487808-41943039,默认为 41943039):+5G
分区 2 已设置为 Linux 类型,大小设为 5 GiB

命令(输入 m 获取帮助):p

磁盘 /dev/sdb:21.5 GB, 21474836480 字节,41943040 个扇区
Units = 扇区 of 1 * 512 = 512 bytes
扇区大小(逻辑/物理):512 字节 / 512 字节
I/O 大小(最小/最佳):512 字节 / 512 字节
磁盘标签类型:dos
磁盘标识符:0x6c292b76

   设备 Boot      Start         End      Blocks   Id  System
/dev/sdb1            2048    10487807     5242880   83  Linux
/dev/sdb2        10487808    20973567     5242880   83  Linux

命令(输入 m 获取帮助):w

 

第二步 格式化操作

   mkswap /dev/sdb2

[root@localhost /]# mkswap /dev/sdb2
正在设置交换空间版本 1,大小 = 5242876 KiB
无标签,UUID=c63f4ad4-00b7-48d4-87d6-caf88d96df08

第三步 挂载使用

swapon   /dev/sdb2  swap设备是挂载到设备里面的,所以不用加挂载点

[root@localhost /]# free -h
              total        used        free      shared  buff/cache   available
Mem:           976M        487M         86M        8.6M        402M        273M
Swap:          2.0G          0B        2.0G
[root@localhost /]# swapon /dev/sdb2
[root@localhost /]# free -h
              total        used        free      shared  buff/cache   available
Mem:           976M        491M         83M        8.6M        402M        270M
Swap:          7.0G          0B        7.0G

第四步  写在系统里

echo “/dev/sdb2   swap  swap  defaults  0   0”  >> /etc/fstab

 

第五步  停止swap

   swapoff  /dev/sdb2

或者 swapoff   -a

              total        used        free      shared  buff/cache   available
Mem:         999936      499740       90608        8836      409588      279980
Swap:       2097148           0     2097148
[root@localhost /]# swapoff -a
[root@localhost /]# free -h
              total        used        free      shared  buff/cache   available
Mem:           976M        486M         89M        8.6M        399M        274M
Swap:            0B          0B          0B

 

LVM ——逻辑卷管理器

在现实生活中,我们常用来存放数据的磁盘不够大了怎么办,,比如一开始规划主机的时候只给了100GB,但用户众多之后发现这个文件系统不够大,此时能怎么做,我相信大多数的朋友都是再加一块新硬盘,然后重新格式化,再将原硬盘数据拷贝过来,然后将原来的分区卸载重新挂载新的分区,如果下一次又不够了呢,随着数据越来越多工作量会越来越大,是不是听上去都很麻烦呢?那么LVM这玩意的作用就体现出来了。

什么是LVM:PV、PE、VG、LV

  LVM的全名是 Logical  Volume Manager ,中文翻译是逻辑卷管理器,是一种可以弹性的调节文件系统的容量的管理器,而不在调整性能与数据安全上面,那是RAID的工作可不要搞混了!它是在硬盘分区和文件系统之间添加了一个逻辑层,它提供了一个抽象的卷组(VG),可以把多块硬盘进行卷组合并再经过划分成为可使用的分区(LV),就可以进行挂载使用了。

物理卷(Physical  Volume  PV)

  物理卷就是LVM的基本存储逻辑块,我们实际的分区(disk)需要调整系统标识符(system ID)成为8e(LVM的标识符),然后再经过 pvcreat 的命令将它转化为LVM最底层的物理卷(PV),之后才能讲这些PV加以利用。

卷组(Volume  Group, VG)

  所谓的LVM大磁盘就是将许多的PV整合成这个VG,所以VG就是LVM组合起来的超大磁盘,那么这个磁盘最大可以到多大容量呢,

 

posted @ 2019-04-10 21:45  清风牧歌  阅读(3323)  评论(1编辑  收藏  举报