lvm的一些问题汇总-凯发app官方网站

凯发app官方网站-凯发k8官网下载客户端中心 | | 凯发app官方网站-凯发k8官网下载客户端中心
  • 博客访问: 854428
  • 博文数量: 179
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 1546
  • 用 户 组: 普通用户
  • 注册时间: 2015-01-27 11:05
个人简介

mysql工程师 qq:1815357042

文章分类

全部博文(179)

文章存档

2015年(179)

相关博文
  • ·
  • ·
  • ·
  • ·
  • ·
  • ·
  • ·
  • ·
  • ·
  • ·

分类: linux

2015-03-30 16:33:12

看了几篇文章和视频,跟啊铭老师也沟通过,下面列出啊铭老师没有说到的命令和自己的一些问题总结
rhca会考到lvm 扩容 缩容

九个查看命令
pvdisplay
vgdisplay
lvdisplay
pvs 常用
vgs 常用
lvs 常用
pvscan
vgscan
lvscan

激活命令
lvchange -ay /dev/vg0 激活,如果逻辑卷还未激活的话就激活
lvchange -an /dev/vg0  休眠


root@steven ~]# pvscan
  pv /dev/sda2   vg volgroup   lvm2 [19.51 gib / 0    free]
  total: 1 [19.51 gib] / in use: 1 [19.51 gib] / in no vg: 0 [0   ]
[root@steven ~]# vgscan
  reading all physical volumes.  this may take a while...
  found volume group "volgroup" using metadata type lvm2
[root@steven ~]# lvscan
  active            '/dev/volgroup/lv_root' [17.54 gib] inherit
  active            '/dev/volgroup/lv_swap' [1.97 gib] inherit
[root@steven ~]# pvs                   #attr不是 a-- 表示未激活  大小是19.51g  没有剩余空间
  pv                      vg           fmt      attr     psize      pfree
  /dev/sda2      volgroup     lvm2      a--      19.51g       0 
[root@steven ~]# vgs              # 这个vg下有一个pv  2个lv  大小跟pv的大小一样都是19.51g  没有剩余空间
  vg               #pv  #lv #sn      attr          vsize      vfree
  volgroup         1      2      0      wz--n-        19.51g        0 
[root@steven ~]# lvs
  lv                      vg                attr             lsize          pool origin data%  meta%  move log cpy%sync convert
  lv_root           volgroup        -wi-ao----     17.54g                                                    
  lv_swap          volgroup        -wi-ao----      1.97g      

lvreduce -l 700m /dev/vgdata/lvdata1
一般用大l 指定大小,弊端就是有可能用不完vg里面的空间
用小 l,-l 127, 127 个pe ,弊端是需要计算,比如一个pe 4m 127*4m=508m 但是不会出现用不完vg的空间的情况

问题一
使用lvreduce进行缩容的时候需要umount  ,如果apache相关文件放在/data下,你要对/data进行缩容,那么apache只能停机


问题二
扩容步骤1、先fdisk分区 
fdisk /dev/sdb
n new
l  login分区
200m  
t  分区类型
15  第15个分区
8e  lvm类型
w   保存

2、重新读取分区
partprobe  

3、建pv ,扩展vg,扩展lv,resize
pvcreate /dev/sdb15   
vgextend vg0 /dev/sdb15
lvextend –l 1g /dev/vg0/lv01  #扩展lv
resize2fs /dev/vg0/lv01    







问题三
5) 当磁盘或分区损坏时,如何转移数据
pvmove 转移空间数据 --> vgreduce命令将即将坏的磁盘或者分区从卷组vgdata里面移除除去 --> pvremove命令将即将坏的磁盘或者分区从系统中删除掉 --> 拆除或修复磁盘
pvmove /dev/sdb1 
vgreduce vgdata /dev/sdb1
pvremove  /dev/sdb1

执行pvmove 的时候,linux是把sdb1 的数据移动到别的分区




