Простой rpm репозиторий используя Inotify и webdav
В этом посте рассмотрим хранилище rpm артефактов c помощью простого скрипта с inotify + createrepo. Заливка артефактов осуществляется через webdav используя apache httpd. Почему apache httpd будет написано ближе к концу поста.
Итак, решение должно отвечать cледующим требованиям для организации только RPM хранилища:
Бесплатное
Доступность пакета в репозитории через несколько секунд после загрузки в хранилище артефактов.
Простое в установке и обслуживании
Возможность сделать высокую доступность (high availability)
Артефакты в SonaType Nexus хранятся в blob. При внезапном выключении электричества вы не сможете восстановить blob, если у в вас нет бекапа. У нас была такая ошибка: ERROR [ForkJoinPool.commonPool-worker-2] *SYSTEM [com.orientechnologies.orient.core.storage](http://com.orientechnologies.orient.core.storage/).fs.OFileClassic - $ANSI{green {db=security}} Error during data read for file 'privilege_5.pcl' 1-th attempt [java.io](http://java.io/).IOException: Bad address. Blob так и не восстановили.
По умолчанию inotify-createrepo мониторит директорию /var/www/repos/rpm-repo/.
Изменить эту директорию можно в файле /etc/inotify-createrepo.conf.
Использование
При добавлении любого файла в директорию /var/www/repos/rpm-repo/ inotifywait создаст файл /tmp/need_create. Функция run_createrepo запускается в бесконечном цикле и мониторит файл /tmp/need_create. Если файл существует, то запускается createrepo --update.
Возможность сделать высокую доступность (high availability)
Чтобы сделать высокую доступность (high availability) из существующего рещения, думаю можно использовать 2 сервера, Keepalived для HA и Lsyncd для синхронизации артефактов. Lsyncd — демон, который следит за изменениями в локальной директории, агрегирует их, и по прошествии определенного времени стартует rsync для их синхронизации. Подробности и настройка описана в посте "Cкоростная синхронизация миллиарда файлов".
WebDav
Загружать файлы можно несколькими путями: SSH, NFS, WebDav. WebDav кажется современным и простым вариантом.
Для WebDav будем использовать Apache httpd. Почему Apache httpd в 2020 году, а не nginx?
Хочется использовать автоматизированные средства для сборки Nginx + модули (например, Webdav).
Остальную настройку Apache httpd я думаю вы сделаете сами.
Nginx перед Apache httpd
В отличие от Apache, Nginx использует событийную модель обработки запросов, благодаря чему на любое количество клиентов требуется всего один процесс HTTP-сервера. Вы можете использовать nginx и снизить нагрузку на сервер.
Конфиг nginx-front.conf. Остальную настройку nginx я думаю вы сделаете сами.