1 LVM介绍

  LVM即logical volume manager逻辑卷管理,其主要特点是:可以动态地扩大和缩小分区大小,但前提是分区的文件系统必须是LVM格式的,lvm的实现需要安装lvm2软件包,一般在安装centos系统都已经一起安装好.

[root@test ~]# rpm -qa lvm2
lvm2-2.02.180-8.el7.x86_64

  LVM优点是:可以实现逻辑卷的动态扩容或收缩;但缺点是:性能较差,因为是以软件方式实现的,丢失数据的风险比较大,数据丢失后恢复较为困难.

1.1 与LVM相关的及个术语

  LVM可以让磁盘分区实现扩容和缩小,但前提是,该分区必须是lvm格式的.磁盘使用MBR分区表格式,lvm的标识符是8e;使用gpt分区表格式,则其lvm标识符是8300.

  与LVM相关的几个术语,分别是:

  名称    说明
  PV (物理卷Physical Volume)

底层物理磁盘分区(分区但未格式化)的磁盘标识符必须为8e或8300,

使用pvcreate命令将其创建为PV,才可以被LVM使用.

  VG (卷组Volume Group)  使用vgcreate命令将多个PV组合创建为VG.

  PE (物理存储单元,实际数据存储

  单元Physical Extend)

 PE是VG中的物理存储单元,存储的是实际的数据.
  LV (逻辑卷Logical Volume)

LV是通过VG划分得到的其中一个分区,VG中以PE为单元,指定划分多少个

PE给LV,然后LV再进行格式化创建文件系统来使用.

  LE (逻辑存储单元Logical Extent)

LE是LV中逻辑存储单元,其大小与PE一样,从VG中划分LV,实质是将VG中的

一部分(或全部)PE分配给LV.

  LVM实现动态扩容就是往LV中添加空闲未被使用的PE;而实现动态收缩则是将LV中空闲的PE抽出(收缩有丢失数据的危险).

  LVM的实现依赖于内核中的dm(device mapper设备映射)模块,dm模块可以将一个或者多个底层的设备组织成为一个逻辑设备.

###VG及LV的路径定义(下面#代表数字)
/dev/dm-#
###有2个符号链接文件分别指向
[root@localhost ~]# ll /dev/mapper/ #<==创建了VG和LV后,此目录下有软链接
总用量 0
lrwxrwxrwx 1 root root 7 12月 15 16:58 centos-root -> ../dm-0
lrwxrwxrwx 1 root root 7 12月 15 16:58 centos-swap -> ../dm-1
###VG与LV软链接文件名称(以下2个都是软链接,VG与LV名称是创建时自定义的名称)
/dev/mapper/VG_NAME-LV_NAME
/dev/VG_NAME/LV_NAME

1.3 图解LVM的实现

1.4 LVM的数据写入机制

  因为LV是通过VG划分的,LV中的PE可能来自多个PE,在向LV存储数据时,有2种主要的存储机制,分别是:

  1) 线性模式(linear):现写完同一个PV中的PE,再写来自下一个PV中的PE,默认就是此种模式.

  2) 条带模式(striped):将数据拆分为多份,再往该LV对应的多个PV上存储,此种模式读写性能较好.但不建议使用此模式,因为扩容和收缩容量时较为麻烦.

  LVM的主要作用是实现逻辑卷的弹性扩展,不追求性能,追求性能就使用raid.

2 管理LVM的相关命令

2.1 管理LVM上的PV

  PV管理涉及到的命令:

命令 说明
pvcreate 创建pv
pvdisplay

列出pv详细信息(PV name/size及所属的VG等)

次此命令有一个重要的参数 -m ,可以查看该PV中

PE的使用分布,只有知道PE的分布,才能使用pvmove

在不同的PV之间进行PE数据的移动

pvcan 扫描并显示所有pv
pvmove 移动pv中的数据,通常用于收缩LVM磁盘
pvremove 移除pv
pvs 简要显示pv信息

2.2 管理LVM上的VG

  管理VG的相关命令有:

命令 说明
vgcreate

创建VG,其常用选项是 -s ,指定PE的大小,不

指定就默认PE的大小是 4M

vgscan 扫描并列出所有VG
vgdisplay 显示VG的详细信息
vgremove 移除/删除VG
vgreduce

从VG中移除PV(注意:先做pvmove操作,先移动

有数据的PE至其他空闲PV上的PE)

vgextend 将PV添加到VG(扩容VG)
vgchange

修改VG的属性信息(如VG的激活状态,VG的激活

状态会影响LV的使用)

2.3 管理LVM上的LV

  在VG的基础上就可以对VG进行分区,创建LV,管理LV的相关命令有:

命令 说明
lvcreate

创建LV,主要选项有:

lvcreate {-L size(M/G) | -l PEnum} -n lv_name vg_name

lvscan 扫描并列出所有的lv
lvdisplay 显示lv详细信息
lvremove 移除/删除lv
lvreduce 收缩lv容量
lvextend 扩容lv容量
lvresize 改变lv容量(lvredunce及lvextend可以使用lvresize命令统一实现)