lvm配置 (参考内容,大家自行实践)
lvm是linux环境中对磁盘分区进行管理的一种机制,是建立在硬盘和分区之上、文件系统之下的一个逻辑层,可提高磁盘分区管理的灵活性。支持动态扩充磁盘空间。
首先从空的硬盘sdb上创建两个分区sdb1 1g, sdb2 2g。
1)创建逻辑卷
pvcreate /dev/sdb1 /dev/sdb2   //创建物理卷
pvdisplay   //可以列出已经创建的物理卷
vgcreate vgdata /dev/sdb1 /dev/sdb2        //创建卷组 vgdata ,并将刚才创建好的两个物理卷加入该卷组
vgdisplay //可以列出已经建好的卷组
# 默认pe大小为4mb,pe是卷组的最小存储单元.可以通过 –s参数修改大小。

lvcreate -l 500m -n lvdata1 vgdata  //分割500m给新的逻辑卷lvdata1-n :指定 lv的名字
lvdisplay //列出当前的逻辑卷

mkfs.ext4 /dev/vgdata/lvdata1  //格式化逻辑卷
mount /dev/vgdata/lvdata1  /aming  //挂载逻辑卷

2) 扩展逻辑卷
逻辑卷lvdata1不够用了,我们如何给他增加空间呢?
lvextend –l 500m /dev/vgdata/lvdata1  //给lvdata1增加500m空间。
resize2fs  /dev/vgdata/lvdata1  //同步文件系统


3)扩展卷组
当卷组不够用的情况下,我们也是可以扩展卷组的。我们再创建一个新的分区叫做/dev/sdb3.
vgextend vgdata /dev/sdb3  //把sdb3加入到卷组vgdata中

4)减少逻辑卷大小
卸载 --> e2fsck 检测剩余空间 --> resize2fs 同步文件系统 --> 使用lvreduce命令将逻辑卷减少
注意:文件系统大小和逻辑卷大小一定要保持一致才行。如果逻辑卷大于文件系统,由于部分区域未格式化成文件系统会造成空间的浪费。

umount  /data1
e2fsck -yf /dev/mapper/vgdata-lvdata1resize2fs /dev/mapper/vgdata-lvdata1 
lvreduce -l 700m /dev/vgdata/lvdata1
mount /dev/vgdata/lvdata1 /data1

5) 当磁盘或分区损坏时,如何转移数据
pvmove 转移空间数据 --> vgreduce命令将即将坏的磁盘或者分区从卷组vgdata里面移除除去 --> pvremove命令将即将坏的磁盘或者分区从系统中删除掉 --> 拆除或修复磁盘
pvmove /dev/sdb1 
vgreduce vgdata /dev/sdb1
pvremove  /dev/sdb1

6) 删除整个逻辑卷
umount卸载逻辑卷 --> 修改配置文件/etc/fstab(若是之前更改过) --> lvremove 删除逻辑卷lvdata1 --> vgremove 删除卷组vgdata --> pvremove 将物理卷转化成普通分区
umount /dev/vgdata/lvdata1 
lvremove /dev/vgdata/lvdata1
vgremove vgdata
pvremove /dev/sdb2
pvremove /dev/sdb3

=================================================
------------------------------------------------------------------------------------------------------------------
-------------------------------------------------------------------------------------------------------------------
动手实验 动态扩容和缩容

扩容
1、在线加一块磁盘
 

 

 

添加1g大小的磁盘
 

完成
 


2、在终端里面 fdisk -l 就能看到新添加的磁盘,如果看不到可以使用这个方法
地址:

  1. 确定主机总线号,磁盘是有总线连接着的
  2. [root@steven ~]# ls /sys/class/scsi_host/
  3. host0 host1 host2




  4. 重新扫描scsi总线来添加设备,因为添加的是scsi磁盘,所以扫描的是scsi总线
  5. [root@steven ~]# echo "- - -" > /sys/class/scsi_host/host0/scan
  6. [root@steven ~]# echo "- - -" > /sys/class/scsi_host/host1/scan
  7. [root@steven ~]# echo "- - -" > /sys/class/scsi_host/host2/scan

 

