スペースが不足しているサーバーを継承し、アクションを実行する前に構成を理解するのに役立ちます。
サーバーを再起動せずに論理ボリュームを拡張する必要があります。
LVSは、295.62gのサイズのRHELと呼ばれるボリュームを示しています。 LSBLKは、実際には295.6のサイズの2つのパーティションがあることを示しているため、ミラーモードにあると仮定しますが、LVSはこれを反映しません。では、この設定はどうですか? rhelは2つのパーティションを効率的に使用しますか?これをどのように確認しますか?
また、パーティションなしのsdbディスクがあるので、パーティションを作成してLVMに追加する予定ですが、まず/sda2/rhel-rootとsda3/rhel-rootがどのように機能するかを理解したいと思います。 ..同じディスクからミラーリングすることはまったく意味がありません!確かにそうではありません。
# lvs
LV VG Attr LSize Pool Origin Data% Meta% Move Log Cpy%Sync Convert
root rhel -wi-ao---- <295,62g
swap rhel -wi-ao---- <3,38g
# lsblk
NAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINT
sda 8:0 0 400G 0 disk
├─sda1 8:1 0 1G 0 part /boot
├─sda2 8:2 0 39G 0 part
│ ├─rhel-root 253:0 0 295,6G 0 lvm /
│ └─rhel-swap 253:1 0 3,4G 0 lvm [SWAP]
└─sda3 8:3 0 360G 0 part
└─rhel-root 253:0 0 295,6G 0 lvm /
sdb 8:16 0 200G 0 disk
# vgdisplay -v rhel
--- Volume group ---
VG Name rhel
System ID
Format lvm2
Metadata Areas 2
Metadata Sequence No 10
VG Access read/write
VG Status resizable
MAX LV 0
Cur LV 2
Open LV 2
Max PV 0
Cur PV 2
Act PV 2
VG Size 298,99 GiB
PE Size 4,00 MiB
Total PE 76542
Alloc PE / Size 76542 / 298,99 GiB
Free PE / Size 0 / 0
VG UUID mDkink-qzyl-2KyS-DG5T-tf55-4it5-eGNqx3
--- Logical volume ---
LV Path /dev/rhel/root
LV Name root
VG Name rhel
LV UUID U4AI2b-eadM-TczV-g4ff-gudE-JWiU-dbz5sT
LV Write Access read/write
LV Creation host, time sms-linux-image.novalocal, 2021-07-01 17:16:09 -0400
LV Status available
# open 1
LV Size <295,62 GiB
Current LE 75678
Segments 3
Allocation inherit
Read ahead sectors auto
- currently set to 8192
Block device 253:0
--- Logical volume ---
LV Path /dev/rhel/swap
LV Name swap
VG Name rhel
LV UUID jSxEFM-frWb-MtJw-ae1g-Omfv-VNHD-SzbGt5
LV Write Access read/write
LV Creation host, time sms-linux-image.novalocal, 2021-07-01 17:16:09 -0400
LV Status available
# open 2
LV Size <3,38 GiB
Current LE 864
Segments 1
Allocation inherit
Read ahead sectors auto
- currently set to 8192
Block device 253:1
--- Physical volumes ---
PV Name /dev/sda2
PV UUID vscfjc-VcNp-Kwdv-JjuB-gtbP-2SsB-6iq6td
PV Status allocatable
Total PE / Free PE 9983 / 0
PV Name /dev/sda3
PV UUID yLqH6J-EQc9-FZBS-2MTr-Tams-7Mhn-hSSXAM
PV Status allocatable
Total PE / Free PE 66559 / 0
答え1
これはlsblk
、部分的にあるデバイスにあり、部分的に別のデバイスにあるファイルシステムを表示する珍しい現象です。
ルートファイルシステムの合計サイズ295,6G
は、表示されているのとまったく同じです。これでLVMにあるので、ファイルシステムの一部はLVM PV内にあり、sda2
他の部分はsda3
...しかし、lsblk
まだLVMの詳細な分析がないため、各部分がどれほど大きいかはわかりません。SIZE
列は以下を表すと理解されるので装備/dev/mapper/rhel-root
、デバイスが1つの物理パーティションに完全に含まれていない場合でも、デバイスのサイズを表示するため、デバイスをlsblk
2回一覧表示する必要があります。
デフォルトのデバイス中心モードではなく、ファイルシステム中心モードでリスト表示を実行し、lsblk -s
進行状況を視覚化するのに役立つことを確認できます。
しかし、sda3
パーティションのサイズは360Gのように見えますが、rhel
VG全体は360Gにすぎません298,99G
。これは、古いパーティションのサイズ変更操作が不完全であるためですsda
。
この試み:
partprobe /dev/sda # to ensure the kernel has up-to-date view of the partition table
pvresize /dev/sda3 # to extend the LVM PV at sda3 to fill the entire partition if it's currently smaller
vgs # to see if the rhel VG now has free space available
これにより、一部のスペースが利用可能になると(=出力ではVFree
0vgs
ではない)、必要に応じてLVを拡張してその容量を使用できます。たとえば、rhel
VGの利用可能なすべての容量をルートファイルシステムに配置するには、次の手順を実行します。
lvextend --resizefs -l +100%FREE /dev/mapper/rhel-root
答え2
LSBLKは、実際には295.6のサイズの2つのパーティションがあることを示しています。
実際にはそうではありません。
├─sda2 8:2 0 39G 0 part
...
└─sda3 8:3 0 360G 0 part
表示sda2
は39G、sda3
表示は360Gです。これは次の情報に反映されますvgdisplay
。
--- Physical volumes ---
PV Name /dev/sda2
PV UUID vscfjc-VcNp-Kwdv-JjuB-gtbP-2SsB-6iq6td
PV Status allocatable
Total PE / Free PE 9983 / 0
PV Name /dev/sda3
PV UUID yLqH6J-EQc9-FZBS-2MTr-Tams-7Mhn-hSSXAM
PV Status allocatable
Total PE / Free PE 66559 / 0
これを見ると(Total PE / Free PE
. はPE
「物理的範囲」を表す)、範囲は通常4MBなので、Total PE
おおよそlsblk
。
では、この設定はどうですか? rhelは2つのパーティションを効率的に使用しますか?これをどのように確認しますか?
両方のパーティションがボリュームグループのメンバーであり、両方のパーティションが完全に割り当てられていることを示すrhel
出力で、両方のパーティションが使用されていることを確認できます。vgdisplay
rhel
また、パーティションなしのsdbディスクがあるので、パーティションを作成してLVMに追加する予定ですが、まず/sda2/rhel-rootとsda3/rhel-rootがどのように機能するかを理解したいと思います。 ..同じディスクからミラーリングすることはまったく意味がありません!確かにそうではありません。
ミラーリングされません(サイズの違いにより不可能です)。これはVGが消費する2つのスペースにすぎません。
にパーティションを作成する必要はありませんsdb
。ディスク全体をVGに追加することをお勧めします。
# pvcreate /dev/sdb
# vgextend rhel /dev/sdb