.\" Automatically generated by Pandoc 3.1.3 .\" .\" Define V font for inline verbatim, using C font in formats .\" that render this, and otherwise B font. .ie "\f[CB]x\f[]"x" \{\ . ftr V B . ftr VI BI . ftr VB B . ftr VBI BI .\} .el \{\ . ftr V CR . ftr VI CI . ftr VB CB . ftr VBI CBI .\} .TH "RPM" "8" "25 февраля 2006" "" "" .hy .SH НАЗВАНИЕ .PP rpm - Менеджер пакетов RPM .SH ОБЗОР .SS ЗАПРОС И ПРОВЕРКА ПАКЕТОВ: .PP \f[B]rpm\f[R] {\f[B]-q|--query\f[R]} [\f[B]опции-выбора\f[R]] [\f[B]опции-запроса\f[R]] .PP \f[B]rpm\f[R] {\f[B]-V|--verify\f[R]} [\f[B]опции-выбора\f[R]] [\f[B]опции-проверки\f[R]] .PP \f[B]rpm\f[R] \f[B]--import\f[R] \f[I]PUBKEY ...\f[R] .PP \f[B]rpm\f[R] {\f[B]-K|--checksig\f[R]} [\f[B]--nosignature\f[R]] [\f[B]--nodigest\f[R]] \f[I]PACKAGE_FILE ...\f[R] .SS УСТАНОВКА, ОБНОВЛЕНИЕ И УДАЛЕНИЕ ПАКЕТОВ: .PP \f[B]rpm\f[R] {\f[B]-i|--install\f[R]} [\f[B]опции-установки\f[R]] \f[I]PACKAGE_FILE ...\f[R] .PP \f[B]rpm\f[R] {\f[B]-U|--upgrade\f[R]} [\f[B]опции-установки\f[R]] \f[I]PACKAGE_FILE ...\f[R] .PP \f[B]rpm\f[R] {\f[B]-F|--freshen\f[R]} [\f[B]опции-установки\f[R]] \f[I]PACKAGE_FILE ...\f[R] .PP \f[B]rpm\f[R] {\f[B]-e|--erase\f[R]} [\f[B]--allmatches\f[R]] [\f[B]--nodeps\f[R]] [\f[B]--noscripts\f[R]] [\f[B]--notriggers\f[R]] [\f[B]--test\f[R]] \f[I]PACKAGE_NAME ...\f[R] .SS РАЗНОЕ: .PP \f[B]rpm\f[R] {\f[B]--initdb|--rebuilddb\f[R]} .PP \f[B]rpm\f[R] {\f[B]--addsign|--resign\f[R]} \f[I]PACKAGE_FILE ...\f[R] .PP \f[B]rpm\f[R] {\f[B]--querytags|--showrc\f[R]} .PP \f[B]rpm\f[R] {\f[B]--setperms|--setugids\f[R]} \f[I]PACKAGE_NAME \&...\f[R] .SS опции-выбора .PP [\f[I]PACKAGE_NAME\f[R]] [\f[B]-a,--all\f[R]] [\f[B]-f,--file \f[R]\f[I]FILE\f[R]] [\f[B]-g,--group \f[R]\f[I]GROUP\f[R]] {\f[B]-p,--package \f[R]\f[I]PACKAGE_FILE\f[R]] [\f[B]--hdrid \f[R]\f[I]SHA1\f[R]] [\f[B]--pkgid \f[R]\f[I]MD5\f[R]] [\f[B]--tid \f[R]\f[I]TID\f[R]] [\f[B]--querybynumber \f[R]\f[I]HDRNUM\f[R]] [\f[B]--triggeredby \f[R]\f[I]PACKAGE_NAME\f[R]] [\f[B]--whatprovides \f[R]\f[I]CAPABILITY\f[R]] [\f[B]--whatrequires \f[R]\f[I]CAPABILITY\f[R]] .SS опции-запроса .PP [\f[B]--changelog\f[R]] [\f[B]-c,--configfiles\f[R]] [\f[B]-d,--docfiles\f[R]] [\f[B]--dump\f[R]] [\f[B]--filesbypkg\f[R]] [\f[B]-i,--info\f[R]] [\f[B]--last\f[R]] [\f[B]-l,--list\f[R]] [\f[B]--provides\f[R]] [\f[B]--qf,--queryformat \f[R]\f[I]QUERYFMT\f[R]] [\f[B]-R,--requires\f[R]] [\f[B]--scripts\f[R]] [\f[B]-s,--state\f[R]] [\f[B]--triggers,--triggerscripts\f[R]] .SS опции-проверки .PP [\f[B]--nodeps\f[R]] [\f[B]--nofiles\f[R]] [\f[B]--noscripts\f[R]] [\f[B]--nodigest\f[R]] [\f[B]--nosignature\f[R]] [\f[B]--nolinkto\f[R]] [\f[B]--nomd5\f[R]] [\f[B]--nosize\f[R]] [\f[B]--nouser\f[R]] [\f[B]--nogroup\f[R]] [\f[B]--nomtime\f[R]] [\f[B]--nomode\f[R]] [\f[B]--nordev\f[R]] .SS опции-установки .PP [\f[B]--aid\f[R]] [\f[B]--allfiles\f[R]] [\f[B]--badreloc\f[R]] [\f[B]--excludepath \f[R]\f[I]OLDPATH\f[R]] [\f[B]--excludedocs\f[R]] [\f[B]--force\f[R]] [\f[B]-h,--hash\f[R]] [\f[B]--ignoresize\f[R]] [\f[B]--ignorearch\f[R]] [\f[B]--ignoreos\f[R]] [\f[B]--includedocs\f[R]] [\f[B]--justdb\f[R]] [\f[B]--nodeps\f[R]] [\f[B]--nodigest\f[R]] [\f[B]--nosignature\f[R]] [\f[B]--nosuggest\f[R]] [\f[B]--noorder\f[R]] [\f[B]--noscripts\f[R]] [\f[B]--notriggers\f[R]] [\f[B]--oldpackage\f[R]] [\f[B]--percent\f[R]] [\f[B]--prefix \f[R]\f[I]NEWPATH\f[R]] [\f[B]--relocate \f[R]\f[I]OLDPATH\f[R]\f[B]=\f[R]\f[I]NEWPATH\f[R]] [\f[B]--replacefiles\f[R]] [\f[B]--replacepkgs\f[R]] [\f[B]--test\f[R]] .SH ОПИСАНИЕ .PP \f[B]rpm\f[R] - это мощный \f[B]Менеджер Пакетов\f[R], который может быть использован для сборки, установки, запроса, проверки, обновления и удаления отдельных программных пакетов. \f[B]Пакет\f[R] содержит архив с файлами и метаданные, используемые для установки и удаления файлов архива. Метаданные включают сценарии, атрибуты файлов и информацию с описанием пакета. \f[B]Пакеты\f[R] бывают двух типов: двоичные пакеты, используемые для объединения устанавливаемых программ, и пакеты с исходными кодами, включающие исходные коды и описание способа формирования двоичного пакета. .PP Необходимо указать один из следующих основных режимов работы: \f[B]Запрос\f[R], \f[B]Проверка\f[R], \f[B]Проверка подписи\f[R], \f[B]Установка/Обновление/Освежение\f[R], \f[B]Удаление\f[R], \f[B]Инициализация Базы данных\f[R], \f[B]Перестройка Базы данных\f[R], \f[B]Повторная подпись\f[R], \f[B]Добавление подписи\f[R], \f[B]Задание Владельцев/Групп\f[R], \f[B]Отображение тегов запроса\f[R] и \f[B]Отображение конфигурации\f[R]. .SS ОБЩИЕ ОПЦИИ .PP Эти опции могут быть использованы во всех режимах. .TP \f[B]-?, --help\f[R] Вывести более детальную, чем обычно, справку об использовании. .TP \f[B]--version\f[R] Вывести одну строку, содержащую номер версии \f[B]rpm\f[R]. .TP \f[B]--quiet\f[R] Выводить как можно меньше сообщений - как правило, отображаются только сообщения об ошибках. .TP \f[B]-v\f[R] Выводить подробную информацию - как правило, отображаются сообщения о выполнении всех шагов. .TP \f[B]-vv\f[R] Выводить много отладочной информации. .TP \f[B]--rcfile \f[R]\f[I]FILELIST\f[R] Каждый из файлов разделенного двоеточиями списка файлов \f[I]FILELIST\f[R] последовательно прочитывается \f[I]rpm\f[R] на предмет конфигурационной информации. В этом списке обязан существовать только первый файл; все знаки тильда будут заменены значением \f[B]$HOME\f[R]. По умолчанию список файлов \f[I]FILELIST\f[R] выглядит как \f[I]/usr/lib/rpm/rpmrc\f[R]:\f[I]/usr/lib/rpm//rpmrc\f[R]:\f[I]/etc/rpmrc\f[R]:\f[I]\[ti]/.rpmrc\f[R]. .TP \f[B]--pipe \f[R]\f[I]CMD\f[R] Перенаправляет вывод \f[B]rpm\f[R] на вход команды \f[I]CMD\f[R]. .TP \f[B]--dbpath \f[R]\f[I]DIRECTORY\f[R] Использовать базу данных RPM в каталоге \f[I]DIRECTORY\f[R] вместо пути по умолчанию \f[I]/var/lib/rpm\f[R] .TP \f[B]--root \f[R]\f[I]DIRECTORY\f[R] Использовать для всех операций файловую систему с корнем в \f[I]DIRECTORY\f[R]. Обратите внимание, что это значит, что база данных внутри \f[I]DIRECTORY\f[R] будет использоваться для проверки зависимостей, и все сценарии \f[B]%post\f[R] и \f[B]%prep\f[R] будут исполняться после chroot(2) в \f[I]DIRECTORY\f[R]. .SS ОПЦИИ УСТАНОВКИ И ОБНОВЛЕНИЯ .PP Общая форма команды установки rpm приведена ниже .PP \f[B]rpm\f[R] {\f[B]-i|--install\f[R]} [\f[B]опции-установки\f[R]] \f[I]PACKAGE_FILE ...\f[R] .PP Так выполняется установка нового пакета. .PP Общая форма команды обновления rpm приведена ниже .PP \f[B]rpm\f[R] {\f[B]-U|--upgrade\f[R]} [\f[B]опции-установки\f[R]] \f[I]PACKAGE_FILE ...\f[R] .PP Так выполняется установка или обновление уже установленного пакета до новой версии. Эта операция аналогична установке, при этом все другие версии удаляются после установки нового пакета. .PP \f[B]rpm\f[R] {\f[B]-F|--freshen\f[R]} [\f[B]опции-установки\f[R]] \f[I]PACKAGE_FILE ...\f[R] .PP Так выполняется обновление пакетов, но только если предыдущая версия уже установлена. Параметр \f[I]PACKAGE_FILE\f[R] может быть указан как адрес \f[B]ftp\f[R] или \f[B]http\f[R] URL, в таком случае пакет будет скачан перед установкой. См. \f[B]ОПЦИИ FTP/HTTP\f[R] для получения информации о работе \f[B]rpm\f[R] с поддержкой \f[B]ftp\f[R] или \f[B]http\f[R]. .TP \f[B]--aid\f[R] Добавляет при необходимости предложенные пакеты в набор транзакции. .TP \f[B]--allfiles\f[R] Устанавливает или обновляет все файлы с флагом missingok в пакете, независимо от их существования. .TP \f[B]--badreloc\f[R] Используется вместе с \f[B]--relocate\f[R], разрешает перемещение всех путей файлов, не только тех, для которых старые пути \f[I]OLDPATH\f[R] включены в заметки по перемещению (relocation hint) в бинарном пакете. .TP \f[B]--excludepath \f[R]\f[I]OLDPATH\f[R] Не устанавливать файлы названия, которых начинаются с \f[I]OLDPATH\f[R]. .TP \f[B]--excludedocs\f[R] Не устанавливать файлы помеченные как документация (включающие man страницы и документы texinfo). .TP \f[B]--force\f[R] Эквивалентно использованию \f[B]--replacepkgs\f[R], \f[B]--replacefiles\f[R] и \f[B]--oldpackage\f[R]. .TP \f[B]-h, --hash\f[R] Выводит 50 отметок при распаковке архива. Используется с \f[B]-v|--verbose\f[R] для удобства отображения. .TP \f[B]--ignoresize\f[R] Не проверять подключенные файловые системы на наличие необходимого места на диске перед установкой данного пакета. .TP \f[B]--ignorearch\f[R] Разрешить установку или обновление, даже если архитектуры бинарного пакета и узла не совпадают. .TP \f[B]--ignoreos\f[R] Разрешить установку или обновление, даже если операционные системы бинарного пакета и узла не совпадают. .TP \f[B]--includedocs\f[R] Устанавливать файлы с документацией. Это поведение задано по умолчанию. .TP \f[B]--justdb\f[R] Обновить только информацию в базе, но не файловые системы. .TP \f[B]--nodigest\f[R] Не проверять при чтении дайджест пакета или заголовка. .TP \f[B]--nosignature\f[R] Не проверять при чтении подпись пакета или заголовка. .TP \f[B]--nodeps\f[R] Не выполнять проверку зависимостей перед установкой или обновлением пакета. .TP \f[B]--nosuggest\f[R] Не предлагать пакет(ы) для разрешения отсутствующих зависимостей. .TP \f[B]--noorder\f[R] Не выполнять переупорядочивание пакетов для установки. Список пакетов обычно переупорядочивается для удовлетворения зависимостей. .TP \f[B]--noscripts\f[R] .TP \f[B]--nopre\f[R] .TP \f[B]--nopost\f[R] .TP \f[B]--nopreun\f[R] .TP \f[B]--nopostun\f[R] Не выполнять скриптлеты с указанным именем. Опция \f[B]--noscripts\f[R] эквивалентна .PP \f[B]--nopre\f[R] \f[B]--nopost\f[R] \f[B]--nopreun\f[R] \f[B]--nopostun\f[R] .PP и выключает исполнение соответствующих \f[B]%pre\f[R], \f[B]%post\f[R], \f[B]%preun\f[R] и \f[B]%postun\f[R] скриптлетов. .TP \f[B]--notriggers\f[R] .TP \f[B]--notriggerin\f[R] .TP \f[B]--notriggerun\f[R] .TP \f[B]--notriggerpostun\f[R] .PP Не выполнять ни какие триггерные скриптлеты с указанным именем. Опция \f[B]--notriggers\f[R] эквивалентна .PP \f[B]--notriggerin\f[R] \f[B]--notriggerun\f[R] \f[B]--notriggerpostun\f[R] .PP и выключает исполнение соответствующих \f[B]%triggerin\f[R], \f[B]%triggerun\f[R] и \f[B]%triggerpostun\f[R] скриптлетов. .TP \f[B]--oldpackage\f[R] Разрешает обновить или заменить новый пакет более старой версией. .TP \f[B]--percent\f[R] Вывести информацию в процентах по мере распаковки файлов из архива пакета. Она предназначена для упрощения вызова \f[B]rpm\f[R] из других утилит. .TP \f[B]--prefix \f[R]\f[I]NEWPATH\f[R] Для перемещаемых бинарных пакетов, преобразовать все пути файлов, которые начинаются с инсталляционного префикса в заметках по перемещению (relocation hint) на \f[I]NEWPATH\f[R]. .TP \f[B]--relocate \f[R]\f[I]OLDPATH\f[R]\f[B]=\f[R]\f[I]NEWPATH\f[R] Для перемещаемых бинарных пакетов, преобразовать все пути файлов, которые начинаются с \f[I]OLDPATH\f[R] в заметках по перемещению (relocation hint) на \f[I]NEWPATH\f[R]. Данная опция может быть использована несколько раз, если требуется переместить несколько путей \f[I]OLDPATH\f[R] в пакете. .TP \f[B]--replacefiles\f[R] Установить пакеты, даже если они заменяют файлы от других установленных пакетов. .TP \f[B]--replacepkgs\f[R] Установить пакеты, даже если они уже установлены в системе. .TP \f[B]--test\f[R] Не устанавливать пакеты, просто выполнить проверку и сообщить о потенциальных конфликтах. .SS ОПЦИИ УДАЛЕНИЯ .PP Общая форма команды удаления rpm приведена ниже .PP \f[B]rpm\f[R] {\f[B]-e|--erase\f[R]} [\f[B]--allmatches\f[R]] [\f[B]--nodeps\f[R]] [\f[B]--noscripts\f[R]] [\f[B]--notriggers\f[R]] [\f[B]--test\f[R]] \f[I]PACKAGE_NAME ...\f[R] .PP Следующие опции могут быть также использованы: .TP \f[B]--allmatches\f[R] Удалить все версии пакета совпадающие с \f[I]PACKAGE_NAME\f[R]. Обычно при наличии нескольких пакетов совпадающих с \f[I]PACKAGE_NAME\f[R] возникает ошибка. .TP \f[B]--nodeps\f[R] Не проверять зависимости перед удалением пакетов. .TP \f[B]--noscripts\f[R] .TP \f[B]--nopreun\f[R] .TP \f[B]--nopostun\f[R] Не выполнять скриптлеты с указанными именами. Наличие параметра \f[B]--noscripts\f[R] при удалении пакетов эквивалентно .PP \f[B]--nopreun\f[R] \f[B]--nopostun\f[R] .PP и выключает исполнение соответствующих скриптлетов \f[B]%preun\f[R] и \f[B]%postun\f[R]. .TP \f[B]--notriggers\f[R] .TP \f[B]--notriggerun\f[R] .TP \f[B]--notriggerpostun\f[R] Не выполнять ни какие триггерные скриптлеты с указанным именем. Опция \f[B]--notriggers\f[R] эквивалентна .PP \f[B]--notriggerun\f[R] \f[B]--notriggerpostun\f[R] .PP и выключает исполнение соответствующих \f[B]%triggerun\f[R] и \f[B]%triggerpostun\f[R] скриптлетов. .TP \f[B]--test\f[R] Не удалять пакеты, просто выполнить проверку. Удобно использовать этот параметр при отладке совместно с опцией \f[B]-vv\f[R]. .SS ОПЦИИ ЗАПРОСА .PP Общая форма команды запроса rpm приведена ниже .PP \f[B]rpm\f[R] {\f[B]-q|--query\f[R]} [\f[B]select-options\f[R]] [\f[B]query-options\f[R]] .PP Существует возможность задать формат вывода информации о пакете. Для этого необходимо использовать параметр .PP \f[B]--qf|--queryformat\f[R] \f[I]QUERYFMT\f[R] .PP вслед за которым указывается строка формата \f[I]QUERYFMT\f[R]. Форматирование запроса - это измененная версия стандартного механизма \f[B]printf(3)\f[R]. Форматирование формируется из статических строк (которые могут включать стандартные для языка C escape-последовательности для перевода строки, табуляции и других спец. символов) и меток форматирования \f[B]printf(3)\f[R]. Т.к. \f[B]rpm\f[R] заранее знает тип выводимой информации, указатель формата может быть опущен и заменен на имя выводимого тега заголовка, заключенного в фигурные скобки \f[B]{}\f[R]. Имена тегов не чувствительны к регистру и префикс \f[B]RPMTAG_\f[R] в имени тега можно опускать. .PP Альтернативные форматы вывода могут быть заданы при помощи задания типа вывода \f[B]:\f[R]\f[I]typetag\f[R] после имени тега. В данный момент поддерживаются следующие типы: .TP \f[B]:armor\f[R] Упаковать публичный ключ в ASCII вид. .TP \f[B]:base64\f[R] Закодировать двоичные данные в формат base64. .TP \f[B]:date\f[R] Использовать формат strftime(3) \[dq]%c\[dq]. .TP \f[B]:day\f[R] Использовать формат strftime(3) \[dq]%a %b %d %Y\[dq]. .TP \f[B]:depflags\f[R] Форматировать флаги зависимостей. .TP \f[B]:fflags\f[R] Форматировать флаги файлов. .TP \f[B]:hex\f[R] В шестнадцатеричном виде. .TP \f[B]:octal\f[R] В восьмеричном виде. .TP \f[B]:perms\f[R] Форматировать права доступа файлов. .TP \f[B]:shescape\f[R] Экранировать одиночные кавычки для применения в сценариях. .TP \f[B]:triggertype\f[R] Вывести суффикс триггера. .PP Например, для вывода только имени пакета при запросе, вы можете использовать строку формата \f[B]%{NAME}\f[R]. Для вывода имени пакетов и информации о дистрибутиве в две колонки вы можете использовать \f[B]%-30{NAME}%{DISTRIBUTION}\f[R]. Команда \f[B]rpm\f[R] отобразит спиков всех тегов, с которыми она может работать при ее вызове с параметром \f[B]--querytags\f[R]. .PP Существуют два набора параметров для выполнения запросов: для выбора пакетов и для указания информации. .SS ОПЦИИ ВЫБОРА ПАКЕТОВ: .TP \f[I]PACKAGE_NAME\f[R] Выполняет запрос к установленному пакету с именем \f[I]PACKAGE_NAME\f[R]. .TP \f[B]-a, --all\f[R] Выполняет запрос ко всем установленным пакетам. .TP \f[B]-f, --file \f[R]\f[I]FILE\f[R] Выполняет запрос к пакету, владельцу файла \f[I]FILE\f[R]. .TP \f[B]-g, --group \f[R]\f[I]GROUP\f[R] Выполняет запрос к пакету с группой \f[I]GROUP\f[R]. .TP \f[B]--hdrid \f[R]\f[I]SHA1\f[R] Выполняет запрос к пакету, содержащему указанный идентификатор заголовка, т.е. \f[I]SHA1\f[R] дайджест неизменной части заголовка. .TP \f[B]-p, --package \f[R]\f[I]PACKAGE_FILE\f[R] Выполняет запрос к (неустановленному) пакету в файле \f[I]PACKAGE_FILE\f[R]. Параметр \f[I]PACKAGE_FILE\f[R] может быть указан в виде адреса \f[B]ftp\f[R] или \f[B]http\f[R] URL, в результате чего заголовок пакета будет скачан и опрошен. Обратитесь к \f[B]ОПЦИЯМ FTP/HTTP\f[R] за информацией о поддержке в \f[B]rpm\f[R] работы с \f[B]ftp\f[R] и \f[B]http\f[R]. Если аргумент(ы) \f[I]PACKAGE_FILE\f[R] не является бинарным пакетом, то он будет интерпретирован как ASCII манифест пакета. В нем разрешено применение комментариев начинающихся с \[aq]#\[aq], каждая из строк файла манифеста пакета может включать разделенные запятыми glob выражения, включая адреса URL с внешними glob выражениями, они будут развернуты в пути, которые будут подставлены вместо манифеста пакета как дополнительный аргумент \f[I]PACKAGE_FILE\f[R] в запросе. .TP \f[B]--pkgid \f[R]\f[I]MD5\f[R] Выполняет запрос к пакету, который содержит указанный идентификатор пакета, т.е. \f[I]MD5\f[R] дайджест объединенного содержимого заголовка и тела пакета. .TP \f[B]--querybynumber \f[R]\f[I]HDRNUM\f[R] Выполняет запрос напрямую \f[I]HDRNUM\f[R]\[aq]ой записи в базе данных; используется только для отладки. .TP \f[B]--specfile \f[R]\f[I]SPECFILE\f[R] Обработать и выполнить запрос к \f[I]SPECFILE\f[R] файлу, как если бы это был пакет. Хотя не вся информация доступна (например, список файлов), этот тип запросов позволяет использовать rpm для извлечения информации из spec файлов без написания специализированного анализатора таких файлов. .TP \f[B]--tid \f[R]\f[I]TID\f[R] Выполняет запрос к пакету(ам), который содержит указанный идентификатор транзакции \f[I]TID\f[R]. В данный момент используется временная метка unix в качестве идентификатора. Все пакеты установленные или удаленные в составе одной транзакции будут иметь один и тот же идентификатор. .TP \f[B]--triggeredby \f[R]\f[I]PACKAGE_NAME\f[R] Выполняет запрос к пакетам, которые вызывают срабатывание триггера пакета(ов) \f[I]PACKAGE_NAME\f[R]. .TP \f[B]--whatprovides \f[R]\f[I]CAPABILITY\f[R] Выполняет запрос ко всем пакетам, которые предоставляют функциональность \f[I]CAPABILITY\f[R]. .TP \f[B]--whatrequires \f[R]\f[I]CAPABILITY\f[R] Выполняет запрос ко всем пакетам, которые требуют \f[I]CAPABILITY\f[R] для корректной работы. .SS ОПЦИИ ЗАПРОСА ПАКЕТОВ: .TP \f[B]--changelog\f[R] Вывести информацию об изменениях в пакете. .TP \f[B]-c, --configfiles\f[R] Вывести только конфигурационные файлы (подразумевает \f[B]-l\f[R]). .TP \f[B]-d, --docfiles\f[R] Вывести только файлы документации (подразумевает \f[B]-l\f[R]). .TP \f[B]--dump\f[R] Распечатать информацию о файле в виде: .RS .IP .nf \f[C] path size mtime md5sum mode owner group isconfig isdoc rdev symlink \f[R] .fi .RE .PP Эта опция должна быть использована совместно с одной из \f[B]-l\f[R], \f[B]-c\f[R], \f[B]-d\f[R]. .TP \f[B]--filesbypkg\f[R] Вывести все файлы во всех выбранных пакетах. .TP \f[B]-i, --info\f[R] Вывести информацию о пакете, включая имя, версию и описание. Будет использована \f[B]--queryformat\f[R] если указана. .TP \f[B]--last\f[R] Упорядочивает вывод пакетов по времени установки так, чтобы последние пакеты были выведены в начале. .TP \f[B]-l, --list\f[R] Вывести список файлов в пакете. .TP \f[B]--provides\f[R] Вывести функциональность (capabilities) предоставляемую пакетом. .TP \f[B]-R, --requires\f[R] Вывести пакеты, от которых зависит этот пакет. .TP \f[B]--scripts\f[R] Вывести скриптлет(ы) пакета, которые используются как часть процесса установки или удаления пакетов. .TP \f[B]-s, --state\f[R] Вывести состояние (\f[I]state\f[R]) файлов в пакете (подразумевается \f[B]-l\f[R]). Состояние каждого файла в пакете является одним из \f[I]нормальное (normal)\f[R], \f[I]не установлен (not installed)\f[R] или \f[I]заменен (replaced)\f[R]. .TP \f[B]--triggers, --triggerscripts\f[R] Показать сценарии триггеров (если существуют), входящие в состав пакета. .SS ОПЦИИ ПРОВЕРКИ .PP Общая форма команды проверки rpm приведена ниже .PP \f[B]rpm\f[R] {\f[B]-V|--verify\f[R]} [\f[B]опции-выбора\f[R]] [\f[B]опции-проверки\f[R]] .PP Операция проверки пакета сравнивает информацию о файлах установленных из пакета с информацией о них из метаданных пакета, хранимых в базе данных rpm. Среди прочего при проверке сравниваются размер, MD5 сумма, права доступа тип, владельца и группу каждого файла. Любые расхождения будут отображены. Файлы, которые не были установлены вместе с пакетом, например, файлы документации, исключенные при помощи опции \[dq]\f[B]--excludedocs\f[R]\[dq], будут проигнорированы без предупреждения. .PP Опции выбора пакетов являются аналогичными запросу пакетов (включая файлы манифеста пакета в качестве аргумента). Опции, уникальные для режима проверки, приведены ниже: .TP \f[B]--nodeps\f[R] Не выполнять проверку зависимостей пакетов. .TP \f[B]--nodigest\f[R] Не проверять при чтении дайджест пакета или заголовка. .TP \f[B]--nofiles\f[R] Не проверять атрибуты файлов пакетов. .TP \f[B]--noscripts\f[R] Не выполнять скриптлет \f[B]%verifyscript\f[R] (если существует). .TP \f[B]--nosignature\f[R] Не проверять при чтении подпись пакета или заголовка при чтении. .TP \f[B]--nolinkto\f[R] .TP \f[B]--nomd5\f[R] .TP \f[B]--nosize\f[R] .TP \f[B]--nouser\f[R] .TP \f[B]--nogroup\f[R] .TP \f[B]--nomtime\f[R] .TP \f[B]--nomode\f[R] .TP \f[B]--nordev\f[R] Не проверять соответствующие атрибуты файлов. .PP Формат вывода представляет собой строку из 9 символов и маркера из заголовка пакета, за которыми следует имя файла. Возможные маркеры атрибутов приведены ниже: .IP .nf \f[C] c %config конфигурационный файл. d %doc файл документации. g %ghost файл (т.е. содержимое файла не включено в состав пакета). l %license файл с лицензией. r %readme файл readme. \f[R] .fi .PP Каждый из 9 символов отражает результат проверки атрибута(ов) файлов с значением того же атрибута, записанного в базе данных. Символ \[dq]\f[B].\f[R]\[dq] (точка) означает, что проверка прошла, а символ \[dq]\f[B]?\f[R]\[dq] (вопросительный знак) означает, что проверка не может быть выполнена (например, права доступа к файлу не позволяют провести чтение). В противном случае будут отображены символы (для привлечения внимания выделены жирным), показывающие сбой проверки соответствующего \f[B]--verify\f[R] теста: .IP .nf \f[C] S размер (Size) файла отличается M режим (Mode) доступа отличается (включая права доступа и тип файла) 5 отличается контрольная MD5 сумма D отличается старший/младший номер файла устройства (Device) L отличается путь ссылки при readLink(2) U отличается владелец (User) G отличается групповое владение (Group) T отличается время изменения (mTime) \f[R] .fi .SS ПРОВЕРКА ЦИФРОВОЙ ПОДПИСИ И ДАЙДЖЕСТА .PP Общая форма команд rpm по работе с цифровой подписью приведена ниже .PP \f[B]rpm\f[R] \f[B]--import\f[R] \f[I]PUBKEY ...\f[R] .PP \f[B]rpm\f[R] {\f[B]--checksig\f[R]} [\f[B]--nosignature\f[R]] [\f[B]--nodigest\f[R]] \f[I]PACKAGE_FILE ...\f[R] .PP Опция \f[B]--checksig\f[R] проверяет все дайджесты и подписи, содержащиеся в \f[I]PACKAGE_FILE\f[R] для проверки целостности и происхождения пакета. Обратите внимание, что подписи теперь проверяются при каждом чтении пакета и опция \f[B]--checksig\f[R] полезна для проверки всех дайджестов и подписей, ассоциированных с пакетом. .PP Цифровые подписи не могут быть проверены без публичных ключей. Публичный ключ в ASCII формате может быть добавлен в базу данных \f[B]rpm\f[R] при использовании команды \f[B]--import\f[R]. Импортированный публичный ключ заносится в заголовок и управление ключами проводится аналогично управлению пакетами. Например, все импортированные ключи можно просмотреть при помощи: .PP \f[B]rpm -qa gpg-pubkey*\f[R] .PP Подробная информация о конкретном публичном ключе после импорта может быть отображена при запросе. Информация о ключе Red Hat GPG/DSA: .PP \f[B]rpm -qi gpg-pubkey-db42a60e\f[R] .PP Наконец, публичный ключ может быть удален после его импорта также как пакет. Удаление ключа Red Hat GPG/DSA: .PP \f[B]rpm -e gpg-pubkey-db42a60e\f[R] .SS ПОДПИСЬ ПАКЕТА .PP \f[B]rpm\f[R] \f[B]--addsign|--resign\f[R] \f[I]PACKAGE_FILE ...\f[R] .PP Обе опции \f[B]--addsign\f[R] и \f[B]--resign\f[R] создают и вставляют новую подпись для каждого указанного файла \f[I]PACKAGE_FILE\f[R], заменяя существующие подписи. Эти две опции существуют по историческим причинам, и разницы в поведении между ними сейчас нет. .SS ИСПОЛЬЗОВАНИЕ GPG ДЛЯ ПОДПИСИ ПАКЕТОВ .PP Для того, чтобы подписывать пакеты при помощи GPG, \f[B]rpm\f[R] должен быть настроен на запуск GPG и иметь возможность находить хранилище ключей с требуемыми ключами. По умолчанию \f[B]rpm\f[R] использует те же соглашения, что и GPG для обнаружения хранилища ключей, а именно переменную среды \f[B]$GNUPGHOME\f[R]. Если ваше хранилище ключей располагается не там, где его ожидает найти GPG, вам потребуется определить в макросе \f[B]%_gpg_path\f[R] расположение хранилища ключей GPG. .PP Для совместимости со старыми версиями GPG, PGP и rpm следует настраивать только подпись пакетов V3 OpenPGP. Могут быть использованы алгоритмы проверки DSA и RSA, хотя предпочитается DSA. .PP Если вам требуется подписывать собственные пакеты, вам также потребуется создать собственную пару из публичного и приватного ключа (см. руководство по GPG). Вам также потребуется настроить \f[B]rpm\f[R] макрос .TP \f[B]%_gpg_name\f[R] Имя пользователя, ключом которого будут подписываться ваши пакеты. .PP Например, для использования GPG для подписи пакетов от имени \f[I]\[dq]John Doe \[dq]\f[R] из хранилища ключей расположенного в \f[I]/etc/rpm/.gpg\f[R], используя программу \f[I]/usr/bin/gpg\f[R], вам потребуется включить строки .IP .nf \f[C] %_gpg_path /etc/rpm/.gpg %_gpg_name John Doe %_gpgbin /usr/bin/gpg \f[R] .fi .PP в файл настройки макросов. Для общесистемной настройки используется \f[I]/etc/rpm/macros\f[R] и \f[I]\[ti]/.rpmmacros\f[R] для конкретного пользователя. .SS ОПЦИИ ПЕРЕСТРОЙКИ БАЗЫ ДАННЫХ .PP Общая форма команды перестройки базы данных rpm приведена ниже .PP \f[B]rpm\f[R] {\f[B]--initdb|--rebuilddb\f[R]} [\f[B]-v\f[R]] [\f[B]--dbpath \f[R]\f[I]DIRECTORY\f[R]] [\f[B]--root \f[R]\f[I]DIRECTORY\f[R]] .PP Используйте \f[B]--initdb\f[R] для создания новой базы данных и \f[B]--rebuilddb\f[R] для перестройки индексов базы данных на основании заголовков установленных пакетов. .SS SHOWRC .PP Команда .PP \f[B]rpm\f[R] \f[B]--showrc\f[R] .PP показывает значения, которые \f[B]rpm\f[R] будет использовать для всех опций, установленные в конфигурационных файлах \f[I]rpmrc\f[R] и \f[I]macros\f[R]. .SS ОПЦИИ FTP/HTTP .PP \f[B]rpm\f[R] может выступать в качестве клиента FTP и/или HTTP, таким образом пакеты могут быть опрошены или установлены из Интернет. Пакеты для операций установки, обновления или запроса могут быть указаны в виде адреса \f[B]ftp\f[R] или \f[B]http\f[R] URL: .PP ftp://USER:PASSWORD\[at]HOST:PORT/path/to/package.rpm .PP Если параметр \f[B]:PASSWORD\f[R] будет опущен, пароль будет запрошен (один раз для пары пользователь/узел). Если опущены оба параметра (user и password), будет выполнено анонимное подключение \f[B]ftp\f[R]. Во всех случаях используется пассивный (PASV) режим передачи файлов \f[B]ftp\f[R]. .PP \f[B]rpm\f[R] допускает следующие опции для адресов ftp URL: .TP \f[B]--ftpproxy \f[R]\f[I]HOST\f[R] Узел \f[I]HOST\f[R] будет использован как прокси-сервер для всех операций передачи данных ftp, что позволяет работать с ftp через межсетевые экраны, на которых запущена служба прокси. Эта опция может быть также указана при настройке макроса \f[B]%_ftpproxy\f[R]. .TP \f[B]--ftpport \f[R]\f[I]PORT\f[R] Номер TCP порта \f[I]PORT\f[R] будет использован для ftp подключения к ftp прокси-серверу вместо порта по умолчанию. Эта опция может быть также указана при настройке макроса \f[B]%_ftpport\f[R]. .PP \f[B]rpm\f[R] допускает следующие опции для адресов \f[B]http\f[R] URL: .TP \f[B]--httpproxy \f[R]\f[I]HOST\f[R] Узел \f[I]HOST\f[R] будет использован как прокси-сервер для всех операций передачи данных \f[B]http\f[R]. Эта опция может быть также указана при настройке макроса \f[B]%_httpproxy\f[R]. .TP \f[B]--httpport \f[R]\f[I]PORT\f[R] Номер TCP порта \f[I]PORT\f[R] будет использован для \f[B]http\f[R] подключения к http прокси-серверу вместо порта по умолчанию. Эта опция может быть также указана при настройке макроса \f[B]%_httpport\f[R]. .SH ВОПРОСЫ СОВМЕСТИМОСТИ .SS Выполнение rpmbuild .PP Режимы сборки rpm теперь вынесены в программу \f[I]/usr/bin/rpmbuild\f[R]. Не смотря на это, совместимость, обеспечиваемая при помощи popt псевдонимов, указанных ниже, является адекватной, но не совершенной. Поэтому совместимость режимов сборки через псевдонимы popt удалена из rpm. Установите пакет \f[B]rpmbuild\f[R] и просмотрите документацию в \f[B]rpmbuild\f[R](8) по всем режимам сборки \f[B]rpm\f[R], ранее приведенную здесь в \f[B]rpm\f[R](8). .PP Добавьте следующие строки в \f[I]/etc/popt\f[R], если вы желаете вызывать \f[B]rpmbuild\f[R] из командной строки \f[B]rpm\f[R]: .IP .nf \f[C] rpm exec --bp rpmb -bp rpm exec --bc rpmb -bc rpm exec --bi rpmb -bi rpm exec --bl rpmb -bl rpm exec --ba rpmb -ba rpm exec --bb rpmb -bb rpm exec --bs rpmb -bs rpm exec --tp rpmb -tp rpm exec --tc rpmb -tc rpm exec --ti rpmb -ti rpm exec --tl rpmb -tl rpm exec --ta rpmb -ta rpm exec --tb rpmb -tb rpm exec --ts rpmb -ts rpm exec --rebuild rpmb --rebuild rpm exec --recompile rpmb --recompile rpm exec --clean rpmb --clean rpm exec --rmsource rpmb --rmsource rpm exec --rmspec rpmb --rmspec rpm exec --target rpmb --target rpm exec --short-circuit rpmb --short-circuit \f[R] .fi .SH ФАЙЛЫ .SS Конфигурация rpmrc .IP .nf \f[C] /usr/lib/rpm/rpmrc /usr/lib/rpm//rpmrc /etc/rpmrc \[ti]/.rpmrc \f[R] .fi .SS Конфигурация макросов .IP .nf \f[C] /usr/lib/rpm/macros /usr/lib/rpm//macros /etc/rpm/macros \[ti]/.rpmmacros \f[R] .fi .SS База данных .IP .nf \f[C] /var/lib/rpm/Basenames /var/lib/rpm/Conflictname /var/lib/rpm/Dirnames /var/lib/rpm/Filemd5s /var/lib/rpm/Group /var/lib/rpm/Installtid /var/lib/rpm/Name /var/lib/rpm/Packages /var/lib/rpm/Providename /var/lib/rpm/Provideversion /var/lib/rpm/Pubkeys /var/lib/rpm/Removed /var/lib/rpm/Requirename /var/lib/rpm/Requireversion /var/lib/rpm/Sha1header /var/lib/rpm/Sigmd5 /var/lib/rpm/Triggername \f[R] .fi .SS Временные файлы .PP \f[I]/var/tmp/rpm*\f[R] .SH СМОТРИ ТАКЖЕ .IP .nf \f[C] popt(3), rpm2cpio(8), rpmbuild(8), \f[R] .fi .PP \f[B]http://www.rpm.org/ \f[R] .SH АВТОРЫ .IP .nf \f[C] Marc Ewing Jeff Johnson Erik Troan \f[R] .fi .SH ПЕРЕВОД .IP .nf \f[C] Андрей Мартынов \f[R] .fi