3、用fdisk分出一个扩展分区 ,当然分出主分区也是可以的
fdisk /dev/sdb
n new
e
500m  大小500m  (我这里只分了500m,当然用尽1g也是可以的)
w   保存
 

4、再在/dev/sdb 上分逻辑分区
  1. [root@steven ~]# fdisk /dev/sdb
复制代码
n
l
200m
p  打印出来看一下分区号
  1. device boot      start         end      blocks   id  system
  2. /dev/sdb2               1          65      522081    5  extended
  3. /dev/sdb5               1          26      208782   83  linux
复制代码
t
5
8e
w
5、重新读取分区partprobe  
partprobe

6、建pv 
pvcreate /dev/sdb5 
  1. [root@steven ~]# pvcreate /dev/sdb5 
  2.   physical volume "/dev/sdb5" successfully created
复制代码

7、查看当前系统中的vg情况
vgs
  1. [root@steven ~]# vgs
  2.   vg       #pv #lv #sn attr   vsize  vfree
  3.   volgroup   1   2   0 wz--n- 19.51g    0
复制代码
8、扩展vg   增加了200m的vg
vgextend volgroup /dev/sdb5   
  1. [root@steven ~]# vgextend volgroup /dev/sdb5
  2. .  volume group "volgroup" successfully extended
复制代码

扩容前


 


9、扩展lv

lvextend -l 200m /dev/volgroup/lv_root

设备文件名规律 /dev/vg名/lv名
  1. [root@steven dev]# lvextend -l 200m /dev/volgroup/lv_root
  2.   size of logical volume volgroup/lv_root changed from 17.54 gib (4490 extents) to 17.73 gib (4540 extents).
  3.   logical volume lv_root successfully resized
复制代码
10、同步
resize2fs  /dev/volgroup/lv_root
  1. [root@steven dev]# resize2fs  /dev/volgroup/lv_root
  2. resize2fs 1.41.12 (17-may-2010)
  3. filesystem at /dev/volgroup/lv_root is mounted on /; on-line resizing required
  4. old desc_blocks = 2, new_desc_blocks = 2
  5. performing an on-line resize of /dev/volgroup/lv_root to 4648960 (4k) blocks.
  6. the filesystem on /dev/volgroup/lv_root is now 4648960 blocks long.
复制代码

扩容后  use% 比之前少了,说明扩容成功
 


扩容时的两个谣言
1、将新的磁盘分区加入到卷组vg之前,需要对分区进行格式化为lv所用的文件系统,通过实验证明是不需要格式化的,直接加入到卷组vg即可
2、对lv进行扩容,需要先umount才能扩容,通过实验证明是不需要umount的,也就是说在apache服务或者其他服务正常运行的情况下就可以扩容


====================================================================
===============================================================
缩容

因为刚才扩容是在根分区扩容的,那么缩容涉及到umount,那么就不在根分区上面做了,我们另外新建一个分区
1、建立文件夹
mkdir /aming
  1. [root@steven ~]# mkdir /aming
复制代码

2、我们刚才还有500m的空间可以利用,我们利用250m建立一个主分区,再用250m建立另一个主分区

fdisk /dev/sdb
n
p
1
250m
t
1
8e
w
sdb1 lvm


fdisk /dev/sdb
n
p
3
220m
t
3
8e
w
sdb3  lvm

3、创建物理卷
  1.    device boot      start         end      blocks   id  system
  2. /dev/sdb1              66          98      265072   8e  linux lvm
  3. /dev/sdb2               1          65      522081    5  extended
  4. /dev/sdb3              99         127      232942   8e  linux lvm
  5. /dev/sdb5               1          26      208782   8e  linux lvm
