TranslateProject/sources/tech/20141013 Manage Multiple Logical Volume Management Disks using Striping I O--Part V.md
2014-10-13 10:03:28 +08:00

8.1 KiB
Raw Blame History

Manage Multiple Logical Volume Management Disks using Striping I/O

In this article, we are going to see how the logical volumes writes the data to disk by striping I/O. Logical Volume management has one of the cool feature which can write data over multiple disk by striping the I/O.

Manage LVM Disks Using Striping I/O

Manage LVM Disks Using Striping I/O

What is LVM Striping?

LVM Striping is one of the feature which will writes the data over multiple disk, instead of constant write on a single Physical volume.

Features of Striping

  • It will increase the performance of disk.
  • Saves from hard write over and over to a single disk.
  • Disk fill-up can be reduced using striping over multiple disk.

In Logical volume management, if we need to create a logical volume the extended will get fully mapped to the volume group and physical volumes. In such situation if one of the PV (Physical Volume) gets filled we need to add more extends from other physical volume. Instead, adding more extends to PV, we can point our logical volume to use the particular Physical volumes writing I/O.

Assume we have four disks drives and pointed to four physical volumes, if each physical volume are capable of 100 I/O totally our volume group will get 400 I/O.

If we are not using the stripe method, the file system will writes across the underlying physical volume. For example, some data writes to physical volume 100 I/O will be write only to the first (sdb1) PV. If we create the logical volume with stripe option while writing, it will write to every four drives by splitting 100 I/O, that means every four drive will receive 25 I/O each.

This will be done in round robin process. If any one of the logical volume need to be extended, in this situation we cant add 1 or 2 PV. We have to add all 4 pvs to extend the logical volume size. This is one of the drawback in stripe feature, from this we can know that while creating logical volumes we need to assign the same stripe size over all logical volumes.

Logical Volume management has these features which we can stripe the data over multiple pvs at the same time. If you are familiar with logical volume you can go head to setup the logical volume stripe. If not then you must need to know about the logical volume managements basics, read below articles to know more about logical volume management.

My Server Setup

Here Im using Centos6.5 for my workout. The same steps can be used in RHEL, Oracle Linux, and most of the distributions.

Operating System :	CentOS 6.5
IP Address :		192.168.0.222
Hostname : 		tecmint.storage.com

Logical Volume management using Striping I/O

For demonstration purpose, Ive used 4 Hard drives, each drive with 1 GB in Size. Let me show you four drives using fdisk command as shown below.

# fdisk -l | grep sd

List Hard Drives

List Hard Drives

Now weve to create partitions for these 4 hard drives sdb, sdc, sdd and sde using fdisk command. To create partitions, please follow the step #4 instructions, given in the Part 1 of this article (link give above) and make sure you change the type to LVM (8e), while creating partitions.

# pvcreate /dev/sd[b-e]1 -v

Create Physical Volumes in LVM

Create Physical Volumes in LVM

Once PVs created, you can list them using pvs command.

# pvs

Verify Physical Volumes

Verify Physical Volumes

Now we need to define volume group using those 4 physical volumes. Here Im defining my volume group with 16MB of Physical extended size (PE) with volume group named as vg_strip.

# vgcreate -s 16M vg_strip /dev/sd[b-e]1 -v

The description of above options used in the command.

  • [b-e]1 Define your hard drive names such as sdb1, sdc1, sdd1, sde1.
  • -s Define your physical extent size.
  • -v verbose.

Next, verify the newly created volume group using.

# vgs vg_strip

Verify Volume Group

Verify Volume Group

To get more detailed information about VG, use switch -v with vgdisplay command, it will give us a every physical volumes which all used in vg_strip volume group.

# vgdisplay vg_strip -v

Volume Group Information

Volume Group Information

Back to our topic, now while creating Logical volume, we need to define the stripe value, how data need to write in our logical volumes using stripe method.

Here Im creating a logical volume in the name of lv_tecmint_strp1 with 900MB size, and it needs to be in vg_strip volume group, and Im defining as 4 stripe, it means the data writes to my logical volume, needs to be stripe over 4 PVs.

# lvcreate -L 900M -n lv_tecmint_strp1 -i4 vg_strip
  • -L logical volume size
  • -n logical volume name
  • -i stripes

Create Logical Volumes

Create Logical Volumes

In the above image, we can see that the default size of stripe-size was 64 KB, if we need to define our own stripe value, we can use -I (Capital I). Just to confirm that the logical volume are created use the following command.

# lvdisplay vg_strip/lv_tecmint_strp1

Confirm Logical Volumes

Confirm Logical Volumes

Now next question will be, How do we know that stripes are writing to 4 drives?. Here we can use lvdisplay and -m (display the mapping of logical volumes) command to verify.

# lvdisplay vg_strip/lv_tecmint_strp1 -m

Check Logical Volumes

Check Logical Volumes

To create our defined stripe size, we need to create one logical volume with 1GB size using my own defined Stripe size of 256KB. Now Im going to stripe over only 3 PVs, here we can define which pvs we want to be striped.

# lvcreate -L 1G -i3 -I 256 -n lv_tecmint_strp2 vg_strip /dev/sdb1 /dev/sdc1 /dev/sdd1

Define Stripe Size

Define Stripe Size

Next, check the stripe size and which volume does it stripes.

# lvdisplay vg_strip/lv_tecmint_strp2 -m

Check Stripe Size

Check Stripe Size

Its time to use a device mapper, for this we use command dmsetup. It is a low level logical volume management tool which manages logical devices, that use the device-mapper driver. We can see the lvm information using dmsetup command to know the which stripe depends on which drives.

# dmsetup deps /dev/vg_strip/lv_tecmint_strp[1-2]

Device Mapper

Device Mapper

Here we can see that strp1 depend on 4 drives, and strp2 depend on 3 devices.

Hope you have learnt, that how we can stripe through logical volumes to write the data. For this setup one must know about the basic of logical volume management. In my next article, I will show you how we can migrate in logical volume management, till then stay tuned for updates and dont forget to give valuable comments about the article.


via: http://www.tecmint.com/manage-multiple-lvm-disks-using-striping-io/

作者:Babin Lonston 译者:译者ID 校对:校对者ID

本文由 LCTT 原创翻译,Linux中国 荣誉推出