- Увеличение размера диска Linux «на лету»
- Перейдем к процедуре:
- Диск увеличили, переходим к расширению раздела:
- Adjust the size of a filesystem
- Resize a filesystem/partition
- Увеличение разделов в Linux на горячую
- План действий
- Сканируем диски в системе
- Меняем размер раздела
- Обычные разделы или LVM
- Большой диск GPT
- Увеличение файловой системы
- Обычная разметка
- LVM
- Итог
- TL;DR
Увеличение размера диска Linux «на лету»
Увеличение размера диска или раздела Linux — достаточно частая процедура в жизни сисадмина. При этом, очень часто требуется выполнить эту операцию «на лету», без остановки работающих сервисов.
В моей практике чаще всего приходилось увеличивать раздела для хранения данных СУБД, вроде Postgres или Mysql, из-за растущего числа клиентов у бизнеса и быстро разрастающихся баз на проде, из-за чего процедура первое время казалась очень страшной. Но на самом деле не так страшен чёрт, как его малюют.
Однако, описанное выше, не отменяет необходимость создания резервной копии перед выполнением процесса. Помните — своевременный бэкап — сохраняет ваши нервы и деньги ваших клиентов. Всегда есть шанс, что что-то пойдет не по плану.
Перейдем к процедуре:
В примере использую тестовую ВМ с Ubuntu-20.04 на борту и 51Гб диска без LVM, у воображаемого хостера в вакууме.
Прежде всего нужно убедится, что увеличение раздела действительно требуется, потому проверяем место на диске, выполнив в консоли:
На скрине выше корневой раздел, сточкой монтирования « / » занят на 22%, из 49Гб свободно только 36Гб. А нужно 40Гб, по этому добавим 5Гб нашей ВМ.
Тут вам следует расширить диск вашей машины в гипервозире или панели управления облаком. Я добавил диску 5Гб.
После физического расширения — проверяем, что место добавилось командой:
Как видно на скрине — диск увеличился на 5Гб до 56Гб, если у вас размер диска не увеличился, то просим систему просканировать железо выполнив команду:
echo 1>/sys/class/block/sda/device/rescan
И по завершении — снова просим lsblk . В результате вы должны увидеть увеличенный объем диска.
Диск увеличили, переходим к расширению раздела:
Запускаем утилиту fdisk выполнив команду:
Откроется консоль утилиты, для начала смотрим текущий статус, вводим:
Видим /dev/sda2 размером 49.5Гб который требуется увеличить.
Удаляем раздел введя в консоли:
Консоль предложит вам выбрать раздел, который вы собираетесь удалить, в моем случае это /dev/sda2 , по этому ввожу 2
При этом удалится только запись о диске, данные на нём сохранятся.
Теперь на его месте создаем новый раздел, с увеличенным объемом, вводим:
Консоль проведет вас через несколько шагов создания раздела:
- Partition number (2-128, default 2) — Логический номер нового раздела, по умолчанию 2, просто нажимаем на Enter
- First sector (1050624-117440478, default 1050624) — Адрес начала диска, вариант по умолчанию нас так же устраивает — оставляем пустым, жмём Enter
- Last sector, +/-sectors or +/-size (1050624-117440478, default 117440478) — Адрес конца диска, по умолчанию самый последний сектор, нас устраивает — оставляем пустым, жмём Enter
После этого система сообщит что нашла файловую систему, хотим ли мы её удалить, мы не хотим, потому отвечаем:
Проверяем результат, снова вводим:
Видим, что раздел увеличился, сохраняем и выходим из утилиты введя в консоли:
Теперь просим систему перечитать таблицу разделов, вводим:
Команда не вернет никакого сообщения в консоль, а нам осталось расширить файловую систему, вводим:
Команда вернет нам сообщение об увеличении раздела
И снова проверяем объем свободного места на диске:
Радуемся увеличившемуся месту.
Adjust the size of a filesystem
A filesystem can be grown to make use of the free space after its partition. Often this is even possible while the filesystem is mounted.
To make space for another partition after the filesystem, it can be shrunk according to the free space within it.
Not all filesystems have resize support.
The partition size will be changed together with the filesystem size. It is also possible to resize a partition without a filesystem in the same way.
Resize a filesystem/partition
- Open Disks from the Activities overview.
- Select the disk containing the filesystem in question from the list of storage devices on the left. If there is more than one volume on the disk, select the volume which contains the filesystem.
- In the toolbar underneath the Volumes section, click the menu button. Then click Resize Filesystem… or Resize… if there is no filesystem.
- A dialog will open where the new size can be chosen. The filesystem will be mounted to calculate the minimum size by the amount of current content. If shrinking is not supported the minimum size is the current size. Leave enough space within the filesystem when shrinking to ensure that it can work fast and reliably. Depending on how much data has to be moved from the shrunk part, the filesystem resize may take longer time.
The filesystem resize automatically involves repairing of the filesystem. Therefore it is advised to back up important data before starting. The action must not be stopped or it will result in a damaged filesystem.
Увеличение разделов в Linux на горячую
Cheatsheet (шпаргалка) по увеличению объема разделов в Linux на горячую без выключения виртуальной машины.
Частая задача в моей текущей работе — увеличить объем раздела на виртуальной машине без выключения машины (на горячую). Под рукой постоянно держу небольшой cheatsheet (шпаргалку) по работе с разделами в Linux.
План действий
Перед изменением размеров разделов рекомендуется отмонтировать диск. Если диск системный, то нужно загружаться в recovery. Я делаю это на горячую на свой страх и риск.
- Делаем бекап машины! (не могу не написать этого)
- Увеличиваем объем диска в гипервизоре (этот пункт не затрагиваем)
- Сканируем диски в системе
- Меняем размер раздела
- Увеличиваем файловую систему
Сканируем диски в системе
После увеличения объема диска есть вероятность того, что в системе мы новый объем сразу не увидим. Проверяем. Я использую команду lsblk :
root@hostname.infra.local:/home/user# lsblk NAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINT fd0 2:0 1 4K 0 disk loop0 7:0 0 99,2M 1 loop /snap/core/10908 loop2 7:2 0 99,2M 1 loop /snap/core/10958 sda 8:0 0 32G 0 disk ├─sda1 8:1 0 1M 0 part └─sda2 8:2 0 32G 0 part / sdb 8:16 0 4T 0 disk
Стрелкой я выделил диск, который мы увеличили до 5Т, но увеличенный объем не видим.
Нужно заставить систему просканировать диск.
echo 1 > /sys/block/sdb/device/rescan
Сразу после этого снова выполняем lsblk :
sdb 8:16 0 5T 0 disk └─sdb1 8:17 0 4T 0 part /pgsqldb
То что нужно. Перейдем к увеличению раздела.
Меняем размер раздела
Вообще, мы можем для любых вариантов использовать программу parted, но я покажу еще способ с программой fdisk. Он подходит для разделов объемом менее 4 терабайт.
Здесь будет несколько вариантов:
- у нас обычная разметка диска или LVM
- у нас диск c таблицей разметки GPT более 4 терабайт объемом
Рекомендую на этом этапе сначала выполнить команду parted -l , которая может показать ошибку и предложить опции Fix\\Ignore :
Warning: Not all of the space available to /dev/sdb appears to be used, you can fix the GPT to use all of the space (an extra 41943040 blocks) or continue with the current setting? Fix/Ignore? Fix
Обычные разделы или LVM
Чаще всего я пользуюсь программой fdisk. Можно посмотреть все наши диски\разделы: fdisk -l .
Так как меняем размер раздела на диске sdb , то и заходим в fdisk /dev/sdb.
Вводим команду p и получаем наш текущий список разделов:
Device Start End Sectors Size Type /dev/sdb1 2048 8589843750 8589841703 4T Linux filesystem
Удаляем раздел /dev/sdb1 : вводим команду d .
Command (m for help): d Selected partition 1 Partition 1 has been deleted.
Если разделов на диске больше, программа предложит ввести цифру нужного раздела.
Создаем новый раздел n :
Command (m for help): n Partition number (1-128, default 1): First sector (34-8589934558, default 2048): Last sector, +sectors or +size (2048-8589934558, default 8589934558): Created a new partition 1 of type 'Linux filesystem' and of size 4 TiB.
Обратите внимание, программа сообщает, что при создании раздела она нашла запись ext4 в разделе и предлагает удалить ее. Не удаляем. Нет! Не надо!
Partition #1 contains a ext4 signature. Do you want to remove the signature? [Y]es/[N]o: N
Опять вводим команду p , чтобы посмотреть новую информацию:
Device Start End Sectors Size Type /dev/sdb1 2048 10751953125 10751951078 5T Linux filesystem
Ну вроде все хорошо. Теперь вводим команду w (write). После этого ваши изменения запишутся на диск.
Большой диск GPT
Если по предыдущему пункту попробовать отресайзить диск большого объема (больше 4 терабайт), то появится ошибка Value out of range . Придется воспользоваться программой parted.
Делаем parted /dev/sdb и смотрим текущие разделы командой print :
(parted) print Model: VMware Virtual disk (scsi) Disk /dev/sdb: 4398GB Sector size (logical/physical): 512B/512B Partition Table: gpt Disk Flags: Number Start End Size File system Name Flags 1 1049kB 3299GB 3299GB ext4 primary
Меняем размер раздела командой resizepart 1 :
(parted) resizepart 1 Warning: Partition /dev/sdb1 is being used. Are you sure you want to continue? Yes/No? Yes End? [3299GB]? 4398GB
На вопрос End? пишем новый объем раздела. Если хотим расширить его до максимума, то цифры можно подсмотреть выше в выводе команды print : Disk /dev/sdb: 4398GB
Здесь изменения происходят сразу, поэтому при отсутствии вывода после предыдущей команды можно делать quit.
Увеличение файловой системы
Тут должно быть все просто. Разница только между разметками: обычная или LVM.
Обычная разметка
Просто выполняем команду resize2fs /dev/sdb1 :
root@hostname.infra.local:/home/user# resize2fs /dev/sdb1 resize2fs 1.44.1 (24-Mar-2018) Filesystem at /dev/sdb1 is mounted on /pgsqldb; on-line resizing required old_desc_blocks = 384, new_desc_blocks = 512 The filesystem on /dev/sdb1 is now 1073730212 (4k) blocks long.
LVM
Вообще, LVM позволяет добавлять физические диски (PV - physical volume) в VG - volume group, а в них создавать логические тома (LV - logical volume) примерно по такой схеме:
Следовательно, можно не ресайзить диск в гипервизоре, а добавить еще один. Затем добавить новый PV в VG.
Но мы идем путем джедая увеличения диска, поэтому в случае с LVM к ресайзингу файловой системы добавляется несколько команд.
Для просмотра информации о PV, VG, LV существуют команды pvs , vgs , lvs . И их более подробные варианты pvscan , vgscan , lvscan :
root@hostname:/home/user# pvs PV VG Fmt Attr PSize PFree /dev/sda5 t-ubuntu16-vg lvm2 a-- 49.52g 0 root@hostname:/home/user# vgs VG #PV #LV #SN Attr VSize VFree t-ubuntu16-vg 1 2 0 wz--n- 49.52g 0 root@hostname:/home/user# lvs LV VG Attr LSize Pool Origin Data% Meta% Move Log Cpy%Sync Convert root t-ubuntu16-vg -wi-ao---- 48.52g swap_1 t-ubuntu16-vg -wi-ao---- 1.00g
- Меняем размер PV pvresize /dev/sda1
- Увеличиваем размер LV до максимального lvextend -l +100%FREE /dev/mapper/vg1-dsads-lv-root
- Увеличиваем файловую систему на нужном разделе resize2fs /dev/mapper/vg1-dsads-lv-root
Итог
Смотрим, что у нас получилось df -h :
root@hostname.infra.local:/home/user# df -h Filesystem Size Used Avail Use% Mounted on udev 38G 0 38G 0% /dev tmpfs 7,5G 4,4M 7,5G 1% /run /dev/sda2 32G 24G 6,3G 79% / /dev/sdb1 5,0T 3,3T 1,5T 71% /pgsqldb
Видим новый объем. Все счастливы и довольны.
TL;DR
Кратко cheatsheet у меня выглядит так:
Смотрим, видит ли система новое место на дисках: lsblk , parted -l , fdisk -l
Если не видит: echo 1 > /sys/block/sda/device/rescan (вместо sda - нужный диск) fdisk /dev/sda (if sda)
d - удалить раздел который расширяешь
n - создать новый раздел (создастся с тем индексом, который удалишь)
В большинстве случаев везде ответы будут по умолчанию. Когда спросит про затирание метки - НЕ удалять
p - проверить что разделы имеют тот же вид что и в начале
w - записать изменения на диск
resize2fs /dev/sda1 (номер - индекс раздела)
lvextend -l +100%FREE /dev/mapper/vg1-dsads-lv-root
Если ошибка с gpt
💡 Подписывайтесь на Телеграм-канал, чтобы не пропускать новые статьи