Yum
YUM (Yellowdog Updater, Modified) — открытый консольный менеджер пакетов для дистрибутивов Linux, основанных на пакетах формата RPM (RedHat, CentOS, Fedora, Oracle Linux)[2]. Позволяет облегчить работу с обновлениями дистрибутивов, отслеживая взаимозависимости между пакетами. Распространяется под лицензией GNU GPL-2.0-or-later. Первоначально проект был разработан программистом Seth Vidal и группой волонтёров. Для работы с YUM используется интерфейс командной строки, однако существуют надстройки, предоставляющие графический интерфейс для функциональности YUM.
Yellowdog updater, Modified | |
---|---|
Yum обновляет Fedora 16. | |
Тип | Пакетный менеджер |
Разработчик | Seth Vidal |
Написана на | Python[1] |
Операционная система | Linux |
Последняя версия | 3.4.3 (28 июня 2011) |
Лицензия | GNU GPL 2 или выше |
Сайт | yum.baseurl.org |
Медиафайлы на Викискладе |
YUM позволяет системным администраторам и пользователям настроить автоматизированные обновление ПО и разрешение зависимостей[3]. Для этого используется ряд инструментов, таких как yum-updatesd, yum-updateonboot, yum-cron, PackageKit. Как и Advanced Package Tool (система APT) из дистрибутивов класса Debian, менеджер YUM работает с репозиториями (наборами) пакетов от производителя дистрибутива или от сторонних авторов. Возможно создание локальных или офлайновых копий репозиториев[4], либо доступ к ним через сетевое Интернет-соединение.
В своем внутреннем устройстве YUM зависит от приложения RPM и использует формат RPM-пакетов. Пакеты обычно имеют криптографические подписи (MD5-хеш и «digisig»)[5] для подтверждения того, что данный файл был подготовлен определенным автором (однако метаданные не подписывались до начала 2010-х годов)[6]. Приложение YUM реализовано как набор библиотек на языке программирования Python и несколько приложений командной строки. Среди графических интерфейсов к YUM — YUM Extender (yumex)[7].
В Fedora 18-й версии началось внедрение более быстрого форка yum под названием «DNF»[8], с 20 версии он мог использоваться вместо yum, а в 22 версии весной 2014 года произошел переход от YUM в пользу dnf[9][10][11][12]. DNF был создан для улучшения YUM в части производительности, качества разрешения конфликтов зависимостей и для упрощения интеграции с другими приложениями[13]. В то же время, в версию YUM 4 2017 года были перенесены многие возможности DNF, в том числе, ускоренное разрешение зависимостей[14][15].
ВозможностиПравить
YUM представляет собой оболочку для RPM, обеспечивающую работу с репозиториями. Был создан для решения следующих задач[16]:
ИсторияПравить
В 1999—2001 году был разработан менеджер Yellowdog UPdater (YUP) в компании Terra Soft Solutions в качестве основы для графического инсталлятора дистрибутива Yellow Dog Linux[2].
Позже, в целях управления системами Red Hat Linux в университете Дьюка, сотрудники физического факультета Seth Vidal и Michael Stenner полностью переписали YUP, создав Yellowdog Updater, Modified, сокращенно "YUM". Seth Vidal продолжил работу над программой до 2013 года.[18][19][20][21]
В 2003 году Robert G. Brown (университет Дьюка) опубликовал документацию по YUM[22]. В дальнейшем ряд дистрибутивов[22] начали использовать YUM, в том числе Fedora, CentOS и другие, построенные на основе RPM. На YUM также перешел Yellow Dog Linux. Оригинальная утилита YUP в последний раз обновлялась в 2001 году[23]. К 2005 году менеджер YUM использовался примерно на половине рынка Linux-дистрибутивов[1], и в 2007 году 2007 YUM признавался наиболее популярным менеджером для RPM дистрибутивов[24].
Приложение YUM устраняло ряд видимых недостатков старого менеджера APT-RPM[25], и ограничения оригинального менеджера пакетов up2date[en] из состава Red Hat. В вышедшей в 2007 году версии Red Hat Enterprise Linux 5 менеджер up2date был заменен на YUM[26][27]. Некоторые авторы называют пакет «Yellowdog Update Manager» или предлагают расшифровку «Your Update Manager»[28][29].
Знание команд YUM часто является требованием для получения сертификатов по администрированию Linux[3].
Пакет YUM распространяется под условиями GNU General Public License, что позволяет свободно распространять приложение и его модификации[2].
РасширенияПравить
В версии 2.x YUM был добавлен интерфейс для написания расширений на языке Python. Такие расширения позволяют изменять поведение YUM, ряд плагинов устанавливается по умолчанию[30]. Например, обычно устанавливается[31] пакет yum-utils
который содержит команды для работы с YUM API и ряд плагинов.
МетаданныеПравить
Информация о пакетах (в отличие от самих файлов пакетов) в терминологии YUM называется метаданными. В состав метаданных входят списки зависимостей, то есть список других пакетов и их версий, которые необходимы для данного. Корректное заполнение метаданных позволяет избегать «ада зависимостей». Коллекции пакетов и их метаданных организуются в репозитории, основные из них поддерживаются производителем дистрибутива. При помощи отдельной утилиты createrepo
возможно создание частных YUM-репозиториев, в которых метаданные указанного набора пакетов собраны в единый XML файл (или в базу метаданных в формате SQLite[32][33]. Дополнительная утилита mrepo
(ранее называлась «Yam») упрощает создание и поддержку репозиториев[34].
XML-репозитории YUM быстро приобрели популярность для публикации наборов пакетов для дистрибутивов на базе RPM-пакетов[33]. Кроме традиционных RPM дистрибутивов от RedHat (RHEL, Fedora), их клонов (CentOS) и многочисленных менее известных вариаций, репозитории YUM могут использоваться в SUSE Linux 10.1[35] (менеджер пакетов YaST). Система репозиториев Open Build Service также использует формат YUM XML[33].
Программа YUM автоматически синхронизирует метаданные через сеть[36][37].
Механизмы безопасности, применяемые к метаданным в YUM неоднократно критиковались[38][39][40][6]. В 2015 годах CentOS внедрил подписывание метаданных для основных репозиториев CentOS 6 и CentOS 7[41], а в 2018 — для всех репозиториев[42]. RedHat традиционно решал проблему при помощи безопасного транспорта[43][44].
Графические оболочкиПравить
См. такжеПравить
ПримечанияПравить
- ↑ 1 2 Jang, Michael H. Chapter 7 – Setting Up a YUM Repository // Linux Patch Management: Keeping Linux Systems Up to Date (англ.). — Prentice Hall Professional, 2005.
- ↑ 1 2 3 Brown, Robert G. YUM (Yellowdog Updater, Modified) HOWTO - Introduction (неопр.). Duke Physics. Дата обращения: 12 июля 2013. Архивировано 2 августа 2013 года.
- ↑ 1 2 Shields, Ian RPM and YUM package management (неопр.). Learn Linux, 101. IBM (11 мая 2010). Дата обращения: 12 июля 2013. Архивировано 2 октября 2016 года.
- ↑ Creating a Local YUM Repository Using an ISO Image (неопр.). Oracle. Дата обращения: 12 июля 2013. Архивировано 19 августа 2013 года.
- ↑ Ian Shields, RPM and YUM package management Архивная копия от 21 октября 2018 на Wayback Machine / IBM, 2010
- ↑ 1 2 Koen Vervloesem, Attacks on package managers Архивная копия от 21 октября 2018 на Wayback Machine / LWN, April 8, 2009
- ↑ Yum Extender (неопр.). Yumex Homepage. Дата обращения: 13 июля 2013. Архивировано 12 ноября 2020 года.
- ↑ Bruce Byfield. Will DNF Replace Yum? Behind the Scenes at Fedora’s Future Package Manager (англ.). Linux Magazine (2014). Дата обращения: 21 октября 2018. Архивировано 26 сентября 2015 года.
- ↑ Miller, Matthew Board Meeting, Rawhide Rebuilt, Firewall Debate, ARM 64, and DNF as Yum Replacement (5tFTW 2014-06-10) (неопр.). Fedora Magazine (11 июня 2014). Дата обращения: 4 мая 2016. Архивировано 11 апреля 2016 года.
- ↑ OpenNews: В Fedora 22 ожидается замена пакетного менеджера Yum на DNF (неопр.). Дата обращения: 13 мая 2015. Архивировано 4 марта 2016 года.
- ↑ В Fedora 22 ожидается замена пакетного менеджера Yum на DNF / linuxforum (неопр.). Дата обращения: 13 мая 2015. Архивировано из оригинала 17 ноября 2015 года.
- ↑ Технический комитет Fedora подтвердил планы по замене Yum на DNF в Fedora 22 — Новости (nixp.ru) (неопр.). Дата обращения: 13 мая 2015. Архивировано 18 мая 2015 года.
- ↑ Edge, Jake DNF and Yum in Fedora (неопр.). LWN.net (15 января 2014). Дата обращения: 16 октября 2018. Архивировано 30 сентября 2015 года.
- ↑ YUM 4 is available for testing – Blog.CentOS.org (неопр.). Дата обращения: 21 октября 2018. Архивировано 21 октября 2018 года.
- ↑ OpenNews: Началось тестирование пакетного менеджера YUM 4 (неопр.). Дата обращения: 21 октября 2018. Архивировано 21 октября 2018 года.
- ↑ Jang, Michael H. Linux Patch Management: Keeping Linux Systems Up to Date (англ.). — Prentice Hall Professional. — P. 199. — (Bruce Perens' Open Source series). — ISBN 9780132366755.
- ↑ Fedora Documentation — Downgrade to a Previous Version (неопр.). Дата обращения: 11 июня 2012. Архивировано 11 января 2012 года.
- ↑ Seth Vidal, creator of "yum" open source software, killed in bike accident off Hillandale Rd. (неопр.) Durham io: The Daily Durham (9 июля 2013). Дата обращения: 13 июля 2013. Архивировано 12 июля 2013 года.
- ↑ Thank you, Seth Vidal (неопр.). Red Hat (10 июля 2013). Дата обращения: 13 июля 2013. Архивировано 14 июля 2013 года.
- ↑ Bort, Julie 36-Year-Old Open Source Guru Seth Vidal Has Been Tragically Killed (неопр.). Business Insider (9 июля 2013). Дата обращения: 13 июля 2013. Архивировано 12 июля 2013 года.
- ↑ Погиб один из ведущих разработчиков Fedora Linux, CNews (10 июля 2013). Архивировано 21 октября 2018 года. Дата обращения: 21 октября 2018.
- ↑ 1 2 Brown, Robert G. YUM: Yellowdog Updater, Modified (неопр.) (17 декабря 2003). Дата обращения: 13 июля 2013. Архивировано 2 октября 2013 года.
- ↑ Yellow Dog Update Program (неопр.). SourceForge repository. Дата обращения: 18 июля 2013. Архивировано 4 октября 2013 года.
- ↑ Fusco, John. The Linux Programmer's Toolbox (неопр.). — Pearson Education (англ.) (рус.. — ISBN 9780132703048.
- ↑ Murphy, David How to run your own yum repository (неопр.). Linux Foundation (23 июля 2004). Дата обращения: 12 июля 2013. Архивировано из оригинала 21 июля 2013 года.
- ↑ What are the yum equivalents of up2date and rpm common tasks on Red Hat Enterprise Linux? (неопр.) Red Hat. Дата обращения: 21 октября 2018. Архивировано 8 января 2014 года.
- ↑ Red Hat Enterprise linux 5. Feature, function, and benefit summary (англ.). RedHat (2007). Дата обращения: 21 октября 2018. Архивировано 21 октября 2018 года.
- ↑ Sweeney, Michael. Network Security Using Linux (неопр.). — 2005. — С. 84. — ISBN 9781411621770.
- ↑ Negus, Christopher; Bresnahan, Christine. Linux Bible (неопр.). — John Wiley & Sons, 2012. — С. 598. — ISBN 9781118286906.
- ↑ Yum Plug-ins (неопр.). Red Hat. Дата обращения: 12 июля 2013. Архивировано 2 октября 2013 года.
- ↑ Maintaining yum (неопр.). CentOS. Дата обращения: 12 июля 2013. Архивировано из оригинала 18 ноября 2018 года.
- ↑ createrepo(8) (неопр.). Linux manual page. Дата обращения: 12 июля 2013. Архивировано 3 июля 2013 года.
- ↑ 1 2 3 Standards Rpm Metadata (неопр.). openSUSE. Дата обращения: 12 июля 2013. Архивировано 17 мая 2013 года.
- ↑ mrepo (неопр.). Freecode. Дата обращения: 12 июля 2013. Архивировано 21 июня 2014 года.
- ↑ SUSE Linux 10.1 Alpha 2 is ready (неопр.). Дата обращения: 12 июля 2013. Архивировано 8 февраля 2006 года.
- ↑ Schmitz, Dietrich T. YUM vs. APT: Which is Best? (неопр.) Дата обращения: 21 октября 2018. Архивировано 21 октября 2018 года.
- ↑ ‘Linux Advocates’ Throws in the Towel (неопр.). FOSS Force (январь 2015). Дата обращения: 21 октября 2018. Архивировано 21 октября 2018 года.
- ↑ Attacks on Package Managers Архивная копия от 20 декабря 2018 на Wayback Machine, Отчет о проблемах безопасности при работе менеджеров пакетов в Linux Архивная копия от 21 октября 2018 на Wayback Machine 15.07.2008
- ↑ Justin Cappos, et al. Package Management Security Архивная копия от 21 октября 2018 на Wayback Machine University of Arizona Technical Report (2008): 08-02; «A look in the mirror: Attacks on package managers» / Proceedings of the 15th ACM conference on Computer and communications security. ACM, 2008.
- ↑ Justin Cappos, Justin Samuel, Package managers still vulnerable: how to protect your systems Архивная копия от 21 октября 2018 на Wayback Machine / USENIX, 2009
- ↑ Signed Repository Metadata is now Available for CentOS 6 and 7 for the Updates Repo – Blog.CentOS.org (неопр.). Дата обращения: 21 октября 2018. Архивировано 21 октября 2018 года.
- ↑ Improving CentOS package delivery security with signed repository metadata – Blog.CentOS.org (англ.). blog.centos.org. Дата обращения: 25 октября 2018. Архивировано 21 октября 2018 года.
- ↑ Secure distribution of RPM packages - Red Hat Customer Portal (англ.). access.redhat.com. Дата обращения: 25 октября 2018. Архивировано 21 октября 2018 года.
- ↑ cdn.redhat.com X.509 certificate - Red Hat Customer Portal (англ.). access.redhat.com. Дата обращения: 25 октября 2018. Архивировано 21 октября 2018 года.
- ↑ PackageKit - Main Page (неопр.). Дата обращения: 14 октября 2018. Архивировано 21 сентября 2018 года.
СсылкиПравить
- Exploring the yum package manager — Linux Magazine issue 103, June 2009 (англ.)
- Roderick W. Smith, Linux Software Management with yum / Linux Magazine, 2007-02-16
- Linux in a Nutshell, 6th Edition ISBN — O’Reilly, 2009, ISBN 9780596806088 — 5. Package Management, «Yum: Yellowdog Updater Modified»
- Ian Shields, RPM and YUM package management / IBM, 2010
- Q. Ethan McCallum, Managing RPM-Based Systems with Kickstart and Yum, ISBN 9780596513825
- Алексей Федорчук, LXF125:Yum, Декабрь 2009
- LXF138:Управление пакетами. Yum и APT, Декабрь 2010
- Package Management Basics apt, yum, dnf, zypper, and pkg