第五週-磁碟分割槽GPT、shell指令碼練習、lvm詳解
1、 描述GPT是什麼,應該怎麼使用
Linux中磁碟分割槽分為MBR和GPT。
MBR全稱為Master Boot Record,為主引導記錄,是傳統的分割槽機制,應用於絕大多數使用的BIOS的PC裝置。
MBR分割槽的特點:
1、MBR支援32位和64位的系統
2、MBR支援分割槽數量有限
3、MBR只支援不超過2T的硬碟,超過2T的硬碟將只能用2T空間。
GPT(全稱為GUID Partition Table)分割槽為全域性唯一分割槽表,是一個較新的分割槽機制,解決了MBR很多缺點
GPT分割槽的特點:
1、支援超過2T的磁碟(64位定址)。Fdisk最大隻能建立2TB大小的分割槽
2、向後相容MBR
3、必須在支援UEFI的硬體上才能使用(Intel提出,用於取代BIOS)
4、 必須使用64位系統
5、 Mac、Linux、Windows7/8 64bit、windows Server2008 64bits系統都能支援GPT分割槽格式
GPT磁碟分割槽是使用parted工具實現的:
Parted用法個常用選項:
用法:parted [選項]… [裝置 [ 命令 [引數]… ]… ]
將帶有引數的命令用於裝置。如果沒有出現命令,則以互動模式執行。
幫助選項:
-h,--help 顯示此幫助資訊
-l , --list 列出所有裝置的分割槽資訊
-I , --interactive 在必要是,提示使用者
-s, --script 從不提示使用者
-v , --version 顯示版本
操作命令:
Minot # 對檔案系統進行一個簡單的檢查
cp [FROM-DEVICE] FROM-MINOR TO-MINOR #將檔案系統複製到另一個分割槽
help [COMMAND] #列印通用求助資訊,或關於command資訊
mklable 標籤型別 #建立新的磁碟標籤(分割槽表)
mkfs MINOR 檔案系統型別 #在MINOR建立型別為“檔案系統型別”的檔案系統
mkpart 分割槽型別 [檔案系統型別] 起始點 終止點 #建立一個分割槽
mkpartfs 分割槽型別 檔案系統型別 起始點 終止點 #建立一個帶有檔案系統的分割槽
move MINOR 起始點 終止點 #移動編號為MINOR的分割槽
name MINOR 名稱 #將編號為MINOR的分割槽命名為“名稱”
print [MINOR] #列印分割槽表,或者分割槽
quit #退出程式
rescue 起始點 終止點 #挽救臨近“起始點”、“終止點”的遺失的分割槽
resize MINOR 起始點 終止點 #改變位於編號為 MINOR 的分割槽中檔案系統的大小
rm MINOR #刪除編號為 MINOR 的分割槽
select 裝置 #選擇要編輯的裝置
set MINOR 標誌 狀態 #改變編號為 MINOR 的分割槽的標誌
示例:
步驟1、使用parted 工具在裝置/dev/sdb上建立磁碟分割槽
1 [[email protected] ~]# parted /dev/sdb 2 3 GNU Parted 3.1 4 5 Using /dev/sdb 6 7 Welcome to GNU Parted! Type 'help' to view a list of commands. 8 9 (parted) 10 11
步驟2、接下來需要建立一個分割槽表(在parted中可以使用help命令列印幫助資訊):
(parted) mklabel New disk label type? gpt #我們要正確分割槽大於2TB的磁碟,應該使用gpt方式的分割槽表,輸入gpt後回車) (parted) mkpart Partition name? []? myNewGPT #輸入建立新區的名字 File system type? [ext2]? ext4 #輸入建立資訊的檔案系統的型別,如果為ext2型別可直接按回車鍵 Start? 0 #輸入分割槽的起始點 End? 5G #輸入分割槽的終止點;GPT分割槽和MBR分割槽不同,這裡可直接輸入起始點如從0開始到5G大小 Warning: The resulting partition is not properly aligned for best performance. #這裡警告新建分割槽會格式化分割槽內容 Ignore/Cancel? I #忽略/取消 (parted)
步驟3、我們已經建立好了一個分割槽,下面使用print命令打印出來看
(parted) print Model: VMware, VMware Virtual S (scsi) Disk /dev/sdb: 21.5GB Sector size (logical/physical): 512B/512B Partition Table: gpt Disk Flags: Number Start End Size File system Name Flags 1 17.4kB 5000MB 5000MB myNewGPT (parted)
步驟4、如果分割槽錯了,可以使用rm命令刪除分割槽,後面跟分割槽的編號,比如我們要刪除上面的分割槽1,然後列印刪除後的結果
(parted) rm 1 (parted) print Model: VMware, VMware Virtual S (scsi) Disk /dev/sdb: 21.5GB Sector size (logical/physical): 512B/512B Partition Table: gpt Disk Flags:
Number Start End Size File system Name Flags
(parted)
步驟5、由於parted內建的mkfs還不夠完善,所以完成以後我們可以使用quit命令退出parted並使用 系統的mkfs命令對分割槽進行格式化了,此時如果使用fdisk -l命令列印分割槽表會出現警告資訊,這是正常的
[[email protected] ~]# fdisk -l /dev/sdb WARNING: fdisk GPT support is currently new, and therefore in an experimental phase. Use at your own discretion. Disk /dev/sdb: 21.5 GB, 21474836480 bytes, 41943040 sectors Units = sectors of 1 * 512 = 512 bytes Sector size (logical/physical): 512 bytes / 512 bytes I/O size (minimum/optimal): 512 bytes / 512 bytes Disk label type: gpt Disk identifier: E53CF9CC-6556-41C1-B188-25735A0928F7 # Start End Size Type Name 1 34 9765625 4.7G Microsoft basic myFirstGPT
步驟6、格式化檔案系統
[[email protected] ~]# mkfs.ext4 /dev/sdb mke2fs 1.42.9 (28-Dec-2013) /dev/sdb is entire device, not just one partition! Proceed anyway? (y,n) y Filesystem label= OS type: Linux Block size=4096 (log=2) Fragment size=4096 (log=2) Stride=0 blocks, Stripe width=0 blocks 1310720 inodes, 5242880 blocks 262144 blocks (5.00%) reserved for the super user First data block=0 Maximum filesystem blocks=2153775104 160 block groups 32768 blocks per group, 32768 fragments per group 8192 inodes per group Superblock backups stored on blocks: 32768, 98304, 163840, 229376, 294912, 819200, 884736, 1605632, 2654208, 4096000 Allocating group tables: done Writing inode tables: done Creating journal (32768 blocks): done Writing superblocks and filesystem accounting information: done [root@localhost ~]#
步驟7、掛載
[[email protected] ~]# mkdir /mnt/myFirstGPT [root@localhost ~]# mount /dev/sdb /mnt/myFirstGPT/
2、 建立一個10G的分割槽,並格式化為etx4檔案系統。要求:
[[email protected] ~]# fdisk /dev/sdb Welcome to fdisk (util-linux 2.23.2). Changes will remain in memory only, until you decide to write them. Be careful before using the write command. Device does not contain a recognized partition table Building a new DOS disklabel with disk identifier 0x3a339f3a. Command (m for help): n Partition type: p primary (0 primary, 0 extended, 4 free) e extended Select (default p): p Partition number (1-4, default 1): 1 First sector (2048-41943039, default 2048): Using default value 2048 Last sector, +sectors or +size{K,M,G} (2048-41943039, default 41943039): +10G Partition 1 of type Linux and of size 10 GiB is set Command (m for help): w
(1) block大小為2048,預留空間20%,卷標為MYDATA
[[email protected] ~]# mkfs -t ext4 -b 2048 -m 20 -L MYDATA /dev/sdb1 mke2fs 1.42.9 (28-Dec-2013) Filesystem label=MYDATA OS type: Linux Block size=2048 (log=1) Fragment size=2048 (log=1) Stride=0 blocks, Stripe width=0 blocks 655360 inodes, 5242880 blocks 1048576 blocks (20.00%) reserved for the super user First data block=0 Maximum filesystem blocks=273678336 320 block groups 16384 blocks per group, 16384 fragments per group 2048 inodes per group Superblock backups stored on blocks: 16384, 49152, 81920, 114688, 147456, 409600, 442368, 802816, 1327104, 2048000, 3981312 Allocating group tables: done Writing inode tables: done Creating journal (32768 blocks): done Writing superblocks and filesystem accounting information: done [root@localhost ~]#
(2) 掛載/mydata目錄,要求掛載時禁止程式自動執行,且不更新檔案的訪問時間戳
[[email protected] ~]# mkdir /mydata [root@localhost ~]# mount -o noatime,noexec /dev/sdb1 /mydata
(3) 可開機自動掛載
[[email protected] ~]# blkid /dev/sdb1 /dev/sdb1: LABEL="MYDATA" UUID="af467f45-8b5c-426f-9aa6-6327e0a4e064" TYPE="ext4" [root@localhost ~]# vim /etc/fstab UUID=af467f45-8b5c-426f-9aa6-6327e0a4e064 /mydata ext4 defaults 0 0 [root@localhost ~]# mount –a
5、 建立一個大小為1G的swap分割槽,並啟用
[[email protected] ~]# fdisk /dev/sdb Welcome to fdisk (util-linux 2.23.2). Changes will remain in memory only, until you decide to write them. Be careful before using the write command. Command (m for help): n Partition type: p primary (1 primary, 0 extended, 3 free) e extended Select (default p): p Partition number (2-4, default 2): 2 First sector (20973568-41943039, default 20973568): Using default value 20973568 Last sector, +sectors or +size{K,M,G} (20973568-41943039, default 41943039): +1G Partition 2 of type Linux and of size 1 GiB is set Command (m for help): t Partition number (1,2, default 2): 2 Hex code (type L to list all codes): 82 Changed type of partition 'Linux' to 'Linux swap / Solaris' Command (m for help): w The partition table has been altered! Calling ioctl() to re-read partition table. WARNING: Re-reading the partition table failed with error 16: Device or resource busy. The kernel still uses the old table. The new table will be used at the next reboot or after you run partprobe(8) or kpartx(8) Syncing disks. [root@localhost ~]# fdisk -l /dev/sdb Disk /dev/sdb: 21.5 GB, 21474836480 bytes, 41943040 sectors Units = sectors of 1 * 512 = 512 bytes Sector size (logical/physical): 512 bytes / 512 bytes I/O size (minimum/optimal): 512 bytes / 512 bytes Disk label type: dos Disk identifier: 0x3a339f3a Device Boot Start End Blocks Id System /dev/sdb1 2048 20973567 10485760 83 Linux /dev/sdb2 20973568 23070719 1048576 82 Linux swap / Solaris [root@localhost ~]# mkswap /dev/sdb2 [root@localhost ~]# swapon /dev/sdb3
6、 編寫指令碼計算/etc/passwd檔案中第10個使用者和第20個使用者id之和
#!/bin/bash #fileName addId.sh #author gongxu #data 2019/12/9 id1=$(head -10 /etc/passwd | tail -1 | cut -d: -f3) id2=$(head -20 /etc/passwd | tail -1 | cut -d: -f3) id_sum=$[$id1+$id2] echo “id_sum=$id_sum” 執行指令碼: [root@localhost ~]# bash .addId.sh “id_sum=1008”
7、 將當前主機名儲存至hostName變數中,主機名如果為空,或者為localhost.localdomain則將設定為www.magedu.com
hostName=$(hostname) [ -z "$hostName" -o "$hostName" == "localhost.localdomain" -o "$hostName" == "localhost" ] && hostname www.magedu.com
8、 編寫指令碼,通過命令列引數傳入一個使用者名稱,判斷id的偶數還是奇數
#!/bin/bash # If ![ $# -eq 1 ] ;then echo “please input at lessest one userName” exit 2 fi $uid = grep “^$1\>” /etc/passwd | cut –d: -f3 $uid_yu = $uid % 2 If $uid_yu –eq 0 ; then echo “$1的ID號為偶數” else echo “$1的ID號為奇數” fi
Lvm基本應用以及擴充套件縮減實現(轉載自:http://blog.csdn.net/ikikik2002/article/details/5187276)
一、 前言
LVM是邏輯卷管理(Logical Volume Manager)的簡稱,他是建立在物理儲存裝置之上的一個抽象層,允許你生成邏輯儲存卷,和直接使用物理儲存在管理上相比,提供了更好靈活性。
LVM將儲存虛擬化,使用邏輯卷,你不會受限於物理磁碟的大小,另外,和硬體相關的儲存設定被其隱藏,你能不用停止應用或解除安裝檔案系統來調整卷大小或資料遷移.這樣能減少操作成本.
LVM和直接使用物理儲存相比,有以下好處:
1. 靈活的容量.
當使用邏輯卷時,檔案系統能擴充套件到多個磁碟上,你能聚合多個磁碟或磁碟分割槽成單一的邏輯卷.
2.可伸縮的儲存池.
你能使用簡單的命令來擴大或縮小邏輯卷大小,不用重新格式化或分割槽磁碟裝置.
3.線上的資料再分配.
你能線上移動資料,資料能在磁碟線上的情況下重新分配.比如,你能線上更換可熱插拔的磁碟.
4. 方便的裝置命名
邏輯卷能按你覺得方便的方式來起所有名稱.
5.磁碟條塊化.
你能生成一個邏輯盤,他的資料能被條塊化儲存在2個或更多的磁碟上.這樣能明顯提升資料吞吐量.
6.映像卷
邏輯卷提供方便的方法來映像你的資料.
7.卷快照
使用邏輯卷,你能獲得裝置快照用來一致性備份或測試資料更新效果而不影響真實資料.
二、 LVM基本術語
前面談到,LVM是在物理儲存上新增的一個邏輯層,來為檔案系統遮蔽下面的硬體儲存裝置,提供了一個抽象的盤卷,在盤捲上建立檔案系統。首先我們討論以下幾個LVM術語:
* 物理儲存介質(The Physical Media)
這裡指系統的儲存裝置,如:/dev/hda1、/dev/sda等等,是儲存系統最低層的儲存單元。
* 物理卷(PV, Physical Volume)
物理卷就是指磁碟,磁碟分割槽或從邏輯上和磁碟分割槽具有同樣功能的裝置(如RAID),是LVM的基本儲存邏輯塊,但和基本的物理儲存介質(如分割槽、磁碟等)比較,卻包含有和LVM相關的管理引數。當前LVM允許你在每個物理捲上儲存這個物理卷的0至2份元資料拷貝.預設為1,儲存在裝置的開始處.為2時,在裝置結束處儲存第二份備份.
* 卷組(VG, Volume Group)
LVM卷組類似於非LVM系統中的物理硬碟,其由物理卷組成。能在卷組上建立一個或多個“LVM分割槽”(邏輯卷),LVM卷組由一個或多個物理卷組成。
* 邏輯卷(LV, Logical Volume)
LVM的邏輯卷類似於非LVM系統中的硬碟分割槽,在邏輯卷之上能建立檔案系統(比如/home或/usr等)。
*線性邏輯卷 (Linear Volumes)
一個線性邏輯卷聚合多個物理捲成為一個邏輯卷.比如,如果你有兩個60GB硬碟,你能生成120GB的邏輯卷.
*條塊化的邏輯卷(Striped Logical Volumes)
當你寫資料到此邏輯卷中時,檔案系統能將資料放置到多個物理卷中.對於大量連線讀寫操作,他能改善資料I/O效率.
*映像的邏輯卷(Mirrored Logical Volumes)
映像在不同的裝置上儲存一致的資料.資料同時被寫入原裝置及映像裝置.他提供裝置之間的容錯。
*快照卷(Snapshot Volumes)
快照卷提供在特定瞬間的一個裝置虛擬映像,當快照開始時,他複製一份對當前資料區域的改動,由於他優先執行這些改動,所以他能重構當前裝置的狀態。
* PE(physical extent)
每一個物理卷被劃分為稱為PE(Physical Extents)的基本單元,具有唯一編號的PE是能被LVM定址的最小單元。PE的大小是可設定的,預設為4MB。
* LE(logical extent)
邏輯卷也被劃分為被稱為LE(Logical Extents) 的可被定址的基本單位。在同一個卷組中,LE的大小和PE是相同的,並且一一對應。
和非LVM系統將包含分割槽資訊的元資料儲存在位於分割槽的起始位置的分割槽表中相同,邏輯卷及卷組相關的元資料也是儲存在位於物理捲起始處的VGDA(卷組描述符區域)中。VGDA包括以下內容: PV描述符、VG描述符、LV描述符、和一些PE描述符 。系統啟動LVM時啟用VG,並將VGDA載入至記憶體,來識別LV的實際物理儲存位置。當系統進行I/O操作時,就會根據VGDA建立的對映機制來訪問實際的物理位置。
三、 安裝LVM
首先確定系統中是否安裝了lvm工具:
[[email protected] root]# rpm ?qa|grep lvm
lvm-x-x-x
如果命令結果輸入類似於上例,那麼說明系統已安裝了LVM管理工具;如果命令沒有輸出則說明沒有安裝LVM管理工具,則需要從網路下載或從光碟裝LVM rpm工具包。
安裝了LVM的RPM軟體包以後,要使用LVM還需要設定核心支援LVM。RedHat預設核心是支援LVM的,如果需要重新編譯核心,則需要在設定核心時,進入Multi-device Support (RAID and LVM)子選單,選中以選項:
- Multiple devices driver support (RAID and LVM)
Device mapper support
Snapshot target (EXPERIMENTAL)
Mirror target (EXPERIMENTAL)
然後重新編譯核心,即可將LVM的支援新增到新核心中。
為了使用LVM,要確保在系統啟動時啟用LVM,在RedHa的版本中,系統啟動指令碼已具有對啟用LVM的支援,在/etc/rc.d/rc.sysinit中有以下內容:
if [ -x /sbin/lvm.static ]; then
action $"Setting up Logical Volume Management:" /sbin/lvm.static vgchange -a y --ignorelockingfailure
fi
vgchange -a y命令啟用系統所有卷組。
四、 建立和管理LVM
要建立一個LVM系統,一般需要經過以下步驟:
1、 建立分割槽
使用分割槽工具(如:fdisk等)建立LVM分割槽,方法和建立其他一般分割槽的方式是相同的,差別僅僅是LVM的分割槽型別為8e。
# fdisk -l /dev/sdb /dev/sdc
Disk /dev/sdb: 18.2 GB, 18200739840 bytes
255 heads, 63 sectors/track, 2212 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Disk /dev/sdb doesn’t contain a valid partition table
Disk /dev/sdc: 18.2 GB, 18200739840 bytes
255 heads, 63 sectors/track, 2212 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Device Boot Start End Blocks Id System
/dev/sdc1 1 200 1606468+ 8e Linux LVM
如果要將使用整塊盤,能通過下面的命令來覆蓋磁碟上的原有分割槽資訊:
#dd if=/dev/zero of=/dev/sdc bs=512 count=1
2、 建立物理卷
建立物理卷的命令為pvcreate,利用該命令將希望新增到卷組的所有分割槽或磁碟建立為物理卷。將整個磁碟建立為物理卷的命令為:
# pvcreate /dev/sdb
Physical volume "/dev/sdb" successfully created
將單個分割槽建立為物理卷的命令為:
# pvcreate /dev/sdc1
Physical volume "/dev/sdc1" successfully created
也能同時生成多個卷:
#pvcreate /dev/sdb /dev/sdc1
3、掃描塊裝置
通過lvmdiskscan能看到那些裝置成為了物理卷.
#lvmdiskscan
/dev/ramdisk [ 16.00 MB]
/dev/sda [ 4.00 GB]
/dev/root [ 2.88 GB]
/dev/ram [ 16.00 MB]
/dev/sda1 [ 101.94 MB]
/dev/VolGroup00/LogVol01 [ 1.00 GB]
/dev/ram2 [ 16.00 MB]
/dev/sda2 [ 3.90 GB] LVM physical volume
/dev/lvm_test/test [ 508.00 MB]
/dev/ram3 [ 16.00 MB]
/dev/ram4 [ 16.00 MB]
/dev/ram5 [ 16.00 MB]
/dev/ram6 [ 16.00 MB]
/dev/ram7 [ 16.00 MB]
/dev/ram8 [ 16.00 MB]
/dev/ram9 [ 16.00 MB]
/dev/ram10 [ 16.00 MB]
/dev/ram11 [ 16.00 MB]
/dev/ram12 [ 16.00 MB]
/dev/ram13 [ 16.00 MB]
/dev/ram14 [ 16.00 MB]
/dev/ram15 [ 16.00 MB]
/dev/sdb [ 512.00 MB] LVM physical volume
/dev/sdc [ 512.00 MB] LVM physical volume
5 disks
16 partitions
2 LVM physical volume whole disks
1 LVM physical volume
4、顯示物理卷
能使用pvs,pvscan,pvdisplay來顯示當前系統中的物理卷.
#pvs
PV VG Fmt Attr PSize PFree
/dev/sda2 VolGroup00 lvm2 a- 3.88G 0
/dev/sdb lvm_test lvm2 a- 508.00M 0
/dev/sdc lvm2 -- 512.00M 512.00M
#pvscan
PV /dev/sdb VG lvm_test lvm2 [508.00 MB / 0 free]
PV /dev/sda2 VG VolGroup00 lvm2 [3.88 GB / 0 free]
PV /dev/sdc lvm2 [512.00 MB]
Total: 3 [4.87 GB] / in use: 2 [4.37 GB] / in no VG: 1 [512.00 MB]
#pvdisplay
--- Physical volume ---
PV Name /dev/sdb
VG Name lvm_test
PV Size 512.00 MB / not usable 4.00 MB
Allocatable yes (but full)
PE Size (KByte) 4096
Total PE 127
Free PE 0
Allocated PE 127
PV UUID Pkp5Cq-SD1w-ANw2-cDDe-BGtw-nmFS-jTxXFD
--- NEW Physical volume ---
PV Name /dev/sdc
VG Name
PV Size 512.00 MB
Allocatable NO
PE Size (KByte) 0
Total PE 0
Free PE 0
Allocated PE 0
PV UUID BNCVEE-YWlK-0mrV-LOcf-0tCY-WWNw-DeySk0
5、移除物理卷
#pvremove /dev/sdc
Labels on physical volume "/dev/sdc" successfully wiped
6、 建立卷組
建立卷組的命令為vgcreate,將使用pvcreate建立的物理卷建立為一個完整的卷組:
# vgcreate lvm_test /dev/sdc1 /dev/sdb
Volume group "lvm_test" successfully created
vgcreate命令第一個引數是指定該卷組的邏輯名:lvm_test。後面引數是指定希望新增到該卷組的所有分割槽和磁碟。vgcreate在建立卷組 lvm_test 以外,還設定使用大小為4 MB的PE(預設為4MB),這表示卷組上建立的所有邏輯卷都以 4 MB 為增量單位來進行擴充或縮減。PE最小為1KB ,並且必須總是1KB的 2^n 的倍數(使用-s指定,具體請參考man vgcreate)。
7、 啟用卷組
卷組在建立時預設啟用,也能使用vgchange來啟用卷組:
# vgchange -a y lvm_test
8、 新增新的物理捲到卷組中
當系統安裝了新的磁碟或新建分割槽並建立了新的物理卷,而要將其新增到已有卷組時,就需要使用vgextend命令:
#fdisk -l /dev/sdc
Disk /dev/sdc: 18.2 GB, 18200739840 bytes
255 heads, 63 sectors/track, 2212 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Device Boot Start End Blocks Id System
/dev/sdc1 1 200 1606468+ 8e Linux LVM
/dev/sdc2 201 400 1606500 8e Linux LVM
#pvcreate /dev/sdc2
Physical volume "/dev/sdc2" successfully created
# vgextend lvm_test /dev/sdc2
Volume group "lvm_test" successfully extended
這裡/dev/sdc2是新的物理卷。
9、顯示卷組
顯示卷組能使用vgs和vgdisplay.
# vgs
VG #PV #LV #SN Attr VSize VFree
VolGroup00 1 2 0 wz--n- 3.88G 0
lvm_test 1 1 0 wz--n- 508.00M 0
# vgdisplay
--- Volume group ---
VG Name lvm_test
System ID
Format lvm2
Metadata Areas 1
Metadata Sequence No 10
VG Access read/write
VG Status resizable
MAX LV 0
Cur LV 1
Open LV 1
Max PV 0
Cur PV 1
Act PV 1
VG Size 508.00 MB
PE Size 4.00 MB
Total PE 127
Alloc PE / Size 127 / 508.00 MB
Free PE / Size 0 / 0
VG UUID uJx24t-WWdY-vffu-97Of-mgFB-FEov-eRwzAf
10、掃描磁碟生成快取檔案
#vgscan
Reading all physical volumes. This may take a while...
Found volume group "lvm_test" using metadata type lvm2
Found volume group "VolGroup00" using metadata type lvm2
11、 從卷組中刪除一個物理卷
要從一個卷組中刪除一個物理卷,首先要確認要刪除的物理卷沒有被所有邏輯卷正在使用,就要使用pvdisplay命令察看一個該物理卷資訊:
#pvdisplay /dev/sdc2
--- Physical volume ---
PV Name /dev/sdc2
VG Name lvm_test
PV Size 1.53 GB / not usable 868.00 KB
Allocatable yes
PE Size (KByte) 4096
Total PE 392
Free PE 392
Allocated PE 0 (表示未被使用)
PV UUID jAiils-1vRz-Td9k-1AiD-kIJs-191z-YMz09H
如果某個物理卷正在被邏輯卷所使用,就需要將該物理卷的資料備份到其他地方,然後再刪除。刪除物理卷的命令為vgreduce:
# vgreduce lvm_test /dev/sdc2
Removed "/dev/sdc2" from volume group "lvm_test"
12、 建立邏輯卷
建立邏輯卷的命令為lvcreate:
# lvcreate -L 1500 ?n test lvm_test
Logical volume "test" created
該命令就在卷組lvm_test上建立名字為test,大小為1500M的邏輯卷,並且裝置入口為/dev/lvm_test/test (lvm_test為卷組名,test為邏輯卷名)。如果希望建立一個使用全部卷組的邏輯卷,則需要首先察看該卷組的PE數,然後在建立邏輯卷時指定:
# vgdisplay lvm_test| grep "Total PE"
Total PE 4731
# lvcreate -l 4731 lvm_test -n test
Logical volume "test" created
13、建立條塊化的邏輯卷
# lvcreate -L 500M -i2 -n test lvm_test
Using default stripesize 64.00 KB
Rounding size (125 extents) up to stripe boundary size (126 extents)
Logical volume "test" created
-i2指此邏輯卷在兩個物理卷中條塊化存放資料,預設一塊大小為64KB.
14、建立映像的邏輯卷。
#lvcreate -L 52M -m1 -n test lvm_test /dev/sdb1 /dev/sdc1 /dev/sdb2
Logical volume "test" created
-m1表示只生成一個單一映像,映像分別放在/dev/sdb1和/dev/sdc1上,映像日誌放在/dev/sdb2上.
15、建立快照卷。
#lvcreate --size 10 --snapshot --name snaptest /dev/lvm_test/test
16、 建立檔案系統
如使用ext3檔案系統:
#mkfs.ext3 /dev/lvm_test/test
mke2fs 1.35 (28-Feb-2004)
max_blocks 4294967295, rsv_groups = 0, rsv_gdb = 1024
Filesystem label=
OS type: Linux
Block size=4096 (log=2)
Fragment size=4096 (log=2)
2424832 inodes, 4844544 blocks
242227 blocks (5.00%) reserved for the super user
First data block=0
Maximum filesystem blocks=8388608
148 block groups
32768 blocks per group, 32768 fragments per group
16384 inodes per group
Superblock backups stored on blocks:
32768, 98304, 163840, 229376, 294912, 819200, 884736, 1605632, 2654208,
4096000
Writing inode tables: done
inode.i_blocks = 90120, i_size = 4243456
Creating journal (8192 blocks): done
Writing superblocks and filesystem accounting information: done
This filesystem will be automatically checked every 25 mounts or
180 days, whichever comes first. Use tune2fs -c or -i to override.
建立了檔案系統以後,就能載入並使用他:
# mkdir /mnt/test
# mount /dev/lvm_test/test /mnt/test
如果希望系統啟動時自動載入檔案系統,則還需要在/etc/fstab中新增內容:
/dev/lvm_test/test /mnt/test ext3 defaults 1 2
17、 刪除一個邏輯卷
刪除邏輯卷以前首先需要將其解除安裝,然後刪除:
# umount /dev/lvm_test/test
# lvremove /dev/lvm_test/test
Do you really want to remove active logical volume "test"? [y/n]: y
Logical volume "test" successfully removed
18、 擴充套件邏輯卷大小
LVM提供了方便調整邏輯卷大小的能力,擴充套件邏輯卷大小的命令是lvextend:
# lvextend -L12G /dev/lvm_test/test
Extending logical volume test to 12.00 GB
Logical volume test successfully resized
上面的命令就實現將邏輯卷test的大小擴大為12G。
# lvextend -L+1G /dev/lvm_test/test
Extending logical volume test to 13.00 GB
Logical volume test successfully resized
上面的命令就實現將邏輯卷test的大小增加1G。
增加了邏輯卷的容量以後,就需要修改檔案系統大小以實現利用擴充的空間。
對於希望調整被載入的檔案系統大小,使用ext2online(ext2resize) 或 resize2fs.
#df -h
# ext2online /dev/lvm_test/test
ext2online /dev/lvm_test/test
ext2online v1.1.18 - 2001/03/18 for EXT2FS 0.5b
#df -h
Filesystem 容量 已用 可用 已用% 掛載點
/dev/mapper/VolGroup00-LogVol01
16G 11G 3.6G 76% /
/dev/sda1 494M 18M 451M 4% /boot
none 506M 0 506M 0% /dev/shm
/dev/mapper/lvm_test-test
13G 63M 13G 1% /mnt/test
一般建議最佳將檔案系統解除安裝,調整大小,然後再載入:
# umount /dev/lvm_test/test
#resize2fs /dev/lvm_test/test
# mount /dev/lvm_test/test /mnt/test
19、 減少邏輯卷大小
使用lvreduce即可實現對邏輯卷的容量,同樣需要首先將檔案系統解除安裝:
# umount /mnt/test
#e2fsck -f /dev/lvm_test/test
# resize2fs /dev/lvm_test/test 11G
# lvreduce -L -1.992G /dev/lvm_test/test (少2個PE的大小)
# resize2fs /dev/lvm_test/test (通過此命令確認是否檔案系統大小和收縮後的邏輯卷大小匹配)
# mount /dev/lvm_test/test /mnt/test
20、顯示邏輯卷
通過lvscan,lvs及lvdisplay能察看當前系統中存在的邏輯卷。
# lvdisplay
--- Logical volume ---
LV Name /dev/VolGroup00/LogVol00
VG Name VolGroup00
LV UUID sPmLMD-6xq4-wStB-uSAP-jlQc-YKTm-3bt8Pc
LV Write Access read/write
LV Status available
# open 1
LV Size 2.88 GB
Current LE 92
Segments 1
Allocation inherit
Read ahead sectors 0
Block device 253:0
#lvscan
lvscan
ACTIVE ’/dev/VolGroup00/LogVol00’ [2.88 GB] inherit
ACTIVE ’/dev/VolGroup00/LogVol01’ [1.00 GB] inherit
#lvs -o +devices
LV VG Attr LSize Origin Snap% Move Log Copy% Devices
LogVol00 VolGroup00 -wi-ao 2.88G /dev/sda2(0)
LogVol01 VolGroup00 -wi-ao 1.00G /dev/sda2(92)
21、使用過濾控制LVM的裝置掃描
通過編輯/etc/lvm/lvm.conf 中的filter段,來定義過濾那些裝置要掃描。
filter =[ "a|/dev/sd.*|", "a|/dev/hd.*|", "r|.*|" ]
上面對scsi及ide裝置掃描,對其他裝置均不掃描。
22、線上資料遷移
通過pvmove能將一個PV上的資料遷移到新的PV上,也能將PV上的某個LV遷移到另一個PV上。
#lvs -o +devices
LV VG Attr LSize Origin Snap% Move Log Copy% Devices
LogVol00 VolGroup00 -wi-ao 2.88G /dev/sda2(0)
LogVol01 VolGroup00 -wi-ao 1.00G /dev/sda2(92)
test lvm_test -wi-ao 52.00M /dev/sdb1(0)
#pvmove -n test /dev/sdb1 /dev/sdc1
#lvs -o +devices
LV VG Attr LSize Origin Snap% Move Log Copy% Devices
LogVol00 VolGroup00 -wi-ao 2.88G /dev/sda2(0)
LogVol01 VolGroup00 -wi-ao 1.00G /dev/sda2(92)
test lvm_test -wi-ao 52.00M /dev/sdc1(0)
23、刪除卷組
按照順序解除安裝檔案系統,刪除邏輯卷,然後刪除卷組。
#umount /mnt/test
# lvremove /dev/lvm_test/test
Do you really want to remove active logical volume "test"? [y/n]: y
Logical volume "test" successfully removed
#vgremove lvm_test
Volume group "lvm_test" successfully removed
24、故障排查
通過在命令後加 -v,-vv,-vvv或-vvvv來獲得更周詳的命令輸出。
通過在lvs,vgs後加-P能更好的檢視失敗裝置.
#vgs -a -o +devices -P
Partial mode. Incomplete volume groups will be activated read-only.
VG #PV #LV #SN Attr VSize VFree Devices
VolGroup00 1 2 0 wz--n- 3.88G 0 /dev/sda2(0)
VolGroup00 1 2 0 wz--n- 3.88G 0 /dev/sda2(92)
lvm_test 2 2 0 wz--n- 1016.00M 896.00M pvmove0(0)
lvm_test 2 2 0 wz--n- 1016.00M 896.00M /dev/sdb(0),/dev/sdc(0)
#lvs -a -o +devices -P
Partial mode. Incomplete volume groups will be activated read-only.
Failure parsing mirror status fraction: 1 core
Failure parsing mirror status fraction: 1 core
LV VG Attr LSize Origin Snap% Move Log Copy% Devices
LogVol00 VolGroup00 -wi-ao 2.88G /dev/sda2(0)
LogVol01 VolGroup00 -wi-ao 1.00G /dev/sda2(92)
[pvmove0] lvm_test p-C-ao 60.00M /dev/sdb /dev/sdb(0),/dev/sdc(0)
test lvm_test -wI-a- 60.00M pvmove0(0)
五、 總結
根據上面的討論能看到,LVM具有非常好的可伸縮性,使用起來非常方便。能方便地對卷組、邏輯卷的大小進行調整,更進一步調整檔案系統的大小,還能方便的進行資料遷移,資料完整性保護。如果希望瞭解更多資訊,請參考LVM-HOWTO。
此檔案使用核心為2.6.22.1,在做pvmove時出現錯誤,如上.補丁如下:
Index: linux-2.6.21/drivers/md/dm-raid1.c
===================================================================
--- linux-2.6.21.orig/drivers/md/dm-raid1.c 2007-05-13 18:56:09.000000000 +0100
+++ linux-2.6.21/drivers/md/dm-raid1.c 2007-05-13 19:09:54.000000000 +0100
@@ -1288,12 +1288,12 @@ static int mirror_status(struct dm_targe
for (m = 0; m nr_mirrors; m++)
DMEMIT("%s ", ms->mirror[m].dev->name);
- DMEMIT("%llu/%llu",
+ DMEMIT("%llu/%llu ",
(unsigned long long)ms->rh.log->type->
get_sync_count(ms->rh.log),
(unsigned long long)ms->nr_regions);
- sz = ms->rh.log->type->status(ms->rh.log, type, result, maxlen);
+ sz += ms->rh.log->type->status(ms->rh.log, type, result+sz, maxlen-sz);
break;