Buildiso с пакетами AUR: Использование buildpkg
Views
Actions
Namespaces
Variants
Tools
Это руководство посвящено созданию собственного онлайн-репозитория и сборке пользовательского пакета (набора) с помощью buildpkg. Позже вы сможете установить эти пакеты в ваш настроенный Manjaro ISO с помощью buildiso.
Прежде чем приступить к этому руководству - убедитесь что Вы выполнили предварительные шаги в Сборка Manjaro ISO с помощью buildiso.
Этот же профиль XFCE ISO будет использоваться в качестве примера на этой странице Wiki.
Инструменты для установки
Синхронизируйте вашу систему с последними пакетами и убедитесь что у вас установлены следующие пакеты.
- git
- manjaro-tools-{base|base-git}
- manjaro-tools-{pkg|pkg-git}
Важно, чтобы ваши пакеты инструментов соответствовали друг другу - не смешивайте пакеты по умолчанию и git.
Создание каталогов
Первое, что вы должны сделать - это создать каталог для вашего онлайн-репозитория. Онлайн-репозиторий называется online-repo в этом руководстве и находится в Вашем домашнем каталоге. Однако, Вы можете выбрать название по своему вкусу. Это поможет сохранить порядок. Ваше хранилище состоит только из этого каталога:
Это онлайн хранилище создается в Вашем домашнем каталоге, но Вы можете создать его в любом удобном для Вас месте.
Создание дерева пользовательских пакетов
Создайте каталог для пакетов, которые вы хотите собрать. Название каталога произвольно - вы можете назвать его так, как считаете нужным.
Клонируйте соответствующий пакет(-ы) из AUR или с Github. Позже Вы могли бы создать их сами! Вы можете выбрать любой пакет для сборки, но в качестве примера мы создаем пакет kickshaw
. Kickshaw - это современный редактор меню, в частности, для openbox. Сначала Вы добавляете его в свой репозиторий pkgbuild. Сделайте это с помощью git
Клонирование примера пакета из AUR
Теперь у вас есть каталог с файлом PKGBUILD
в вашем репозитории pkgbuild.
Лучше всего всегда знакомиться с содержимым пакета, чтобы убедиться, что все соответствует ожиданиям.
Сборка с помощью buildpkg
В buildpkg есть несколько опций, с которыми вам необходимо ознакомиться.
Использование: buildpkg [options] -p <pkg> Список или пакет [default: default] -a <arch> Азхитектура [default: x86_64] -b <branch> Ветка [default: unstable] -r <dir> Каталог chroot [default: /var/cache/manjaro-tools] -i <pkgs> Установить пакеты в рабочую копию chroot -c Пересоздать chroot -w Очистить кэш и исходиники -n Установить и запустить проверку namcap -s Подписать пакеты -u Группа Udev base-devel (без systemd) -q Настройки запросов и предварительная сборка -h Эта помощь
Следующее, что нужно сделать - это создать пакет. Пожалуйста, обратите внимание, что Вы должны находиться на один уровень выше Вашего фактического PKGBUILD. Поймите это, поскольку аргумент -p
- это "название каталога", содержащего набор инструкций PKGBUILD.
Дополнительные примеры использования buildpkg смотрите здесь.
Скрипт buildpkg создает закрытую среду для сборки пакета. Это делается для того, чтобы не засорять Вашу систему артефактами сборки.
Копирование файлов пакета в онлайн-репозиторий
Полученный пакет сохраняется в месте, определенном в manjaro-tools.conf в вашей системе (по умолчанию это каталог cache).
Вы должны увидеть сжатые файлы пакета. Имя файла должно заканчиваться на .pkg.tar.zst
.
Скопируйте или переместите файлы пакетов в онлайн-репозиторий:
Создание файла .db
Для отслеживания доступных пакетов менеджер пакетов pacman использует файлы базы данных, которые загружаются и хранятся на вашем компьютере. Вам необходимо создать такой файл базы данных для Вашего репозитория. Очень важно, чтобы имя файла базы данных совпадало с именем вашего репозитория. Если ваше хранилище называется online-repo, то имя базы данных должно быть online-repo.db.tar.gz.
Используйте команду repo-add
для создания файла базы данных в указанном вами каталоге репозитория
kickshaw-0.5-2-x86_64.pkg.tar.zst online-repo.db online-repo.db.tar.gz online-repo.files online-repo.files.tar.gz
Каждый раз, когда вы изменяете содержимое вашего онлайн-репозитория, база данных должна быть пересоздана! В противном случае buildiso впоследствии будет жаловаться на отсутствие пакетов в вашем онлайн-репозитории.
Two of the files are symlinks which may or may not work on your chosen host so they can be left out.
Upload online-repo to Host Server
Now you need to upload online-repo to your Host Server. Upload everything from online-repo to your Host Server. Your web address as to match the name of the directory folder you created. This is what your web address should look like after upload online-repo to your Host Server.
http://www.myserver.com/repository/online-repo/x86_64/
Add online-repo to your iso-profile
Create a file
[online-repo] SigLevel = Never Server = http://www.myserver.com/repository/online-repo/$repo/$arch
Custom online repositories will be added to the resulting pacman.conf. This means AUR packages cannot be installed unless you are using webserver to provide [online-repo]
as shown this article).
Add package names to ISO profile
Now you add kickshaw
to your package list for your ISO profile. This means your Packages-Desktop file should look something like this:
ffmpegthumbnailer gconf # fix qt-theme gnome-keyring # fix wlan segfault gufw # firewall accountsservice lightdm-gtk-greeter lightdm-gtk-greeter-settings light-locker manjaro-settings-manager menulibre ## AUR packages kickshaw
Cleaning build environment
For removing your build environment from your hard drive, execute:
NOTE
Now, you can continue to adjust your manjaro-tools.conf or build your ISO.
Creating an online repo requires you to keep the repo up-to-date when changes are made upstream.