复制代码
partprobe
pvcreate     /dev/sdb1     /dev/sdb3 
  1. [root@steven ~]# pvcreate /dev/sdb1
  2.   physical volume "/dev/sdb1" successfully created
  3. [root@steven ~]# pvcreate /dev/sdb3
  4.   physical volume "/dev/sdb3" successfully created
复制代码
4、查看物理卷pvs
 

5、创建卷组vgdata
vgcreate vgdata /dev/sdb1
  1. [root@steven ~]# vgcreate vgdata /dev/sdb1
  2.   volume group "vgdata" successfully created
复制代码

查看卷组
 

6、创建逻辑卷
lvcreate -l 240m -n lvdata1 vgdata
  1. [root@steven ~]# lvcreate -l 240m -n lvdata1 vgdata
  2.   logical volume "lvdata1" created
复制代码
查看逻辑卷
lvs
 

7、格式化逻辑卷mkfs.ext4  /dev/vgdata/lvdata1
  1. [root@steven ~]# mkfs.ext4 /dev/vgdata/lvdata1
  2. mke2fs 1.41.12 (17-may-2010)
  3. 文件系统标签=
  4. 操作系统:linux
  5. 块大小=1024 (log=0)
  6. 分块大小=1024 (log=0)
  7. stride=0 blocks, stripe width=0 blocks
  8. 61440 inodes, 245760 blocks
  9. 12288 blocks (5.00%) reserved for the super user
  10. 第一个数据块=1
  11. maximum filesystem blocks=67371008
  12. 30 block groups
  13. 8192 blocks per group, 8192 fragments per group
  14. 2048 inodes per group
  15. superblock backups stored on blocks: 
  16.         8193, 24577, 40961, 57345, 73729, 204801, 221185

  17. 正在写入inode表: 完成                            
  18. creating journal (4096 blocks): 完成
  19. writing superblocks and filesystem accounting information: 完成

  20. this filesystem will be automatically checked every 24 mounts or
  21. 180 days, whichever comes first.  use tune2fs -c or -i to override.
复制代码

8、挂载 如果要永久挂载 就要写在/etc/fstab 文件里面
mount /dev/vgdata/lvdata1  /aming
  1. [root@steven ~]# cd /aming
  2. [root@steven aming]# ls
  3. lost found
复制代码
fdisk -l
  1. disk /dev/mapper/vgdata-lvdata1: 251 mb, 251658240 bytes
  2. 255 heads, 63 sectors/track, 30 cylinders
  3. units = cylinders of 16065 * 512 = 8225280 bytes
  4. sector size (logical/physical): 512 bytes / 512 bytes
  5. i/o size (minimum/optimal): 512 bytes / 512 bytes
  6. disk identifier: 0x00000000
复制代码

9、扩展vg ,将sdb3加进来
vgextend  vgdata  /dev/sdb3
  1. [root@steven aming]# vgextend  vgdata  /dev/sdb3
  2.   volume group "vgdata" successfully extended
复制代码
10、扩展lv
lvextend -l 230m /dev/vgdata/lvdata1
  1. [root@steven aming]# lvextend -l 230m /dev/vgdata/lvdata1
  2.   rounding size to boundary between physical extents: 232.00 mib
  3.   size of logical volume vgdata/lvdata1 changed from 240.00 mib (60 extents) to 472.00 mib (118 extents).
  4.   logical volume lvdata1 successfully resized
复制代码

11、同步
resize2fs   /dev/vgdata/lvdata1
  1. [root@steven aming]# resize2fs   /dev/vgdata/lvdata1
  2. resize2fs 1.41.12 (17-may-2010)
  3. filesystem at /dev/vgdata/lvdata1 is mounted on /aming; on-line resizing required
  4. old desc_blocks = 1, new_desc_blocks = 2
  5. performing an on-line resize of /dev/vgdata/lvdata1 to 483328 (1k) blocks.
  6. the filesystem on /dev/vgdata/lvdata1 is now 483328 blocks long.