2.4 格式化创建文件系统

  在LV基础上,就可以对LV进行格式化创建文件系统,挂载使用了.

LVM知识梳理的更多相关文章

  1. MySQL 基础知识梳理

    MySQL 的安装方式有多种,但是对于不同场景,会有最适合该场景的 MySQL 安装方式,下面就介绍一下 MySQL 常见的安装方法,包括 rpm 安装,yum 安装,通用二进制安装以及源码编译安装, ...

  2. [SQL] SQL 基础知识梳理(一)- 数据库与 SQL

    SQL 基础知识梳理(一)- 数据库与 SQL [博主]反骨仔 [原文地址]http://www.cnblogs.com/liqingwen/p/5902856.html 目录 What's 数据库 ...

  3. [SQL] SQL 基础知识梳理(二) - 查询基础

    SQL 基础知识梳理(二) - 查询基础 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5904824.html 序 这是<SQL 基础知识梳理( ...

  4. [SQL] SQL 基础知识梳理(三) - 聚合和排序

    SQL 基础知识梳理(三) - 聚合和排序 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5926689.html 序 这是<SQL 基础知识梳理 ...

  5. [SQL] SQL 基础知识梳理(四) - 数据更新

    SQL 基础知识梳理(四) - 数据更新 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5929786.html 序 这是<SQL 基础知识梳理( ...

  6. [SQL] SQL 基础知识梳理(五) - 复杂查询

    SQL 基础知识梳理(五) - 复杂查询 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5939796.html 序 这是<SQL 基础知识梳理( ...

  7. solr DIH 知识梳理

    solr DIH 知识梳理 web.xml中listener配置 <listener> <listener-class>org.apache.solr.handler.data ...

  8. Anliven - 基础知识梳理汇总 - 软件测试

    基础知识梳理 - 软件测试 - 概念 基础知识梳理 - 软件测试 - 分类 基础知识梳理 - 软件测试 - 流程 基础知识梳理 - 软件测试 - 用例 基础知识梳理 - 软件测试 - 方法 基础知识梳 ...

  9. [C# 基础知识梳理系列]专题六:泛型基础篇——为什么引入泛型

    引言: 前面专题主要介绍了C#1中的2个核心特性——委托和事件,然而在C# 2.0中又引入一个很重要的特性,它就是泛型,大家在平常的操作中肯定会经常碰到并使用它,如果你对于它的一些相关特性还不是很了解 ...

随机推荐

  1. P1640 [SCOI2010]连续攻击游戏 二分图最大匹配 匈牙利算法

    题目描述 lxhgww最近迷上了一款游戏,在游戏里,他拥有很多的装备,每种装备都有2个属性,这些属性的值用[1,10000]之间的数表示.当他使用某种装备时,他只能使用该装备的某一个属性.并且每种装备 ...

  2. 简单的 FFT 变形 - BZOJ 2194

    「BZOJ2194」快速傅立叶之二 2015年4月29日3,8300 Description 请计算C[k]=sigma(a[i]*b[i-k]) 其中 k < = i < n ,并且有 ...

  3. 求树上任意一点所能到达的最远距离 - 树上dp

    A school bought the first computer some time ago(so this computer's id is 1). During the recent year ...

  4. hadoop 基础

    common 一组分布式文件系统和通用I/O的组件与接口(序列化.java RPC和持久化数据结构) Avro 一种支持高效.跨语言的RPC以及永久存储数据的序列化系统 MapReduce 分布式数据 ...

  5. RabbitMQ入门(二)工作队列

      在文章RabbitMQ入门(一)之Hello World,我们编写程序通过指定的队列来发送和接受消息.在本文中,我们将会创建工作队列(Work Queue),通过多个workers来分配耗时任务. ...

  6. 如何添加.pch文件

    1.Create a pch , call name is project+xxx.pch For example: DuoME-PrefixHeader.pch 2.在project——>Bu ...

  7. [bzoj2004] [洛谷P3204] [Hnoi2010] Bus 公交线路

    Description 小Z所在的城市有N个公交车站,排列在一条长(N-1)km的直线上,从左到右依次编号为1到N,相邻公交车站间的距 离均为1km. 作为公交车线路的规划者,小Z调查了市民的需求,决 ...

  8. CTF-Keylead(ASIS CTF 2015)

    将keylead下载到本地用7-ZIP打开,发现主要文件 keylead~ 在ubuntu里跑起来,发现是个游戏,按回车后要摇出3,1,3,3,7就能获得flag. 拖进IDA 直接开启远程调试,跑起 ...

  9. 微服务的多数据源配置: step 1

    spring boot + mybatis: 实现的功能点: 多数据源 jdbc: spring.datasource.test1.url = jdbc:mysql://localhost:3306/ ...

  10. 创建一个区域(Creating an Area) |使用区域 | 高级路由特性 | 精通ASP-NET-MVC-5-弗瑞曼

    摘自:http://www.cnblogs.com/chenboyi081/p/4472709.html#tar2015050302 下面的AdminAreaRegistration继承自AreaRe ...