NixOS - NixOS

NixOS
Снежинка NixOS с текстом
Написано вЯзык выражения Nix
Семейство ОСUnix-подобный
Рабочее состояниеВ развитии
Исходная модельОткрытый исходный код
изначальный выпуск2003; 17 лет назад (2003)
Последний релиз20.09 / 27 октября 2020 г.; 42 дней назад (2020-10-27)[1]
Репозиторий Отредактируйте это в Викиданных
Маркетинговая цельОбщее назначение
Менеджер пакетовNix
Платформыi686, x86-64, ARMv7, AArch64
Ядро типМонолитный (Ядро Linux )
ЛицензияМассачусетский технологический институт[2]
Официальный веб-сайтниксос.org

NixOS это Дистрибутив Linux построен на вершине Менеджер пакетов Nix. Оно использует декларативный конфигурации и позволяет надежно обновлять систему.[3] Предлагаются две основные ветки: текущий стабильный выпуск и нестабильный после последней разработки. Хотя NixOS начинался как исследовательский проект,[4] это полностью функциональная и удобная операционная система.[нужна цитата ] В NixOS есть инструменты, предназначенные для DevOps и задачи развертывания.[5][6]

История

NixOS стартовал как исследовательский проект Eelco Dolstra в 2003 году.[4][7]

В Stichting NixOS была основана в 2015 году и направлена ​​на поддержку таких проектов, как NixOS, реализующих чисто функциональную модель развертывания.[8]

Версии

NixOS выпускается постепенно, дважды в год.[9], обычно в марте и в сентябре. Каждый номер версии имеет следующий формат: «ГГ.ММ».

Например: «20.03» - это версия, выпущенная примерно в марте 2020 года.

Кроме того, каждая версия имеет название, например «Мархор» для выпуска 20.03.

История версий
Список версий NixOS[10]
ДатаВерсияИмяПримечания
2013-10-3113.10ТрубкозубПервый стабильный выпуск
2014-04-3014.04БабуинЯдро Linux 3.12
2014-12-3014.12ГусеницаЯдро Linux 3.14
2015-09-3015.09ДингоЯдро Linux 3.18
2016-03-3116.03ЭмуЯдро Linux 4.4
2016-09-3016.09КамбалаЯдро Linux 4.4
2017-03-3117.03ГориллаЯдро Linux 4.9
2017-09-2917.09КолибриЯдро Linux 4.9
2018-04-0418.03ИмпалаЯдро Linux 4.14
2018-10-0518.09МедузаЯдро Linux 4.14
2019-04-1119.03КоиЯдро Linux 4.19
2019-10-0919.09ЛорисЯдро Linux 4.19
2020-04-2020.03МархурЯдро Linux 5.4
2020-10-2720.09СоловейЯдро Linux 5.4

Функции

Декларативная модель конфигурации системы

В NixOS вся операционная система - ядро, приложения, системные пакеты, файлы конфигурации и т. д. - создается менеджером пакетов Nix из описания на функциональном языке сборки. Это означает, что создание новой конфигурации не может перезаписать предыдущие конфигурации.[11]

Система NixOS настраивается путем записи спецификации функций, которые пользователь хочет использовать на своей машине, в глобальном файле конфигурации. Например, вот минимальная конфигурация машины, на которой работает демон SSH:[12]

{  ботинок.грузчик.жратва.устройство = "/ dev / sda";  файловые системы."/".устройство = "/ dev / sda1";  Сервисы.sshd.включить = истинный;}

После изменения файла конфигурации систему можно обновить с помощью переключатель nixos-rebuild команда. Эта команда делает все необходимое для применения новой конфигурации, включая загрузку и компиляцию пакетов и создание файлов конфигурации.

Надежные обновления

Поскольку файлы Nix чистый и декларативный их оценка всегда будет давать один и тот же результат, независимо от того, какие пакеты или файлы конфигурации находятся в системе. Таким образом, обновление системы так же надежно, как и переустановка с нуля.

Атомные улучшения

NixOS использует транзакционный подход к управлению конфигурацией, внося изменения конфигурации, такие как обновления. атомный. Это означает, что если обновление до новой конфигурации будет прервано - скажем, произойдет сбой питания на полпути - система все равно будет находиться в согласованном состоянии: она загрузится либо в старой, либо в новой конфигурации. В других системах машина может оказаться в несогласованном состоянии и даже больше не загружаться.[13]

Откаты

Если после обновления системы новая конфигурация нежелательна, ее можно откатить специальной командой (переключатель nixos-rebuild --rollback). Каждая версия конфигурации системы автоматически отображается в меню загрузки системы. Если новая конфигурация дает сбой или не загружается должным образом, можно выбрать более старую версию. Откаты - это легкие операции, не связанные с восстановлением файлов из копий.

Воспроизводимые конфигурации системы

Модель декларативной конфигурации NixOS позволяет легко воспроизвести конфигурацию системы на другом компьютере. Копирование файла конфигурации на целевой компьютер и запуск команды обновления системы генерирует ту же конфигурацию системы (ядро, приложения, системные службы и т. Д.), За исключением частей системы, не управляемых менеджером пакетов, таких как данные пользователя.

Исходная модель с двоичными файлами

Язык сборки Nix, используемый NixOS, определяет, как собирать пакеты из исходного кода. Это позволяет легко адаптировать систему к потребностям пользователя. Однако, поскольку сборка из исходного кода является медленным процессом, диспетчер пакетов автоматически загружает предварительно созданные двоичные файлы с кэш-сервера, когда они доступны. Это дает гибкость модели управления пакетами на основе исходного кода с эффективностью бинарной модели.[14]