复制代码
查看空间占用df -h
 


缩容
12、减少逻辑卷大小
先cd回去root目录 cd
umount -l  /aming  强制卸载


13、e2fsck 检测剩余空间
e2fsck -yf /dev/vgdata/lvdata1
-yf:不询问
  1. [root@steven ~]# e2fsck -yf /dev/vgdata/lvdata1
  2. e2fsck 1.41.12 (17-may-2010)
  3. 第一步: 检查inode,块,和大小
  4. 第二步: 检查目录结构
  5. 第3步: 检查目录连接性
  6. pass 4: checking reference counts
  7. 第5步: 检查簇概要信息
  8. /dev/vgdata/lvdata1: 13/120832 files (0.0% non-contiguous), 21656/483328 blocks
复制代码

14、resize2fs 同步文件系统 
resize2fs  -f /dev/vgdata/lvdata1
  1. [root@steven ~]# resize2fs  -f /dev/vgdata/lvdata1
  2. resize2fs 1.41.12 (17-may-2010)
  3. the filesystem is already 483328 blocks long.  nothing to do!
复制代码

15、使用lvreduce命令将逻辑卷减少注意:文件系统大小和逻辑卷大小一定要保持一致才行。如果逻辑卷大于文件系统,由于部分区域未格式化成文件系统会造成空间的浪费。
lvreduce -l -230m /dev/vgdata/lvdata1
  1. [root@steven ~]# lvreduce -l -230m /dev/vgdata/lvdata1
  2.   rounding size to boundary between physical extents: 228.00 mib
  3.   warning: reducing active logical volume to 244.00 mib
  4.   this may destroy your data (filesystem etc.)
  5. do you really want to reduce lvdata1? [y/n]: y
  6.   size of logical volume vgdata/lvdata1 changed from 472.00 mib (118 extents) to 244.00 mib (61 extents).
  7.   logical volume lvdata1 successfully resized
复制代码

16、重新挂载
mount  /dev/vgdata/lvdata1  /aming

不知道为何superblock损坏,mount不上[root@steven ~]# mount  /dev/vgdata/lvdata1  /aming
mount: wrong fs type, bad option, bad superblock on /dev/mapper/vgdata-lvdata1,
       missing codepage or helper program, or other error
       in some cases useful info is found in syslog - try
       dmesg | tail  or so

===================================================================================================================
删除lvm

1、umount卸载逻辑卷
先cd回去root目录 cd
umount -l  /aming  强制卸载


修改配置文件/etc/fstab(若是之前更改过) 


2、lvremove 删除逻辑卷lvdata1
lvremove  /dev/vgdata/lvdata1
  1. [root@steven ~]# lvremove  /dev/vgdata/lvdata1
  2. do you really want to remove active logical volume lvdata1? [y/n]: y
  3.   logical volume "lvdata1" successfully removed
复制代码

3、vgremove 删除卷组
vgremove  vgdata
  1. [root@steven ~]# vgremove  vgdata
  2.   volume group "vgdata" successfully removed
复制代码

4、pvremove 将物理卷转化成普通分区
pvremove /dev/sdb1  /dev/sdb3

  1. [root@steven ~]# pvremove /dev/sdb1  /dev/sdb3
  2.   labels on physical volume "/dev/sdb1" successfully wiped
  3.   labels on physical volume "/dev/sdb3" successfully wiped
复制代码

