Filesystem coherency and conflicts
Материал из ALT Linux Wiki
Строка 1: | Строка 1: | ||
{{DraftPolicy | {{DraftPolicy | ||
|responsible=Igor Vlasenko | |responsible=Igor Vlasenko | ||
+ | |metabug=repocop тесты rpm-filesystem-conflict-* | ||
}} | }} | ||
Строка 7: | Строка 8: | ||
=== Предварительные сведения === | === Предварительные сведения === | ||
- | + | При установке пакетов rpm может неожиданно обнаружить, что содержимое устанавливаемых пакетов конфликтует | |
+ | между собой. Это особенно неприятно при dist-upgrade транзакциях на сотни и тысячи пакетов. | ||
+ | Поэтому необходимо, чтобы пакеты заранее предупеждали rpm и apt о своих конфликтах. | ||
+ | Кроме того, некоторые конфликты являются особо патологическими и легко вводящими rpm в заблуждение. | ||
+ | Наличие таких конфликтов свидетельствует о проблемах в упаковке пакета. | ||
=== Требования к целостности файловой системы === | === Требования к целостности файловой системы === | ||
- | + | * Пакетам запрещается содержать путь в файловой системе, часть которого является альтернативой. | |
- | + | ||
+ | Обоснование: изменение альтернативы спрячет файлы от rpm. Установка пакета блокирует создание альтернативы. | ||
+ | |||
+ | * Пакетам запрещается содержать файлы, которые в другом пакете являются каталогами. | ||
+ | |||
+ | * Пакетам запрещается содержать путь в файловой системе, часть которого является симлинком в другом пакете. | ||
+ | При обнаружении такого рода конфликтов (см. [http://lists.altlinux.org/pipermail/devel/2008-December/164768.html devel]) | ||
+ | пакет необходимо переупаковать. | ||
+ | |||
+ | Обоснование: будет блокирована установка пакета с симлинком; изменение симлинка спрячет файлы от rpm. | ||
=== Требования к разрешению конфликтов === | === Требования к разрешению конфликтов === | ||
- | + | * Пакетам запрещается иметь неявные конфликты в файловой системе друг с другом. | |
+ | |||
Рекомендуется переделывать пакеты так, чтобы убрать неявные конфликты в файловой системе, | Рекомендуется переделывать пакеты так, чтобы убрать неявные конфликты в файловой системе, | ||
используя переименование, выделение общих ресурсов в подпакет <code>-common</code> или альтернативы. | используя переименование, выделение общих ресурсов в подпакет <code>-common</code> или альтернативы. | ||
Пакеты, у которых не удается устранить неявные конфликты в файловой системе друг с другом, обязаны иметь | Пакеты, у которых не удается устранить неявные конфликты в файловой системе друг с другом, обязаны иметь | ||
явные конфликты друг на друга используя тег <code>Conflicts:</code>. | явные конфликты друг на друга используя тег <code>Conflicts:</code>. | ||
+ | |||
+ | * Если пакеты не имеют других конфликтов, кроме конфликтов по каталогам, то такие конфликты настоятельно рекомендуется устранять без использования <code>Conflicts:</code>, через переименование, выделение общих ресурсов в подпакет <code>-common</code> или альтернативы. |
Версия 19:33, 4 января 2009
Содержание |
Полиси по целостности файловой системы внутри RPM пакетов и указанию конфликтов.
Предварительные сведения
При установке пакетов rpm может неожиданно обнаружить, что содержимое устанавливаемых пакетов конфликтует между собой. Это особенно неприятно при dist-upgrade транзакциях на сотни и тысячи пакетов. Поэтому необходимо, чтобы пакеты заранее предупеждали rpm и apt о своих конфликтах. Кроме того, некоторые конфликты являются особо патологическими и легко вводящими rpm в заблуждение. Наличие таких конфликтов свидетельствует о проблемах в упаковке пакета.
Требования к целостности файловой системы
- Пакетам запрещается содержать путь в файловой системе, часть которого является альтернативой.
Обоснование: изменение альтернативы спрячет файлы от rpm. Установка пакета блокирует создание альтернативы.
- Пакетам запрещается содержать файлы, которые в другом пакете являются каталогами.
- Пакетам запрещается содержать путь в файловой системе, часть которого является симлинком в другом пакете.
При обнаружении такого рода конфликтов (см. devel) пакет необходимо переупаковать.
Обоснование: будет блокирована установка пакета с симлинком; изменение симлинка спрячет файлы от rpm.
Требования к разрешению конфликтов
- Пакетам запрещается иметь неявные конфликты в файловой системе друг с другом.
Рекомендуется переделывать пакеты так, чтобы убрать неявные конфликты в файловой системе,
используя переименование, выделение общих ресурсов в подпакет -common
или альтернативы.
Пакеты, у которых не удается устранить неявные конфликты в файловой системе друг с другом, обязаны иметь
явные конфликты друг на друга используя тег Conflicts:
.
- Если пакеты не имеют других конфликтов, кроме конфликтов по каталогам, то такие конфликты настоятельно рекомендуется устранять без использования
Conflicts:
, через переименование, выделение общих ресурсов в подпакет-common
или альтернативы.