WikiDer > Venti
Эта статья нужны дополнительные цитаты для проверка. (Июнь 2008 г.) (Узнайте, как и когда удалить этот шаблон сообщения) |
Venti это сетевая система хранения, в которой постоянно хранятся блоки данных. 160-битный SHA-1 хеш данных (называемый счет by Venti) действует как адрес данных. Это заставляет однократная запись политики, поскольку нельзя найти другой блок данных с таким же адресом: адреса нескольких записей одних и тех же данных идентичны, поэтому повторяющиеся данные легко идентифицируются, а блок данных сохраняется только один раз. Блоки данных нельзя удалить, что делает его идеальным для постоянного или резервного хранилища. Venti обычно используется с Ископаемое чтобы обеспечить файловую систему постоянными снимками.
История
Venti был разработан и реализован Шон Куинлан и Шон Дорвард в Bell Labs. Он появился в План 9 распространение в 2002 году. Развитие было продолжено Расс Кокс который повторно реализовал большую часть сервера, написал библиотеку для создания структур данных (файлов, каталогов и метаданных) для хранения в Venti и реализовал оптимизацию. Venti доступен как в дистрибутиве Plan 9, так и для многих UNIX-подобных операционных систем.[1] как часть План 9 из пользовательского пространства. Venti входит в состав Inferno с сопутствующими модулями для доступа. Существует Идти набор программ для построения собственных серверов Venti. Включены примеры использования различных видов внутреннего хранилища.
Подробности
Venti - это пространство пользователя демон.[2] Клиенты подключаются к Venti через TCP[2] и общаться, используя простой RPC-протокол. Наиболее важные сообщения протокола перечислены ниже. Обратите внимание, что нет сообщения об удалении адреса или изменении данных по данному адресу.
- читать (оценка, тип), возвращает данные, идентифицированные счет и тип[2]
- запись (данные, тип), магазины данные по адресу, вычисленному с помощью хеширования SHA-1 данные, в сочетании с тип.[2]
Блок данных, сохраняемый Venti, должен быть больше 512 байт и меньше 56 килобайт. Итак, если пользователь / клиент Venti хочет хранить большие блоки данных, он должен создать структуру данных (которая может храниться в Venti). Например, Ископаемое использует хэш-деревья для хранения больших файлов. Сам Venti не заботится о содержимом блока данных; однако он хранит тип блока данных.
Конструкция Venti имеет следующие последствия:
- Поскольку записи являются постоянными, файловая система предназначена только для добавления (что позволяет реализовать простую реализацию с меньшей вероятностью ошибок, разрушающих данные); нет файловой системы фрагментация происходит.
- Клиенты могут проверить правильность сервера: оценка возвращенных данных должна совпадать с запрошенным адресом. Поскольку SHA-1 является криптографически безопасным хешем, изготовление данных с вычислительной точки зрения невозможно.
- Данные не могут быть перезаписаны. Если адрес уже присутствует, данные уже присутствует.
- В аутентификации пользователя нет необходимости: данные не могут быть удалены и могут быть прочитаны, только если известен счет. Единственная потенциальная проблема - это то, что пользователь заполняет диски.
- Данные можно сжимать, не усложняя структуру диска.
Блоки данных хранятся на жесткие диски. Диски, составляющие доступное хранилище, обычно RAID, называется лог данных. Этот журнал данных разделен на более мелкие части, называемые арены, размер которых позволяет записывать их на другие носители, например CD/DVD или же магнитная лента. Другой набор жестких дисков используется для индекса, который сопоставляет оценки с адресами в журнале данных. Структура данных, используемая для индекса, представляет собой хеш-таблица с фиксированным размером ведра. Venti полагается на то, что оценки распределяются случайным образом, поэтому ведра не заполняются. Поскольку каждый поиск стоит один диск время поиска, индекс обычно состоит из нескольких жестких дисков с низким время доступа.
использование
Сервер Venti может использоваться клиентами несколькими способами. Операционная система Plan 9 использует Venti для ежедневного архивирования моментальных снимков файловой системы. Эти копии основной файловой системы могут быть смонтированы как файловое дерево полных копий, упорядоченных по дате. Служебные программы vac и unvac могут использоваться для хранения и получения данных с сервера Venti в виде отдельных файлов или в виде каталога и его содержимого. «Vacfs» позволяет просматривать данные, связанные с оценкой Vac, без полного извлечения всех удаленно сохраненных данных. Баллы данных и индексов могут дублироваться между серверами Venti с помощью rdarena и wrarena. План 9 от Bell Labs, План 9 из пользовательского пространства, Inferno и любые другие клиенты, реализующие протокол Venti, могут использоваться взаимозаменяемо для хранения и извлечения данных.[3]
Коллизии хэшей
Основной принцип теория информации это принцип голубятни, в котором говорится, что если набор A содержит больше значений, чем набор B, то для любой функции, отображающей A в B, будут члены B, которые связаны с более чем одним членом набора A. В случае Venti набор возможные хэши SHA-1, очевидно, меньше, чем набор всех возможных блоков, которые могут быть сохранены в файловой системе, и, следовательно, хэш-коллизия возможно.
Риск случайного хеш-коллизии в 160-битном хеш-коде очень мал даже для экзабайт данных. Однако исторически сложилось так, что многие хеш-функции становятся все более уязвимыми для злонамеренных хеш-коллизий из-за как криптографических, так и вычислительных достижений.[4] Venti не занимается проблемой хеш-коллизий; с этого времени[когда?] по-прежнему невозможно найти коллизии в SHA-1 с вычислительной точки зрения, но Venti может потребоваться переключиться на другую хеш-функцию в какой-то момент в будущем. 23 февраля 2017 года Google объявил SHAttered атака, в ходе которой они сгенерировали два разных файла PDF с одинаковым хешем SHA-1 примерно за 263.1 Оценки SHA-1. [5]
Смотрите также
- Ископаемое - файловая система моментальных снимков, использующая Venti для постоянного хранения
- План 9 из пользовательского пространства
Рекомендации
- ^ Такие как Linux, FreeBSD, NetBSD, OpenBSD, SunOS или же Mac OS X
- ^ а б c d Луккиен, Мехиэль. Анализ Venti и реализация Memventi. Тезис. Университет Твенте, 2007. Нр .: н.п., н.д. Хранилище диссертаций Университета Твенте. Интернет. 13 октября 2014 г. <http://essay.utwente.nl/694/1/scriptie_Lukkien.pdf>.
- ^ "Страница руководства Venti (6) в руководстве Plan 9 4-го издания". Man.cat-v.org. Получено 2013-04-21.
- ^ "HASH COLLISION Q&A." Криптографические исследования. Рамбус, н.д. Интернет. 12 января 2010 г. <https://web.archive.org/web/20100306180648/http://www.cryptography.com/cnews/hash.html>.
- ^ <https://en.wikipedia.org/wiki/SHA-1#SHAttered_–_first_public_collision>
внешняя ссылка
- Venti: новый подход к архивному хранению, бумага с описанием Venti.
- Новая страница руководства Venti (обзор), раздел 7, страница руководства Venti, включая общее описание и формат хранения.
- Новая страница руководства Venti (сервер), раздел 8, страница руководства по серверу вентиляции.
- Новая страница руководства Venti (инструменты), раздел 1, страница руководства по утилитам Venti.
- Код Go для реализации клиентов и серверов.
- Модуль вентиляции в Limbo для Inferno, любезно воплощенные в жизнь благодаря Google Summer of Code.