5、将sdb1和sdb3 转换回 83 linux分区类型
fdisk /dev/sdb
l
  1. command (m for help): l

  2. 0  empty           24  nec dos         81  minix / old lin bf  solaris        
  3. 1  fat12           39  plan 9          82  linux swap / so c1  drdos/sec (fat-
  4. 2  xenix root      3c  partitionmagic  83  linux   
复制代码
t
1
t
3
w
6、查看分区类型
partprobe
fdisk -l
  1. disk /dev/sdb: 1073 mb, 1073741824 bytes
  2. 255 heads, 63 sectors/track, 130 cylinders
  3. units = cylinders of 16065 * 512 = 8225280 bytes
  4. sector size (logical/physical): 512 bytes / 512 bytes
  5. i/o size (minimum/optimal): 512 bytes / 512 bytes
  6. disk identifier: 0xf27bd8ef

  7.    device boot      start         end      blocks   id  system
  8. /dev/sdb1              66          98      265072   83  linux
  9. /dev/sdb2               1          65      522081    5  extended
  10. /dev/sdb3              99         127      232942   83  linux
  11. /dev/sdb5               1          26      208782   8e  linux lvm
复制代码

7、格式化 sdb1和sdb3
mkfs -t ext4 /dev/sdb1 
mkfs -t ext4 /dev/sdb3
  1. [root@steven aming]# mkfs -t ext4 /dev/sdb3
  2. mke2fs 1.41.12 (17-may-2010)
  3. 文件系统标签=
  4. 操作系统:linux
  5. 块大小=1024 (log=0)
  6. 分块大小=1024 (log=0)
  7. stride=0 blocks, stripe width=0 blocks
  8. 58464 inodes, 232940 blocks
  9. 11647 blocks (5.00%) reserved for the super user
  10. 第一个数据块=1
  11. maximum filesystem blocks=67371008
  12. 29 block groups
  13. 8192 blocks per group, 8192 fragments per group
  14. 2016 inodes per group
  15. superblock backups stored on blocks: 
  16.         8193, 24577, 40961, 57345, 73729, 204801, 221185

  17. 正在写入inode表: 完成                            
  18. creating journal (4096 blocks): 完成
  19. writing superblocks and filesystem accounting information: 完成

  20. this filesystem will be automatically checked every 38 mounts or
  21. 180 days, whichever comes first.  use tune2fs -c or -i to override.
复制代码

8、创建目录
[root@steven ~]# mkdir /testsdb1
[root@steven ~]# mkdir /testsdb3




9、挂载
[root@steven ~]# mount /dev/sdb1 /testsdb1
[root@steven ~]# mount /dev/sdb3 /testsdb3


10、查看挂载情况
  1. [root@steven testsdb3]# mount
  2. /dev/mapper/volgroup-lv_root on / type ext4 (rw)
  3. proc on /proc type proc (rw)
  4. sysfs on /sys type sysfs (rw)
  5. devpts on /dev/pts type devpts (rw,gid=5,mode=620)
  6. tmpfs on /dev/shm type tmpfs (rw)
  7. /dev/sda1 on /boot type ext4 (rw)
  8. none on /proc/sys/fs/binfmt_misc type binfmt_misc (rw)
  9. sunrpc on /var/lib/nfs/rpc_pipefs type rpc_pipefs (rw)
  10. /dev/sdb1 on /testsdb1 type ext4 (rw)
  11. /dev/sdb3 on /testsdb3 type ext4 (rw)
复制代码

11、卸载先cd 回根目录
[root@steven testsdb3]# umount  -l /testsdb3
[root@steven testsdb3]# umount  -l /testsdb1



12、删除sdb1和sdb3fdisk /dev/sdb
d
1
d
3
w

partprobe
fdisk -l
  1.   device boot      start         end      blocks   id  system
  2. /dev/sdb2               1          65      522081    5  extended
  3. /dev/sdb5               1          26      208782   8e  linux lvm
复制代码

阅读(7223) | 评论(0) | 转发(1) |
0

上一篇:

下一篇:

给主人留下些什么吧!~~
")); function link(t){ var href= $(t).attr('href'); href ="?url=" encodeuricomponent(location.href); $(t).attr('href',href); //setcookie("returnouturl", location.href, 60, "/"); }
网站地图