Управление пакетами в (open)SUSE с помощью zypper
- 02.06.10, 16:28
написать документацию на zypper. Скорее это попытка познакомить
читателя со средством пакетного менеджмента, используемым в
дистрибутивах компании Novell. Данный пакетный менеджер является
незаслуженно игнорируемым многими. Естественно, что охватить все его
функции в рамках такой короткой статьи не представляется возможным, хотя
бы потому, что для этого есть исчерпывающая документация ;), с которой
трудно конкурировать. Ниже приведено вольное изложение об его основных и
часто используемых возможностях. Более полный вариант документации и
все возможные опции можно посмотреть в man zypper и здесь, здесь и здесь.
версиях SUSE как самое высокоуровневое средство используется Yast,
который на самом деле использует zypper (а если еще точнее, то его
библиотеку libzypp). Причем, обратите внимание на то, что вторая буква в
его названии это "Y", а то почему-то его название многие порываются
написать, как zipper. Zypper - средство для управления пакетами в
текстовом режиме. С SUSE версии 11 (включая энтерпрайзовые версии)
zypper существенно прибавил в скорости. По данному теперь он легко
уделывает yum (в отличие от yum zypper написан на С) и не уступает (по
субъективному ощущению) apt. Синтаксис его конфигурационных файлов
достаточно прост, например, чтобы управлять разными репозиториями не
нужно ломать голову в отношении их приоритетов (это камень в огород
apt). Также zypper достаточно «всеяден» в плане подключения разных
репозиториев - он понимает:
- «родной» формат репозиториев yast;
- репозитории yum (rpm repo-md);
- iso-образы репозиториев (да-да, не нужно их распаковывать!) ;
- локальный каталог с rpm-пакетами;
- то, что писать уже практически не обязательно - разные сетевые
источники репозиториев — http, ftp, nfs.
Oб остальных интересностях я расскажу по ходу дела.
наконец-то была добавлена опция, которая давно в него просилась, а
именно, опции предварительного выкачивания пакетов при обновлении. Ранее
zypper работал так. Например, нужно обновить с десяток пакетов. Zypper
выкачивал их все и устанавливал по одному. В принципе, ничего страшного.
Если канал в сеть хороший и надежный. А это в наших широтах не всегда
встречается. В основном конфигурационном файле /etc/zypp/zypp.conf
данное поведение описывается опцией commit.download.mode (опция
закоментирована по умолчанию), которая имеет следующие варианты:
- DownloadOnly — опция,
которая легко заменяется ключом --dry-run, т. е. выкачивание всех
пакетов необходимых для обновления без их установки. - DownloadInAdvance — сначала выкачать все пакеты, требующие
обновления, затем начать процесс их установки. - DownloadInHeaps — опция аналогичная представленной выше, но в
данном случае закачка и установка пакетов выполняется «порциями», не
нарушающими целостность системы. Примерно также ведет себя пакетный
менеджер в Mandriva. - DownloadAsNeeded — традиционное поведение. Закачка и
установка осуществляется по одному пакету.
zypper является сокращенный вариант его опций, т. е. для установки
пакета можно написать zypper install foopackage, а можно zypper in
foopackage. Далее я буду приводить именно сокращенный вариант опций, а
полный вариант писать в скобках.
пакет в подключенных репозиториях используется следующая команда:
поиск (se - search) пакета foopackage.
программу, но не знаете в каком пакете ее искать, можно сделать так:
openSUSE-11.2-Oss
package | 7.2-16.7 | i586 | openSUSE-11.2-Oss
openSUSE-11.2-Oss
позволяет искать пакет по любому возможному параметру: имя исполняемого
файла, путь до исполняемого файла, любой набор символов из описания
пакета. В данном случае я попросил найти пакет, содержащий редактор vi.
Еще примеры:
у нас находится библиотека libpng:
zypper wp libpng
data...
packages...
| Version | Arch | Repository
| 1.2.39-2.2 | x86_64 | openSUSE-11.2-Oss
openSUSE-11.2-Oss
находится файл /bin/bash?
4.0-18.4.1 | x86_64 | Updates for openSUSE 11.2-0
openSUSE 11.2-0
4.0-18.3 | x86_64 | openSUSE-11.2-Oss
openSUSE-11.2-Oss
пакета, где i означает - установлен.
можно командой zypper info <имя пакета>
репозиториев выполняется командой:
установит пакет foopackage со всеми его зависимостями.
опция rm/remove:
foopackage из вашей системы.
на предмет удовлетворения зависимостей существует команда verify:
zypper предложит доустановить нехватающие пакеты (или даже удалить
ненужные).
не являются обязательными, но могут здорово помочь, если вы вызываете
zypper из скриптов. Первый ключ «-y» заставляет пакетный менеджер
отвечать на все вопрос «да»/«yes». Второй ключ «-l» (маленькая L) -
имеет похожее значение, она заставляет zypper соглашаться с
лицензионными соглашениями отдельных пакетов (например, таких как Adobe
Flash).
zypper позволяет двумя способами — на основе патчей и на основе пакетов.
Первый способ рекомендуется для серверов. В данном случае производится
только наложение патчей, исправляющих ошибки безопасности на
установленное ПО, причем этот способ обновлений должен поддерживаться
теми, кто ведет репозиторий, из которого вы обновляетесь. Стандартные
репозитории openSUSE поддерживают данный способ. Второй способ выполняет
установку новых пакетов в систему. Понятно, что в данном случае все
определяется способом ведения репозитория майнтейнерами пакетов.
Стандартные репозитории openSUSE «замораживают» номера версий ПО, так
что в принципе эти два способа равноценны (но только для них). Это все
была теория. Теперь немного практики.
Обновить метаданные репозитория можно командой zypper ref и это
необходимо делать всякий раз перед выполнением обновления (либо включить
autorefresh для всех репозиториев - см.ниже).
патчей (list-patches) можно командой:
конкретном патче можно командой (про опцию -t ниже):
zypper patch .
пакетов выполняется командой:
выполняет обновление либо указанного пакета, либо всей системы.
для обновления системы между релизами (dist-upgrade):
интересных эффектов. Как известно все пакеты rpm имеют поле Vendor, в
котором указан сборщик пакета. Пакеты из стандартных репозиториев имеют в
данном поле openSUSE (или просто SUSE для энтерпрайзовых версий).
Пакеты собранные на openSUSE Build Service имеют в данном поле слово obs
с указанием вида репозитория. Так вот команда zypper up выполняет
обновление таким образом, чтобы поле Vendor не менялось при обновлении.
zypper dup, наоборот, может предпочесть изменить вендора пакета при
обновлении.
касается тех, кто как я любит поэкспериментировать с системой. Допустим,
вы хотите поставить последнюю версию KDE, подключаете репозиторий (об
этом ниже) KDE4:Factory (данный репозиторий для разработчиков и
тестеров), выполняете zypper dup (при этом Vendor меняется с openSUSE на
что-то вроде obs://build.opensuse.org/KDE/KDE4:Factory) и получаете ее.
Но потом, вы обнаруживаете, что в ней еще куча ошибок и вы хотели бы
вернуться обратно. Что же делать? Неужели ничего нельзя поправить?!!! А
ничего страшного! Убираете данный репозиторий (удаляете файл с его
описанием или просто выключаете его) и опять выполняете zypper dup. При
этом zypper вам предложит выполнить downgrade всех обновленных ранее
пакетов. Т. е. zypper dup выполняет обновление системы таким образом,
чтобы она всегда соответствовала подключенным репозиториям.
Справедливости ради, стоит отметить, что downgrade не всегда проходит
гладко. Иногда, при неблагоприятном положении звезд и планет, в системе
остаются библиотеки от новых репозиториев, которые могут помешать работе
программ. Так что возможно, придется затем позаниматься таким
«увлекательным» занятием, как troubleshooting.
всеяден в плане возможных репозиториев. Посмотреть что же у вас
подключено в данный момент можно следующей командой:
zypper lr
В первой колонке приведен порядковый номер репозитория, во второй и
третьей его название и описание. Четвертая и пятая колонки показывают
включен ли данный репозиторий и включено ли его автообновление
(autorefresh). Если последняя возможность включена, то при каждом своем
запуске zypper будет проверять нужно ли обновление метаданных
репозитория и, если нужно, выполнять его. В противном случае, вам нужно
будет делать это собственноручно командой zypper ref (refresh).
командой: zypper ar URI alias ,
где - URI идентификатор репозитория. alias
- это любое понятное вам имя репозитория, позволяющее идентифицировать
его и отличить от других. ar — сокращенный вариант addrepo. Пример
команды:
nfs://192.168.0.254/srv/ftp/sles11 sles11
No
nfs://192.168.0.254/srv/ftp/sles11
командой zypper rr . Например:
указав его ID (то есть номер). Его можно увидеть в выводе команды zypper
lr . Аналогичного эффекта я бы добился, указав zypper rr sles11 .
То есть в данном случае указывать нужно или ID репозитория, или его
псевдоним.
репозитория выполняется командой: zypper mr [options] . Список опций
можно получить следующим образом:
<--all|--remote|--local|--medium-type>
alias, number, or URI, or by the
options.
don't remove it).
Enable a disabled repository.
--refresh Enable auto-refresh of the repository.
repository.
Set a descriptive name for the repository.
Enable RPM files caching.
--no-keep-packages Disable RPM files caching.
repositories.
Apply changes to all local repositories.
repositories.
Apply changes to repositories of specified type.
включит параметр autorefresh для все репозиториев:
автообновление для репозиториев (а -R выключит его), а опция -a говорит
применить это ко всем репозиториям.
приоритеты, которые могут дополнительно указывать zypper ваши
предпочтения (меньшее значение - больший приоритет). Работа с
приоритетами аналогична тому, что происходит в yum. Только здесь не
нужно ставить никаких дополнительных плагинов. Чтобы задать приоритет
репозиторию можно воспользоваться командой zypper mr, но на мой взгляд,
гораздо проще открыть файл .repo репозитория и дописать в нем, например,
такую строчку - priority=100. Стандартные репозитории openSUSE имеют
приоритет 90, а репозиторий Updates приоритет 20. Имейте это в виду,
когда будете задавать собственные приоритеты. После изменения
приоритетов репозиториев обязательно необходимо запустить, сначала
zypper ref (если не включен autorefresh для репозиториев), а затем
zypper dup, для того, чтобы zypper установил пакеты в соответствии с
высказанными вами предпочтениями.
управления репозиториями использовать соответствующий модуль yast:
Yast могут воспользоваться либо его графическим меню, либо набрав в
консоли:
подключения репозиториев - это скачать файл с его описанием отсюда. В каждом
из репозиториев есть текстовый .repo файл, например, для репозитория со
свежими версиями Apache он лежит здесь.
Затем нужно поместить его в каталог /etc/zypp/repos.d/. Ну и
подредактировать на предмет приоритетов, если это нужно.
zypper в том, что он позволяет использовать разные типы «пакетов» при
установке. В данном случае под «пакетами» понимаются:
- собственно, пакеты (и если ничего не указывать специально, то
имеются в виду именно они); - патчи (patch) (репозитории могут содержать просто патчи, а не
пакеты с обновлениями); - шаблоны (pattern) - группы пакетов, устанавливающие ту или иную
функциональность; - продукты (product) - совсем редко встречающийся зверь - это группы
пакетов для работы того или иного продукта; - пакет с исходниками (srcpackage) - это обычный src.rpm.
Тип пакета указывается опцией -t . Например, получить список доступных
шаблонов можно командой zypper patterns. И поставить тот, что нужен,
командой:
устанавливаемого пакета, то есть мы указываем, что имеем в виду именно
шаблон. x11 - имя устанавливаемого шаблона. Самое плохое при
использовании шаблонов это то, что удалять пакеты шаблонами zypper пока
не умеет.
рассказать про zypper на данном этапе. Я не ставил целью написать полный
обзор данного пакетного менеджера, но надеюсь, что после этого хотя бы
кто-то прочтет его полную документацию ;
http://tux-the-penguin.blogspot.com/2010/05/opensuse-zypper.html
Коментарі
анонім
13.06.10, 08:27
Круто, спасибо!
)
Только вот остался вопрос - понимает ли он deb-пакеты? (ну так, для полного комплекта
UseNix
23.06.10, 21:59Відповідь на 1 від анонім
из deb в тарбол , а там уже все проще , конечно alien рулит но на сюсе его нет вроде , на самом деле недавно начал разбираться , потому любому комменту в помощь буду рад
UseNix
33.06.10, 22:03Відповідь на 2 від UseNix
параллельно еще ковыряю OpenBSD хочу окончательно с убунтой попрощаться , хотя как это сделать на нетбуке еще вопрос , от сюси тоже есть предложение для нетбуков но тоже еще руки не дошли , 3 часа назад сново установил опен но только уже не на виртуалку , не спрашивайте сколько у меня железа )))