LVM resize root volume
Since this is a root/boot volume we are talking about anything on this page is VERY risky. Be warned this post may provide you with a strategy or hints but you are completely responsible for your system.
Of course the best route to extend a root volume in an unmounted state is to boot of a Live CD. In some cases and even more relevant a lot of cloud instances you do not have normal physical or virtualization methods to access server consoles.
I have been trying a couple ideas. First one is using dracut to resize the root volume on system bootup. I have had success with this method. The second method is using pivot_root. On this method it may be slightly easier on systemd servers but for my paritcular need I have an older Centos 6 flavor without systemd and so far I could not get pivot_root and resize online to work.
Below is notes on method 1 (dracut resize):
Specs:
VirtualBox VM CentOS6.4
Disk layout 15G
- /boot 200M ext4
- / LV 13G ext4
- /u01 LV 2G ext4
GOAL:
1. Resize / file system smaller without boot CD only SSH access. Using dracut bootup.
2. Extend /u01 with the additional space in the VG
[root@localhost ~]# df -h
Filesystem Size Used Avail Use% Mounted on
/dev/mapper/VolGroupSys-LogVolRoot
11G 2.1G 8.7G 20% /
tmpfs 1.9G 0 1.9G 0% /dev/shm
/dev/sda1 194M 29M 155M 16% /boot
/dev/mapper/VolGroupSys-LogVolU01
2.1G 68M 2.0G 4% /u01
[root@localhost ~]# pvs
PV VG Fmt Attr PSize PFree
/dev/sda2 VolGroupSys lvm2 a-- 14.80g 1.70g
[root@localhost ~]# vgs
VG #PV #LV #SN Attr VSize VFree
VolGroupSys 1 2 0 wz--n- 14.80g 1.70g
[root@localhost ~]# lvs
LV VG Attr LSize Pool Origin Data% Move Log Cpy%Sync Convert
LogVolRoot VolGroupSys -wi-ao--- 11.00g
LogVolU01 VolGroupSys -wi-ao--- 2.11g
# pwd
/usr/share/dracut/modules.d/95rootfs-block
# vi mount-root.sh
[..]
if [ -n "$root" -a -z "${root%%block:*}" ]; then
## custom code testing lvresize on root vol
lvm vgchange -ay --config " global {locking_type=1} "
rm -f /etc/lvm/lvm.conf
e2fsck -C 0 -f /dev/VolGroupSys/LogVolRoot
resize2fs -p -f /dev/VolGroupSys/LogVolRoot 8G
lvm lvresize -f /dev/VolGroupSys/LogVolRoot -L 8G
resize2fs -p -f /dev/VolGroupSys/LogVolRoot
e2fsck -C 0 -f /dev/VolGroupSys/LogVolRoot
mount -t ${fstype:-auto} -o "$rflags" "${root#block:}" "$NEWROOT" \
[..]
# dracut -f --install 'resize2fs e2fsck'
# reboot
Verify after the reboot
# pvs
PV VG Fmt Attr PSize PFree
/dev/sda2 VolGroupSys lvm2 a-- 14.80g 4.70g
# vgs
VG #PV #LV #SN Attr VSize VFree
VolGroupSys 1 2 0 wz--n- 14.80g 4.70g
# lvs
LV VG Attr LSize Pool Origin Data% Move Log Cpy%Sync Convert
LogVolRoot VolGroupSys -wi-ao--- 8.00g
LogVolU01 VolGroupSys -wi-ao--- 2.11g
# df -h
Filesystem Size Used Avail Use% Mounted on
/dev/mapper/VolGroupSys-LogVolRoot
7.9G 2.1G 5.8G 26% /
tmpfs 1.9G 0 1.9G 0% /dev/shm
/dev/sda1 194M 30M 155M 16% /boot
/dev/mapper/VolGroupSys-LogVolU01
2.1G 68M 2.0G 4% /u01
** remove custom code from mount-root.sh
# dracut -f # reboot
#################################################################
### EXTEND u01
#################################################################
# lvextend -L+2G /dev/VolGroupSys/LogVolU01
Extending logical volume LogVolU01 to 4.11 GiB
Logical volume LogVolU01 successfully resized
# resize2fs /dev/VolGroupSys/LogVolU01
resize2fs 1.41.12 (17-May-2010)
Filesystem at /dev/VolGroupSys/LogVolU01 is mounted on /u01; on-line resizing required
old desc_blocks = 1, new_desc_blocks = 1
Performing an on-line resize of /dev/VolGroupSys/LogVolU01 to 1076224 (4k) blocks.
The filesystem on /dev/VolGroupSys/LogVolU01 is now 1076224 blocks long.
# vgs
VG #PV #LV #SN Attr VSize VFree
VolGroupSys 1 2 0 wz--n- 14.80g 2.70g
# lvs
LV VG Attr LSize Pool Origin Data% Move Log Cpy%Sync Convert
LogVolRoot VolGroupSys -wi-ao--- 8.00g
LogVolU01 VolGroupSys -wi-ao--- 4.11g
# df -h
Filesystem Size Used Avail Use% Mounted on
/dev/mapper/VolGroupSys-LogVolRoot
7.9G 2.1G 5.8G 26% /
tmpfs 1.9G 0 1.9G 0% /dev/shm
/dev/sda1 194M 29M 155M 16% /boot
/dev/mapper/VolGroupSys-LogVolU01
4.1G 69M 3.8G 2% /u01
#################################################################
### APPENDIX:
#################################################################
** Use /var/messages/boot.log to check dracut failures on our custom code
[bash]
# more boot.log
e2fsck 1.41.12 (17-May-2010)
Pass 1: Checking inodes, blocks, and sizes
_CentOS-6.4-x86_: |=== - 4.8%
Pass 2: Checking directory structure
Pass 3: Checking directory connectivity
Pass 4: Checking reference counts
Pass 5: Checking group summary information
_CentOS-6.4-x86_: 76680/835584 files (0.1% non-contiguous), 578555/3328000 blocks
resize2fs 1.41.12 (17-May-2010)
Resizing the filesystem on /dev/VolGroupSys/LogVolRoot to 2621440 (4k) blocks.
Begin pass 3 (max = 102)
Scanning inode table XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
The filesystem on /dev/VolGroupSys/LogVolRoot is now 2621440 blocks long.
Read-only locking type set. Write locks are prohibited.
Can't get lock for VolGroupSys
resize2fs 1.41.12 (17-May-2010)
Resizing the filesystem on /dev/VolGroupSys/LogVolRoot to 3328000 (4k) blocks.
Begin pass 1 (max = 22)
Extending the inode table XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
The filesystem on /dev/VolGroupSys/LogVolRoot is now 3328000 blocks long.
[..]
** Howto check if lvm and resize2fs is in intramfs image
# lsinitrd /boot/initramfs-2.6.32-358.el6.x86_64.img | grep lvm -rw-r--r-- 1 root root 657 Feb 22 2013 etc/udev/rules.d/64-lvm.rules -r--r--r-- 1 root root 1286 Feb 22 2013 etc/udev/rules.d/11-dm-lvm.rules drwxr-xr-x 2 root root 0 May 21 13:27 etc/lvm -rw-r--r-- 1 root root 37554 May 21 13:27 etc/lvm/lvm.conf -rwxr-xr-x 1 root root 2243 Feb 22 2013 sbin/lvm_scan -r-xr-xr-x 1 root root 1013336 May 21 13:27 sbin/lvm [..] -rwxr-xr-x 1 root root 525 Feb 22 2013 cmdline/30parse-lvm.sh # lsinitrd /boot/initramfs-2.6.32-358.el6.x86_64.img | grep resize2fs
#################################################################
#### Some links ...
#################################################################
Kernel panic on boot following "dracut Warning: LVM rootvg/rootlv not found": https://access.redhat.com/solutions/1282013
Rename LVM Volume Group Holding Root File System Volume: https://oraganism.wordpress.com/2013/03/09/rename-lvm-vg-for-root-fs-lv/
How to debug Dracut problems: https://fedoraproject.org/wiki/How_to_debug_Dracut_problems
Inject ephemeral disk into root disk: https://github.com/eucalyptus/eucalyptus/wiki/Inject-ephemeral-disk-into-root-disk
Convert an Existing System to Use Thin LVs: https://dustymabe.com/2013/09/07/convert-an-existing-system-to-use-thin-lvs/
Partition Resize fails on LVM: https://github.com/flegmatik/linux-rootfs-resize/issues/8
How to write a pre-mount startup script?: https://unix.stackexchange.com/questions/87814/how-to-write-a-pre-mount-startup-script
Is it possible to on-line shrink a EXT4 volume with LVM?: https://serverfault.com/questions/528075/is-it-possible-to-on-line-shrink-a-ext4-volume-with-lvm/528076
resize a Linux root partition while it's still mounted: http://www.ivarch.com/blogs/oss/2007/01/resize-a-live-root-fs-a-howto.shtml
How to shrink root filesystem without booting a livecd: https://unix.stackexchange.com/questions/226872/how-to-shrink-root-filesystem-without-booting-a-livecd?utm_medium=organic&utm_source=google_rich_qa&utm_campaign=google_rich_qa
[/bash]