Hasher/Tips
Автоматическое переключение sources.list под архитектуру
В ~/.hasher/config:
# target if [ `uname -m` = "i686" ]; then def_target=i586 apt_config=$HOME/.hasher/apt.conf.i586 fi
При запуске hsh через i586 автоматически используется нужный sources.list. (mithraen@ в devel@)
См. полный пример от at@ с заданием полностью своего sources.list для hasher.
Кэширование скачиваемых apt-ом пакетов
- "Проблема", в связи с которой возникает такое пожелание, вот в чём
- При каждой сборке в hasher-е, hasher готовит окружение для сборки, устанавливая пакеты к себе; их вытаскивает из репозитория-источника apt. Если репозиторий удалённый (например, используются общесистемные настройки apt, указывающие на ftp-репозиторий Sisyphus), то каждый раз apt будет скачивать все потребовавшиеся пакеты по сети (заново). Хотелось бы сэкономить на трафике и времени и использовать постоянный кэш apt -- один и тот же для всех предстоящих сборок в hasher-е.
(То же пожелание, высказанное Yury Aliaev.)
- Судя по высказывавшимся советам, это должно быть возможно, если включить себя в группу rpm
- at@:
Добавьте себя в группу rpm.
- at@:
hasher умеет делать 'apt-get install --download-only' через системный /etc/apt/sources.list. Но ему может не хватить прав на /var/*/apt.
- Но в чистом виде такой совет (просто добавление себя в группу rpm) не сработал для hasher-1.3.22-alt1 -- общесистемный /var/cache/apt/archives/ не стал хранить скачанные пакеты.
- Поправка конфигурации apt для hasher
- Посмотрим на то, как работает hasher. /usr/bin/mkaptbox готовит конфигурацию apt для hasher так (см. исходный код):
# create final apt.conf file. cat >"$apt_config_file" <<__EOF__ Dir::State "$aptbox/var/lib/apt/"; Dir::Cache "$aptbox/var/cache/apt/"; ${apt_config:+$(cat "$apt_config")} Dir::Etc::SourceList "$aptbox/etc/apt/sources.list"; RPM::RootDir "$aptbox"; APT::Install::Virtual "true"; APT::Install::VirtualVersion "true"; ${alternate_arch:+APT::Architecture "${target:-$def_target}";} __EOF__ verbose "Created APT configuration file \`$apt_config_file'."
- Т.е. оно не собирается использовать общесистемный кэш (а прописывает свою директорию для кэша, которая будет стираться между вызовами hsh). Но есть возможность вставить какую-нибудь нашу добавку к конфигурации, передав её параметром --apt-config.
- Я записал в некий файл (~/hsh-extra-apt.conf):
Dir::Cache "/var/cache/apt/";
- (комментарии там не надо использовать, потому что при вставке в mkaptbox они нарушат синтаксис файла конфигурации).
- Теперь я могу запускать сборки с опцией --apt-config=/home/imz/hsh-extra-apt.conf (нужно вписать именно полный путь, без ~) для hsh; например, так:
gear-hsh -v -- -v --no-sisyphus-check=packager,gpg --apt-config=/home/imz/hsh-extra-apt.conf
- и оно кэширует скачиваемые пакеты.
- Можно сохранить эти настройки в ~/.hasher/config (чтобы каждый раз не писать опцию):
apt_config=/home/imz/.hasher/extra-apt.conf
- (очевидно, тут я уже переместил тот файл в ~/.hasher/extra-apt.conf).
Замеченные проблемы:
- может понадобиться сделать от root:
rm /var/cache/apt/archives/lock
- Неудобно, что при размножении ~/.hasher/*-apt.conf (для разных веток ALTLinux) приходится добавлять конфигурацию для кеширования скачиваемых пакетов в каждый файл. Если общих опций несколько, то, конечно, хочется делать include общего конфигурационного файла для apt; для этого есть специальная директива #include -- см. "man apt.conf".
- Ещё одна неприятность -- то, что pkglist всё время скачиваются заново; например:
$ gear-hsh -- -v --lazy-cleanup hsh: changed working directory to `/tmp/.private/imz/hasher' [...] mkaptbox: Created RPM database in `./var/lib/rpm/'. Получено: 1 http://ftp.altlinux.org x86_64 release [914B] Получено: 2 http://ftp.altlinux.org noarch release [709B] Получено: 3 http://ftp.altlinux.org x86_64-i586 release [573B] Получено 2196B за 0s (7819B/s). Получено: 1 http://ftp.altlinux.org x86_64/classic pkglist [17,4MB] [...]
Неприятно долго ждать. А ведь работа системного apt этого недостатка не имеет, например (вместо "Получено" -- "Найдено"):
[root@z ~]# apt-get update Получено: 1 http://ftp.altlinux.org x86_64 release [914B] Получено: 2 http://ftp.altlinux.org noarch release [709B] Получено: 3 http://ftp.altlinux.org x86_64-i586 release [573B] Получено 2196B за 0s (9125B/s). Найдено http://ftp.altlinux.org x86_64/classic pkglist Найдено http://ftp.altlinux.org x86_64/classic release Найдено http://ftp.altlinux.org noarch/classic pkglist Найдено http://ftp.altlinux.org noarch/classic release Найдено http://ftp.altlinux.org x86_64-i586/classic pkglist Найдено http://ftp.altlinux.org x86_64-i586/classic release Чтение списков пакетов... Завершено Построение дерева зависимостей... 0%
Похоже, что эту проблему тоже можно решить:
Кэширование скачиваемых pkglist
Скачиваемые pkglist кладутся в /var/lib/apt/lists/ :
[root@z ~]# l /var/lib/apt/lists/ итого 167244 drwxr-xr-x 3 root root 4096 янв 29 18:00 ./ drwxr-xr-x 2 root root 4096 янв 29 18:00 partial/ -rw-r----- 1 root root 0 янв 29 18:00 lock -rw-r--r-- 1 root root 528 янв 29 03:23 ftp.altlinux.org_pub_distributions_ALTLinux_Sisyphus_noarch_base_release -rw-r--r-- 1 root root 40060882 янв 29 03:23 ftp.altlinux.org_pub_distributions_ALTLinux_Sisyphus_noarch_base_pkglist.classic -rw-r--r-- 1 root root 147 янв 29 03:23 ftp.altlinux.org_pub_distributions_ALTLinux_Sisyphus_noarch_base_release.classic -rw-r--r-- 1 root root 84706486 янв 29 02:30 ftp.altlinux.org_pub_distributions_ALTLinux_Sisyphus_x86%5f64_base_pkglist.classic -rw-r--r-- 1 root root 733 янв 29 02:30 ftp.altlinux.org_pub_distributions_ALTLinux_Sisyphus_x86%5f64_base_release -rw-r--r-- 1 root root 147 янв 29 02:30 ftp.altlinux.org_pub_distributions_ALTLinux_Sisyphus_x86%5f64_base_release.classic -rw-r--r-- 1 root root 392 янв 28 22:17 ftp.altlinux.org_pub_distributions_ALTLinux_Sisyphus_x86%5f64-i586_base_release -rw-r--r-- 1 root root 46447120 янв 28 22:17 ftp.altlinux.org_pub_distributions_ALTLinux_Sisyphus_x86%5f64-i586_base_pkglist.classic -rw-r--r-- 1 root root 152 янв 28 22:17 ftp.altlinux.org_pub_distributions_ALTLinux_Sisyphus_x86%5f64-i586_base_release.classic drwxr-xr-x 4 root root 4096 ноя 28 17:58 ../ [root@z ~]#
Может быть, для этого места тоже есть переменная, которую мы можем переопределить?..
[root@z ~]# apt-config dump | fgrep -6 var/lib/apt APT ""; APT::Architecture "x86_64"; APT::Cache-Limit "536870912"; APT::DistroVersion ""; Dir "/"; Dir::State "var/lib/apt/"; Dir::State::lists "lists/"; Dir::State::cdroms "cdroms.list"; Dir::State::prefetch "prefetch"; Dir::Cache "var/cache/apt/"; Dir::Cache::archives "archives/"; Dir::Cache::srcpkgcache "srcpkgcache.bin"; [root@z ~]#
Да! Только права на /var/lib/apt/lists/ не позволят в него писать.
Можно завести такое место у себя.
Может быть, даже стоит использовать директорию совместно с другим пользовательскими программами (apt-аплетом), которые тоже скачивают эти списки:
[root@z ~]# l ~imz/.apt/lists/ итого 167244 drwxr-xr-x 3 imz imz 4096 янв 29 15:14 ./ drwxr-xr-x 2 imz imz 4096 янв 29 15:14 partial/ -rw-r--r-- 1 imz imz 528 янв 29 03:23 ftp.altlinux.org_pub_distributions_ALTLinux_Sisyphus_noarch_base_release -rw-r--r-- 1 imz imz 40060882 янв 29 03:23 ftp.altlinux.org_pub_distributions_ALTLinux_Sisyphus_noarch_base_pkglist.classic -rw-r--r-- 1 imz imz 147 янв 29 03:23 ftp.altlinux.org_pub_distributions_ALTLinux_Sisyphus_noarch_base_release.classic -rw-r--r-- 1 imz imz 84706486 янв 29 02:30 ftp.altlinux.org_pub_distributions_ALTLinux_Sisyphus_x86%5f64_base_pkglist.classic -rw-r--r-- 1 imz imz 733 янв 29 02:30 ftp.altlinux.org_pub_distributions_ALTLinux_Sisyphus_x86%5f64_base_release -rw-r--r-- 1 imz imz 147 янв 29 02:30 ftp.altlinux.org_pub_distributions_ALTLinux_Sisyphus_x86%5f64_base_release.classic -rw-r--r-- 1 imz imz 392 янв 28 22:17 ftp.altlinux.org_pub_distributions_ALTLinux_Sisyphus_x86%5f64-i586_base_release -rw-r--r-- 1 imz imz 46447120 янв 28 22:17 ftp.altlinux.org_pub_distributions_ALTLinux_Sisyphus_x86%5f64-i586_base_pkglist.classic -rw-r--r-- 1 imz imz 152 янв 28 22:17 ftp.altlinux.org_pub_distributions_ALTLinux_Sisyphus_x86%5f64-i586_base_release.classic drwxr-xr-x 4 imz imz 4096 ноя 13 18:04 ../ [root@z ~]#
Итак, добавим в ~/.hasher/extra-apt.conf:
Dir::State::lists "/home/imz/.apt/lists/";
Вроде бы работает. Только иерархию нужных директорий обязательно надо предварительно создать: mkdir -p ~/.apt/lists/partial
(Допишите, пожалуйста, если есть ещё какие-то идеи по кешированию и ускорению apt в hasher.)
Получение списка пакетов для установки заданного
Для разворачивания полного списка файлов пакетов, образующих замыкание зависимостей какого-либо пакета (реального, виртуального или синтетической зависимости) можно воспользоваться mkaptbox:
$ mkaptbox -f && ~/hasher/aptbox/apt-get install -qqqy \ -oRPM::PM=external -oDir::Bin::rpm=hsh-rpmi-print-files 'perl(Text/ParseWords.pm)' /ALT/Sisyphus/noarch/RPMS.classic/setup-2.2.14-alt1.noarch.rpm /ALT/Sisyphus/x86_64/RPMS.classic/filesystem-2.3.11-alt1.x86_64.rpm /ALT/Sisyphus/x86_64/RPMS.classic/glibc-preinstall-2.11.3-alt8.x86_64.rpm /ALT/Sisyphus/x86_64/RPMS.classic/glibc-core-2.11.3-alt8.x86_64.rpm /ALT/Sisyphus/x86_64/RPMS.classic/bzlib-1.0.6-alt3.x86_64.rpm /ALT/Sisyphus/x86_64/RPMS.classic/libgcc1-4.5.3-alt3.x86_64.rpm /ALT/Sisyphus/x86_64/RPMS.classic/glibc-pthread-2.11.3-alt8.x86_64.rpm /ALT/Sisyphus/x86_64/RPMS.classic/libbeecrypt7-4.2.1-alt7.x86_64.rpm /ALT/Sisyphus/x86_64/RPMS.classic/libdb4.7-4.7.25-alt7.x86_64.rpm /ALT/Sisyphus/x86_64/RPMS.classic/libelf-0.153-alt1.x86_64.rpm /ALT/Sisyphus/x86_64/RPMS.classic/liblzma-5.0.3-alt1.x86_64.rpm /ALT/Sisyphus/x86_64/RPMS.classic/libpopt-1.14-alt6.x86_64.rpm /ALT/Sisyphus/x86_64/RPMS.classic/zlib-1.2.5-alt3.x86_64.rpm /ALT/Sisyphus/x86_64/RPMS.classic/sh-3.2.51-alt1.x86_64.rpm /ALT/Sisyphus/x86_64/RPMS.classic/libselinux-2.0.98-alt2.1.x86_64.rpm /ALT/Sisyphus/x86_64/RPMS.classic/librpm-4.0.4-alt100.51.x86_64.rpm /ALT/Sisyphus/x86_64/RPMS.classic/perl-base-5.14.2-alt4.x86_64.rpm
Советы бывалых
hsh-shell и hsh
mike@:
Собранное в hsh-shell пересобирать начисто hsh заодно выясняя, не забыл ли добавить в спек поставленное для сборки hsh-install'ом
ну и как минимум спеки-то должны быть или в ~/RPM/SPECS, или в ~/git :)
А перед этим можно скопировать спек
cp -ai ~/hasher/tmpfs/chroot/usr/src/RPM/SPECS/*.spec .
или вытащить весь пакет в ~/RPM:
rpm -i ~/hasher/tmpfs/chroot/usr/src/RPM/SRPMS/openmotif-2.3.3-alt3.src.rpm
Два хашера
drool@:
У меня два каталога хашера, один обычный, а второй я никогда не удаляю.
Когда наступает момент, что версии пакетов внутри неудаляемого хашера слишком устаревают, я рутом сохраняю оттуда /usr/src (ведь он там фактически как хомяк используется), а после генерации каталога заново заменяю им то, что создалось по новой. В итоге я у меня там сохраняется и настроенный ~/.rpmmacros, и ccache с его ~/.ccache, и содержимое ~/RPM и, что иногда бывает весьма полезным, ~/.bash_history.
Кэш в hasher
drool@:
И в этом втором каталоге у меня, ко всему прочему, настроен еще и ccache, что дает просто огромный прирост скорости компиляции, если пакет уже там собирался. Для этого внутрь этого хашера установлен непосредственно сам ccache, а в начало ~/.bash_profile вставлена конструкция:
GCC_USE_CCACHE=1 export GCC_USE_CCACHE