Последовательность

Диспетчер пакетов Nix гарантирует, что работающая система соответствует логической спецификации системы, что означает, что он перестроит все пакеты, которые необходимо перестроить. Например, если ядро ​​изменено, диспетчер пакетов гарантирует, что внешние модули ядра будут перестроены. Точно так же, когда библиотека обновляется, это гарантирует, что все системные пакеты используют новую версию, даже пакеты, статически связанные с ней.

Многопользовательское управление пакетами

Для установки программного обеспечения в NixOS не требуются особые привилегии. В дополнение к общесистемному профилю у каждого пользователя есть специальный профиль, в который они могут устанавливать пакеты. Nix также позволяет сосуществовать нескольким версиям пакета, поэтому разные пользователи могут иметь разные версии одного и того же пакета, установленные в их соответствующих профилях. Если два пользователя устанавливают одну и ту же версию пакета, будет создана или загружена только одна копия, и модель безопасности Nix гарантирует ее безопасность.

Выполнение

NixOS основан на диспетчере пакетов Nix, который хранит все пакеты изолированно друг от друга в хранилище пакетов.

Установленные пакеты идентифицируются криптографическим хешем всех входных данных, используемых для их сборки. При изменении инструкций сборки пакета изменяется его хэш, и в результате в хранилище пакетов устанавливается другой пакет. Эта система также используется для управления файлами конфигурации, гарантируя, что более новые конфигурации не перезаписывают старые.

Следствием этого является то, что NixOS не следует Стандарт иерархии файловой системы. Единственное исключение - символическая ссылка / bin / sh к версии трепать в магазине Nix (вот так: /nix/store/s/5rnfzla9kcx4mj5zdc7nlnv8na1najvg-bash-4.3.43/); и хотя у NixOS есть /так далее каталог для хранения общесистемных файлов конфигурации, большинство файлов в этом каталоге являются символическими ссылками на сгенерированные файлы в / nix / store Такие как / nix / store / s2sjbl85xnrc18rl4fhn56irkxqxyk4p-sshd_config. Не использовать глобальные каталоги, такие как / bin является частью того, что позволяет сосуществовать нескольким версиям пакета.

Прием

Джесси Смит сделал обзор NixOS 15.09 для DistroWatch Weekly.[15] Смит писал:

Мне очень нравится, как NixOS избавляет от проблем с обновлением пакетов, помещая каждое изменение в свое собственное «поколение», и я обнаружил, что с точки зрения конечного пользователя NixOS работает так же, как и любой другой дистрибутив Linux. Настройка NixOS не для новичков, и я не думаю, что NixOS предназначена для использования в качестве настольной операционной системы общего назначения. Но NixOS дает нам полезную площадку для изучения диспетчера пакетов Nix, и я думаю, что это очень интересная технология, которая заслуживает дальнейшего изучения и принятия в дополнительных дистрибутивах.

В DistroWatch Weekly также есть обзор NixOS 17.03, написанный Иваном Сандерсом.[16]

Смотрите также

Рекомендации

  1. ^ «Выпуск 20.09 (« Соловей », 2020-10-27)». 2020-10-27. Получено 2020-10-28.
  2. ^ "nixpkgs / КОПИРОВАНИЕ на главном сервере · NixOS / nixpkgs · GitHub". Github.com. Получено 2015-09-19.
  3. ^ "DistroWatch.com: NixOS". Distrowatch.com. Получено 2015-09-19.
  4. ^ а б Долстра, Eelco. «Интеграция создания программного обеспечения и развертывания программного обеспечения» (PDF). Конспект лекций по информатике. 2649: 102–117. Архивировано из оригинал (PDF) на 2019-04-21.
  5. ^ «NixOps - средство развертывания в облаке NixOS». Nixos.org. Получено 2015-09-19.
  6. ^ «Дисникс». Nixos.org. Получено 2015-09-19.
  7. ^ Долстра, Eelco (2006). Модель развертывания чисто функционального программного обеспечения (PDF) (Кандидат наук.). Архивировано из оригинал (PDF) на 2019-06-09.
  8. ^ «Фонд Stichting NixOS». Nixos.org. Получено 2015-09-19.
  9. ^ "Управление". Nixos.org. Получено 2020-08-28.
  10. ^ «Приложение Б. Информация о версии». Nixos.org. Получено 2020-08-28.
  11. ^ Долстра, Eelco; Хемель, Армийн (2007). «Чисто функциональное управление конфигурацией системы» (PDF). Архивировано из оригинал (PDF) на 2019-07-06. Цитировать журнал требует | журнал = (помощь)
  12. ^ «О NixOS». Nixos.org. Получено 2015-09-19.
  13. ^ ван дер Бург, Сандер; Долстра, Eelco; де Йонге, Мерин (2008). «Атомарная модернизация распределенных систем» (PDF). Архивировано из оригинал (PDF) на 2019-01-15. Цитировать журнал требует | журнал = (помощь)
  14. ^ Долстра, Eelco (2005). «Безопасное совместное использование между ненадежными пользователями в прозрачной исходной / двоичной модели развертывания» (PDF). Архивировано из оригинал (PDF) на 2019-09-26. Цитировать журнал требует | журнал = (помощь)
  15. ^ DistroWatch Weekly, выпуск 637, 23 ноября 2015 г.
  16. ^ DistroWatch Weekly, выпуск 712, 15 мая 2017 г.
  17. ^ "О компании - GuixSD". www.gnu.org. Получено 2018-05-03.

внешняя ссылка