LVM知识梳理
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知识梳理的更多相关文章
- MySQL 基础知识梳理
MySQL 的安装方式有多种,但是对于不同场景,会有最适合该场景的 MySQL 安装方式,下面就介绍一下 MySQL 常见的安装方法,包括 rpm 安装,yum 安装,通用二进制安装以及源码编译安装, ...
- [SQL] SQL 基础知识梳理(一)- 数据库与 SQL
SQL 基础知识梳理(一)- 数据库与 SQL [博主]反骨仔 [原文地址]http://www.cnblogs.com/liqingwen/p/5902856.html 目录 What's 数据库 ...
- [SQL] SQL 基础知识梳理(二) - 查询基础
SQL 基础知识梳理(二) - 查询基础 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5904824.html 序 这是<SQL 基础知识梳理( ...
- [SQL] SQL 基础知识梳理(三) - 聚合和排序
SQL 基础知识梳理(三) - 聚合和排序 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5926689.html 序 这是<SQL 基础知识梳理 ...
- [SQL] SQL 基础知识梳理(四) - 数据更新
SQL 基础知识梳理(四) - 数据更新 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5929786.html 序 这是<SQL 基础知识梳理( ...
- [SQL] SQL 基础知识梳理(五) - 复杂查询
SQL 基础知识梳理(五) - 复杂查询 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5939796.html 序 这是<SQL 基础知识梳理( ...
- solr DIH 知识梳理
solr DIH 知识梳理 web.xml中listener配置 <listener> <listener-class>org.apache.solr.handler.data ...
- Anliven - 基础知识梳理汇总 - 软件测试
基础知识梳理 - 软件测试 - 概念 基础知识梳理 - 软件测试 - 分类 基础知识梳理 - 软件测试 - 流程 基础知识梳理 - 软件测试 - 用例 基础知识梳理 - 软件测试 - 方法 基础知识梳 ...
- [C# 基础知识梳理系列]专题六:泛型基础篇——为什么引入泛型
引言: 前面专题主要介绍了C#1中的2个核心特性——委托和事件,然而在C# 2.0中又引入一个很重要的特性,它就是泛型,大家在平常的操作中肯定会经常碰到并使用它,如果你对于它的一些相关特性还不是很了解 ...
随机推荐
- P1640 [SCOI2010]连续攻击游戏 二分图最大匹配 匈牙利算法
题目描述 lxhgww最近迷上了一款游戏,在游戏里,他拥有很多的装备,每种装备都有2个属性,这些属性的值用[1,10000]之间的数表示.当他使用某种装备时,他只能使用该装备的某一个属性.并且每种装备 ...
- 简单的 FFT 变形 - BZOJ 2194
「BZOJ2194」快速傅立叶之二 2015年4月29日3,8300 Description 请计算C[k]=sigma(a[i]*b[i-k]) 其中 k < = i < n ,并且有 ...
- 求树上任意一点所能到达的最远距离 - 树上dp
A school bought the first computer some time ago(so this computer's id is 1). During the recent year ...
- hadoop 基础
common 一组分布式文件系统和通用I/O的组件与接口(序列化.java RPC和持久化数据结构) Avro 一种支持高效.跨语言的RPC以及永久存储数据的序列化系统 MapReduce 分布式数据 ...
- RabbitMQ入门(二)工作队列
在文章RabbitMQ入门(一)之Hello World,我们编写程序通过指定的队列来发送和接受消息.在本文中,我们将会创建工作队列(Work Queue),通过多个workers来分配耗时任务. ...
- 如何添加.pch文件
1.Create a pch , call name is project+xxx.pch For example: DuoME-PrefixHeader.pch 2.在project——>Bu ...
- [bzoj2004] [洛谷P3204] [Hnoi2010] Bus 公交线路
Description 小Z所在的城市有N个公交车站,排列在一条长(N-1)km的直线上,从左到右依次编号为1到N,相邻公交车站间的距 离均为1km. 作为公交车线路的规划者,小Z调查了市民的需求,决 ...
- CTF-Keylead(ASIS CTF 2015)
将keylead下载到本地用7-ZIP打开,发现主要文件 keylead~ 在ubuntu里跑起来,发现是个游戏,按回车后要摇出3,1,3,3,7就能获得flag. 拖进IDA 直接开启远程调试,跑起 ...
- 微服务的多数据源配置: step 1
spring boot + mybatis: 实现的功能点: 多数据源 jdbc: spring.datasource.test1.url = jdbc:mysql://localhost:3306/ ...
- 创建一个区域(Creating an Area) |使用区域 | 高级路由特性 | 精通ASP-NET-MVC-5-弗瑞曼
摘自:http://www.cnblogs.com/chenboyi081/p/4472709.html#tar2015050302 下面的AdminAreaRegistration继承自AreaRe ...