LVM: LVM: Logical Volume Manager,可以實現動態的擴容和縮容。邏輯捲是一種邏輯上的管理方式,把一塊或多塊硬碟或分區邏輯的組合在一起,命令成一個捲組(VG),捲組的空間來自所有硬碟空間的總和。(組成邏輯捲的硬碟或分區大小可以不一樣) VG: 多個磁碟或者分區組合在一起的( ...
LVM:
LVM: Logical Volume Manager,可以實現動態的擴容和縮容。邏輯捲是一種邏輯上的管理方式,把一塊或多塊硬碟或分區邏輯的組合在一起,命令成一個捲組(VG),捲組的空間來自所有硬碟空間的總和。(組成邏輯捲的硬碟或分區大小可以不一樣)
VG:
多個磁碟或者分區組合在一起的(邏輯上的大硬碟)
LV:
是從VG中取出一塊空間而來的(相當於VG這個邏輯上大硬碟的一個分區)
PE:
PE:物理盤區,作用是負責分配空間的最小單位(邏輯捲中),擴容和縮容都是以PE為單位來操作的。PE大小預設為4M
LVM的實現過程:
-
1.將設備設為物理捲 -- 貼個標簽,表示這個硬碟要作為物理捲使用了
-
2.指定捲組(一個或多個物理捲加入捲組形成一個大硬碟)
-
3.創建邏輯捲(相當於分區)
-
4.創建文件系統並掛載
邏輯捲的名字:
邏輯捲有三個名稱你可以用,一個真名,兩個軟連接。
第一個邏輯捲對應設備名:/dev/dm-# (邏輯捲的真名)
dm: device mapper,將一個或多個底層塊設備組織成一個邏輯設備的模塊
邏輯捲的軟鏈接:
-
/dev/mapper/VG_NAME-LV_NAME
-
/dev/VG_NAME/LV_NAME
邏輯捲的實現範例:
#創建swap空間,分區的id要改為82,創建邏輯捲,物理設備分區的id要改成8e fdisk的t選項。
#如果是使用硬碟的話,就不存在改ID的問題了。
#這些命令依賴lvm2這個工具包
#創建物理捲
pvcreate /dev/sda3
#為捲組分配物理捲
vgcreate vg0(捲組名) /dev/sda3(把創建的pv加進來) #-s可以指定PE的大小
#從捲組創建邏輯捲
lvcreate -L 256M -n data vg0 # -n:指定設備名稱 -l:PE的個數 -L:指定LV的大小
mkfs.xfs /dev/vg0/data #創建文件系統
#掛載
mount /dev/vg0/data /mnt/data
邏輯捲的擴展和縮減
擴展邏輯捲:
#兩步實現 -- 空間擴展和文件系統擴展 (缺點在於文件系統擴容的時候不同系列的文件系統命令不一樣)
#第一步實現邏輯捲的空間擴展
lvextend -L [+]#[mMgGtT](大小) /dev/VG_NAME/LV_NAME #-l:擴容多少個pe -L:擴容的大小 不寫+號表示擴容到xx,寫了+號表示增加xxx
#第二步實現文件系統的擴展
#使用df命令看到的是文件系統的情況,擴容了的部分但是上面沒有文件系統,所以就看不見
#針對ext
resize2fs /dev/VG_NAME/LV_NAME #resize2fs:對ext系列的文件系統進行擴容,把文件系統同步到空間裡面去
#針對xfs
xfs_growfs MOUNTPOINT
#一步實現容間和文件系統的擴展(不用關註文件系統的類型,直接擴容)
lvextend -r -l +100%FREE /dev/VG_NAME/LV_NAME #-l:pe的個數 -r:表示不管是什麼文件系統都立即同步文件系統 +100%FREE:表示剩下的所有剩餘空間
擴展卷組的空間:
##添加物理捲到捲組中(分區需要改id號)
pvcreate 物理捲
##將添加的設備添加到捲組中
vgextend 捲組名 物理捲
縮減邏輯捲(有丟失數據的風險)
#建議先備份再縮減,xfs文件系統不支持縮減
#五個步驟:1.卸載 -- 2.檢查文件系統完整性(不管是否完整必須) -- 3.縮減文件系統 -- 4.縮減邏輯捲大小 -- 5.重新掛載
#1.卸載:
umount /dev/VG_NAME/LV_NAME #首先卸載
#2.檢查文件系統完整性
e2fsck -f /dev/VG_NAME/LV_NAME
#3.縮減文件系統
resize2fs /dev/VG_NAME/LV_NAME #[mMgGtT](縮減後的大小,例如2G表示縮減到2G)
#4.縮減邏輯捲大小
lvreduce -L [-]#[mMgGtT](這個大小要和上面的大小相匹配) /dev/VG_NAME/LV_NAME(對誰進行縮減)
#5.重新掛載
mount /dev/VG_NAME/LV_NAME mountpoint
清除緩存的方法:
使用 free -h 可以看到緩存
查看緩存對應的目錄: find /proc -name 'drop*' --- /proc/sys/vm/drop_caches
清理緩存:echo 3 > /proc/sys/vm/drop_caches --- 3就是清理緩存
#緩存的目的就是為了提高性能(一般做測試的時候才清理緩存)
拆除指定的PV存儲設備
要想移除指定的pv存儲設備,首先要將它上面的數據移到別的pv上面去。(要確保上面的數據在別的pv上面能存得下)
#實現方法:
#移動指定pv設備上的所有被占用的pe移動到同一捲組的其他成員上面
pvmove 指定的pv設備
#把pv設備從vg裡面移走
vgreduce 指定的設備
#不讓這個設備作為pv了
pvremove 指定的設備
刪除邏輯捲
應該倒過來刪除,從邏輯捲、捲組再到物理捲
-
1.取消掛載
-
2.刪除邏輯捲: lvremove 邏輯捲
-
3.刪除捲組: vgremove 捲組
-
4.刪除物理捲:pbremove 物理捲
邏輯捲快照
快照:把當前的狀態快速做一個備份,快照類似備份的效果,但是特別快
邏輯捲快照:瞬間把邏輯捲做個備份
工作邏輯:
- 首先有一個捲組,捲組裡面存在一個邏輯捲,假設邏輯捲裡面有一些文件。
- 做快照就是在同屬於同一捲組的空間中創建一個邏輯捲(快照邏輯捲--snapshot,具有特殊屬性)。
- 創建快照的時候並沒有把原邏輯捲中的數據備份到快照中,只是在硬碟上分配了一個空間。
- 起到備份效果是因為在更改原文件的時候,會自動把被修改文件的舊版本推送到快照裡面去了(只存放最初的原始版本)沒有修改的文件就不會被放到做快照的這個空間裡面去。
總結:
快照備份邏輯:創建快照的時候會分配一塊空間,只有原文件發生了修改,才會把這個原文件的最初版本放到快照裡面去(快照裡面只放發生了改變的數據)。
快照的實現:(快照也是一種邏輯捲,所以使用的命令和創建邏輯捲的命令一樣)
#為現有邏輯捲創建快照,註意ext4必須使用-p r 實現只讀
#創建快照:
lvcreate -l 64 -s -n data-snapshot /dev/vg0/data
#-l: 指定這個快照的大小(多少個pe)
# -s:表示創建的是快照,不加s表示創建的是普通邏輯捲
# -n: 快照的名字
# /dev/vg0/data -- 表示指定的是誰的快照(原始邏輯捲的名稱)
創建完成後可以使用 lvs或lvdisplay來進行查看(因為快照也是一個邏輯捲)
#創建快照以後進行掛載
#掛載快照,xfs註意要使用-o ro實現只讀,訪止快照被修改
mkdir -p /mnt/snap
mount -o ro,nouuid /dev/vg0/data-snapshot /mnt/snap #nouuid--不檢查uuid xfs這類文件系統不允許相同的uuid設備掛載, ext系列文件系統不用加nouuid都行的
#掛載以後,進入這個目錄進行查看能看的數據的原因是(這裡面的數據是來源於原邏輯捲的,並非已經將這些數據備份了,因為之後原邏輯捲的數據修改以後,才會備份被修改數據的初始數據)
#恢復快照(使用快照數據還原修改過的數據)
umount /dev/vg0/data-snapshot #先取消掛載
umount /dev/vg0/data #先取消掛載
lvconvert --merge /dev/vg0/data-snapshot #利用快照還原原來的邏輯捲數據
#merge -- 合併,融入
#還原以後,快照會自動刪除