LVM и аварийное восстановление
Я понимаю, что такое LVM и чего он добивается, но мне кажется, что мне чего-то не хватает.
Допустим, у нас есть два физических диска, sda и sdb. Оба по 100 мегабайт. Я помещаю их в VolumeGroup1 и создаю один 200 мегабайт LogicalVolume1.
Что произойдет, если я создам файл размером 150 мегабайт? Будет ли 100 мегабайт физически на SDA и 50 на SDB? Если это так, что говорит ОС, что часть файла находится на одном диске, а другая - на другом?
Как насчет сбоя диска? Предполагая отсутствие RAID, если sdb завершится неудачей, будут ли потеряны все данные на sda? Есть ли способ контролировать, какие файлы находятся на каких физических дисках?
Как вы вообще управляете LVM? Вы создаете одну или две большие группы томов, а затем создаете разделы, как это имеет смысл? Любые другие советы?
5 ответов
Допустим, у нас есть два физических диска, sda и sdb. Оба по 100 мегабайт. Я помещаю их в VolumeGroup1 и создаю один 200 мегабайт LogicalVolume1.
Что произойдет, если я создам файл размером 150 мегабайт? Будет ли 100 мегабайт физически на SDA и 50 на SDB?
Правильно (при условии, что файловая система была пуста до создания файла).
Если это так, что говорит ОС, что часть файла находится на одном диске, а другая - на другом?
LVM сообщает операционной системе, что существует один диск емкостью 200 МБ. Часть ядра LVM (она состоит из двух частей, инструментов управления пользовательским пространством и драйверов ядра) затем сопоставит то, что видит операционная система, с физическими местоположениями / блоками на дисках.
Как насчет сбоя диска? Предполагая отсутствие RAID, если sdb завершится неудачей, будут ли потеряны все данные на sda? Есть ли способ контролировать, какие файлы находятся на каких физических дисках?
Да, считают данные потерянными.
Если вы создаете меньшие логические тома, вы можете использовать pvmove
Команда для перемещения их с диска на диск.
Как вы вообще управляете LVM? Вы создаете одну или две большие группы томов, а затем создаете разделы, как это имеет смысл? Любые другие советы?
Я склонен создавать большие группы томов, а затем создавать логические тома по мере необходимости. Нет необходимости полностью выделять все пространство в группе томов; выделить его, когда это необходимо. Размер логического тома легко увеличить, и почти все современные файловые системы тоже могут быть легко расширены.
В основе работы LVM и Software Raid в Linux лежит принцип отображения устройств в ядре. Это то, что абстрагирует адреса блоков физических устройств к используемым вами виртуальным блочным устройствам.
При использовании LVM, как и во всем, что касается данных, вам необходимо знать о последствиях доступности данных. Это не значит, что LVM опасен на самом деле, когда используются правильные методы, его влияние на доступность минимально.
В сценарии, который вы предлагаете в своем вопросе, доступность ваших данных будет такой же, как и у RAID0, где в случае отказа любого диска это приведет к потере данных.
На практике я бы не использовал LVM без запуска его на каком-либо RAID. Я использовал LVM на файловом сервере 30 ТБ, в котором было около 20 томов аппаратного RAID5 в одной VG. Но если у вас достаточно свободных экстентов, вы можете использовать pvmove для переноса данных с одного или нескольких PV, если они начнут вызывать проблемы.
Но всегда имейте стратегию резервного копирования, которая проверяется время от времени.
Как вы вообще управляете LVM? Вы создаете одну или две большие группы томов, а затем создаете разделы, как это имеет смысл?
Моя общая стратегия состоит в том, чтобы поместить в отдельную группу томов физические тома, которые могут быть перенесены (как целый набор) в другую систему.
Если у вас есть внешнее хранилище, рекомендуется поместить его в отдельную группу томов. Физически легко отсоединить его от этого компьютера и подключить к другому, поэтому логически должно быть аналогично легко экспортировать / импортировать его в LVM, сохраняя данные нетронутыми.
Если у вас уже есть vg00 на внутреннем диске (дисках), а затем вы покупаете другой внутренний диск для вашей машины, задайте себе вопрос: будут ли данные на новом диске привязаны к vg00, и не было бы никакого смысла перемещать данные в другую систему? В этом случае он должен быть частью vg00. В противном случае я бы создал vg01, так как он может быть легко экспортирован / импортирован самостоятельно.
Что произойдет, если я создам файл размером 150 мегабайт? Будет ли 100 мегабайт физически на SDA и 50 на SDB? Если это так, что говорит ОС, что часть файла находится на одном диске, а другая - на другом?
LVM (менеджер логических томов) собирает физические тома в группы томов. Каждый физический том (сам диск) имеет небольшие части, называемые физическими экстентами. У этих экстентов есть уникальный идентификатор на диске. На самом деле они нумеруются последовательно. Когда вы создаете логический том, он создается из логических экстентов, которые связаны с физическими экстентами. Логические экстенты имеют уникальный идентификатор в логическом томе. В HP-UX вы можете проверить, какой логический экстент связан с каким физическим экстентом. В SLES11 я не могу понять, как это проверить. lvdisplay --maps
должно быть хорошо, но не идеально (для меня).
Если у вас есть два физических диска в такой группе, то у вас есть массив JBOD (просто набор дисков). Если один из дисков выйдет из строя, вы не будете лучше защищены, чем если бы диски были организованы в массив RAID0.
Вы не можете напрямую контролировать, что происходит на двух дисках, если у вас есть один логический том в группе томов (так как это будет контролироваться файловой системой в томе, а не LVM), хотя, если вы разделите группу томов на несколько логических томов, можно вручную заказать их создание таким образом, чтобы данный логический том находился на данном диске.
Я полагаю, что каждый PV в VG имеет копию схемы LV, и данные не удаляются, как с RAID0, поэтому у вас больше шансов восстановить что-либо, если один из ваших дисков выйдет из строя, но если потеря данных вообще вызывает беспокойство Я бы не стал использовать два диска таким образом (через LVM или RAID0).