Содержание

Работа с дисками

df -h - смонтированные разделы в системе.
lsblk - список дисков и разделов.
fdisk -l - расширенная информация о дисках и разделах.
blkid - тоже инфа по дискам mount - инфа о смонтированных носителях

cfdisk - работа с диском, с неразмеченной областью в т.ч.
du -sh - размер папок.

udev - управление устройствами
udevadm - собсна управление управлением устр-вами

  # список дисков с ID
ls -l /dev/disk/by-id
 
  # информация по диску (в т.ч. размер секторов)
smartctl -a /dev/sda
 
lsblk -td
hdparm -I /dev/sdb
 
  # Полная инфа по устр-ву, серийники, номера и т.д.
udevadm info --query=all --name=/dev/sda

Монтирование дисков/разделов

Монтировать указанный диск к ФС:

# mount /dev/newdisk /desc-fold/

Размонтировать:

# umount /desc-fold/

Монтирование NFS с удаленного хоста

# mount host:/folder /desc-fold

Автоматическое монтирование настраивается в файле /etc/fstab.
Структура записи:

Пример (монтирование raid массива):

/dev/md0        /mnt    ext4    defaults    0 0 

Разметка дисков

cfdisk - работа с разделами, «write» для сохранения изменений
Для ntfs используется тип «Microsoft basic.. что то там»

Для создания ФС утилита mkfs.ext4 или mkntfs, последняя ставится в пакете «ntfs-3g»

RAID массив

Для работы с raid массивами, в Linux есть утилита mdadm, ставится отдельно.

Сборка

Для начала стоит проверить, при необходимости занулить суперблоки на дисках:

# mdadm --zero-superblock --force /dev/sd{b,c}

Далее, удалим метаданные с дисков:

# wipefs --all --force /dev/sd{b,c}

Сборка массива (-l 1 -уровень raid; -n 2 -кол-во дисков):
(рекомендуется указывать ID дисков, узнать можно командой ls -l /dev/disk/by-id)

# mdadm --create --verbose /dev/dm0 -l 1 -n 2 /dev/sd{b,c}

Далее, командой lsblk можно увидеть что в указанных дисках, появились разделы md0.
Процесс синхронизации можно увидеть командой cat /proc/mdstat.
Для сохранения результата, необходимо внести информацию в файл /etc/mdadm/mdadm.conf

echo "DEVICE partitions" > /etc/mdadm/mdadm.conf
mdadm --detail --scan --verbose | awk '/ARRAY/ {print}' >> /etc/mdadm/mdadm.conf

Так же, создаем файловую систему, на созданном диске: mkfs.ext4 /dev/md0 и монтируем диск, при необходимости.

Информация о raid

Состояние всех raid

# cat /proc/mdstat

Подробная информация

# mdadm -D /dev/md0

Проверка целостности

Запуск проверки

# echo 'check' > /sys/block/md0/md/sync_action

Просмотр результата: (0- все в порядке)

# cat /sys/block/md0/md/mismatch_cnt

Остановка проверки:

# echo 'idle' > /sys/block/md0/md/sync_action

Замена диска

Удаляем сбойный диск:

# mdadm /dev/md0 --remove /dev/sdc

Добавляем новый:

# mdadm /dev/md0 --add /dev/sde

Смотрим состояние, синхронизация должна начаться автоматически.
Запасной диск- запасным будет диск, который просто добавлен к массиву, при выходе из строя, он автоматически станет активным

# mdadm /dev/md0 --add /dev/sdd

Чтобы добавить диск в качестве активного, нужно после добавления, расширить массив:

# mdadm -G /dev/md0 --raid-devices=3

Симуляция выхода из строя диска:

# mdadm /dev/md0 --fail /dev/sdb

Удаление массива

umount /folder
mdadm -S /dev/md0
mdadm --zero-superblock /dev/sd{d,c,d}
wipefs --all --force /dev/sd{b,c,d}

Траблы

После аварийного завершения сервера, иногда не запускается ОС, из-за проблем с массивом, хз в чем там тонкости, иногда меняется название массива, ⇒ нужно изменить параметры монтирования.
Иногда не запускается сам массив, сейчас я просто остановил его командой mdadm –stop /dev/md127, попробовал пересобрать, но выдал ошибки, в итоге перезагрузил сервер и заработало..

Переустановка ОС

# После переустановки, поиск созданных массивов
mdadm --assemblr --scan
 
# Тек состояние
mdadm /proc/mdstat
 
# Создайте конфиг файл для массива
mdadm --detail --scan --verbose > /etc/mdadm.conf
 
# Создайте точку монтирования
mkdir /stor1
 
# Далее запись в /etc/fstab
/dev/md127	/stor1	ext4	defaults	0	0
 
# Так же состояние можно посмотреть командой
mdadm -D /dev/md127

LVM

Это метод распределения пространства жесткого диска по логическим томам, размер которых, в последствии можно менять.
Объединить можно место с нескольких физических дисков, в общее логическое пространство, затем из этого пространства выделять логические тома.
Три уровня абстракции:

Для работы нужна утилита lvm2.

Создание

Помечаем диски, для работы в LVM (pvdisplay- просмотр результата)

#pvcreate /dev/sd{b,c}

Создаем группу томов (vgdisplay- просмотр результата)

# vgcreate vg0 /dev/sd{b,c}

Создаем логические тома (lvdisplay- просмотр результата)

# lvcreate -L 50G -n lv0 vg0

Далее создаем ФС, монтируем и т.д.
Обращение к логическому тому происходит через группу: /dev/vg0/lv0.

Удаление

Размонтируем

lvremove /dev/vg/lv0
vgremove vg0
pvremove /dev/sd{b,c}

Примеры

:!: Добавление нового диска в пулл
# Информация об установке LVM
sudo lvmdiskscan
 
# Проверяем подключение нового диска, в данном случае "/dev/sda"
sudo fdisk -l
 
# Создаем физический том
sudo pvcreate /dev/sda
 
# Смотрим существующие группы томов
sudo vgs
 
# Расширяем группу "ubuntu-vg" на созданный физ том
sudo vgextend ubuntu-vg /dev/sda
 
# Смотрим логические тома
sudo lvdisplay
 
# Расширяем нужный логический том
sudo lvextend -l +100%FREE /dev/ubuntu-vg/ubuntu-lv
 
# Теперь нужно расширить файловую систему
# Смотрим какая используется (в данном случае ext4)
lsblk -f
 
# Расширяем ФС на все доступное пространство (безопасно для файлов)
sudo resize2fs /dev/ubuntu-vg/ubuntu-lv
 
   # для xfs
sudo xfs_growfs /dev/ubuntu-vg/ubuntu-lv
 
 
# Смотрим результат
df -h

Ручная разметка при установке

Во время установки, при ручной разметке, для загрузчика достаточно 500мб, с ФС ext2 т.к. она не журналируемая, так же, можно создать раздел подкачки, указав соответствующий тип раздела.
Первые три раздела можно делать первичными, остальные логическими.
Два варианта из-за специфики MBR..