Создание собственного репозитория: различия между версиями

Материал из ALT Linux Wiki
 
(не показано 13 промежуточных версий 2 участников)
Строка 1: Строка 1:
{{Stub}}
{{Note|Данная статья создана для организаций, которые хотят создать собственный репозиторий с ПО для ALT Linux, совместимый с APT-RPM, который используется в данной системе.}}
{{Note|Данная статья создана для организаций, которые хотят создать собственный репозиторий с ПО для ALT Linux, совместимый с APT-RPM, который используется в данной системе.}}
{{Note|Короткая ссылка сюда - https://www.altlinux.org/Ownrepo}}


Рпозиторий ALT Linux состоит из двух компонетов:
Репозиторий ALT Linux состоит из двух компонентов:
*индексов - где описаны все пакеты, ссылки на них и их версии
*индексов - где описаны все пакеты, ссылки на них и их версии
*самих пакетов (в формате *.rpm)
*самих пакетов (в формате *.rpm)
Строка 25: Строка 25:


В новосозданном пути обратите внимание на следующие моменты:
В новосозданном пути обратите внимание на следующие моменты:
*x86_64 - архитектура пакетов
*x86_64 - архитектура пакетов (Возможные архитектуры: i586, i686, x86_64, noarch)
*RPMS.classic - каталог с пакетами. Обычно он имеет компонент classic, но можно указать любое имя компонента.
*RPMS.classic - каталог с пакетами. Обычно он имеет компонент classic, но можно указать любое имя компонента.


Строка 63: Строка 63:
Теперь данный каталог ({{path|/home/user/MyRepo/x86_64}}) нужно опубликовать на http, ftp или rsync сервере.
Теперь данный каталог ({{path|/home/user/MyRepo/x86_64}}) нужно опубликовать на http, ftp или rsync сервере.


===Публикация на Http-сервере===
===Публикация на Веб-сервере===
По статье [[Веб-сервер]]:
По статье [[Веб-сервер]]:
*Поставьте пакеты
*Запустите службу httpd2


Ставим пакеты:
Скопируйте каталоги репозитория в каталог Apache:
# apt-get install lamp-server
  cp -a /home/user/MyRepo /var/www/html/
 
Запускаем службу:
 
Apache:
  # service httpd2 start
# service httpd2 enable
 
=====Настройка Apache2=====
Открываем от имени суперпользователя:
# mcedit /etc/httpd2/conf/include/Directory_html_default.conf
 
Необходимо в строке
Options Includes FollowSymLinks MultiViews
дописать слово Indexes:
Options Indexes Includes FollowSymLinks MultiViews
 
=====Где хранится репозиторий?=====
Открываем в редакторе от суперпользователя файл {{path|/etc/httpd2/conf/sites-available/default.conf}}.
 
Ищем строку
DocumentRoot "/var/www/html/"
 
======Вариант I======
Меняем путь на свой. В нашем случае:
DocumentRoot "/home/user/MyRepo/"
Реалный путь в ФС:
/home/user/MyRepo/x86_64.
 
Адрес будет:
IP x86_64 classic
 
======Вариант II======
Но, можно оставить:
DocumentRoot "/var/www/html/"
 
И создать в папке {{path|html}} каталоги {{path|altlinux/p10}}.


Путь получится такой:
Путь получится такой:
/var/www/html/altlinux/p10
  var
  var
  └── www
  └── www
     └── html <- корневой каталог Apache для сайтов
     └── html <- каталог Apache для веб-сайтов
         └── altlinux <-каталог на сайте для ALT Linux (в случае, если будут еще репозитории для других ОС)
         └── MyRepo <- каталог репозитория
             └── p10 <- каталог под конкретную платформу
             └── x86_64 <- подкаталог для архитектуры x86_64


В этот каталог переместите папку x86_64.
Адрес будет:
IP/altlinux/p10 x86_64 classic
И вы сможете создавать репозитории под другие плафтормы/дистрибутивы на этом http-сервере.
===Прописывание в системе===
===Прописывание в системе===
====Вариант I====
Если вы опубликовали данный каталог (MyRepo) на веб-сервере по адресу {{path|MyRepo/x86_64}}, полный путь для добавления в систему (в файл sources.list) получается такой:
Например, вы опубликовали данный каталог (x86_64) на http сервере по адресу {{path|IP/x86_64}}
<syntaxhighlight lang="text">rpm http://IP/MyRepo x86_64 classic</syntaxhighlight>
 
{{Category navigation|title=Начинающему разработчику|category=Начинающему разработчику|sortkey={{SUBPAGENAME}}}}
Там путь:
├── base
│   ├── pkglist<nowiki>*</nowiki> <- в этих файлах список пакетов
│   └── release<nowiki>*</nowiki> <- в этих файлах информация о репозиториях
└── RPMS.classic <- в этом каталоге лежат rpm-пакеты
 
Полный путь для добавления в систему (в файл sources.list) получается такой:
{{path|rpm http://IP/ x86_64 classic}}
 
====Вариант II====
Например, вы опубликовали данный каталог (x86_64) на http сервере по адресу {{path|IP/altlinux/p10/x86_64}}
 
Там путь:
├── base
│   ├── pkglist<nowiki>*</nowiki> <- в этих файлах список пакетов
│   └── release<nowiki>*</nowiki> <- в этих файлах информация о репозиториях
└── RPMS.classic <- в этом каталоге лежат rpm-пакеты
 
Полный путь для добавления в систему (в файл sources.list) получается такой:
{{path|rpm http://IP/altlinux/p10 x86_64 classic}}

Текущая версия от 18:55, 15 февраля 2024

Примечание: Данная статья создана для организаций, которые хотят создать собственный репозиторий с ПО для ALT Linux, совместимый с APT-RPM, который используется в данной системе.
Примечание: Короткая ссылка сюда - https://www.altlinux.org/Ownrepo


Репозиторий ALT Linux состоит из двух компонентов:

  • индексов - где описаны все пакеты, ссылки на них и их версии
  • самих пакетов (в формате *.rpm)

Создание каталога для репозитория

Первым делом нужно создать каталог репозитория.

Примечание: Вы можете создать репозиторий в любом месте файловой системы


Создание каталога для репозитория, в общем примере, выглядит так:

# mkdir путь/где/вы/хотите/создать/репозиторий
# cd путь/где/вы/хотите/создать/репозиторий
# mkdir -p x86_64/RPMS.classic #создание хранилища пакетов

Находиться он может в любом месте.

Примечание: В нашем примере репозиторий будет в домашнем каталоге - ~


Например:

$ mkdir ~/MyRepo
$ cd ~/MyRepo
$ mkdir -p x86_64/RPMS.classic

В новосозданном пути обратите внимание на следующие моменты:

  • x86_64 - архитектура пакетов (Возможные архитектуры: i586, i686, x86_64, noarch)
  • RPMS.classic - каталог с пакетами. Обычно он имеет компонент classic, но можно указать любое имя компонента.
Примечание: Компонент - последнее слово после "RPMS."


В этот каталог RPM.classic и нужно скопировать все ваши *.rpm пакеты.

Полный путь для *.rpm-пакетов, в нашем случае, получается таким:

  • /home/user/MyRepo/x86_64/RPMS.classic/

Создание индексов

Следующим шагом нам нужно создать индексы для репозитория.

Для этого нам нужна утилита apt-repo-tools. Установим ее следующей командой:

$ su -
# apt-get install apt-repo-tools

Переходим в каталог с нашей созданной папкой x86_64 и оттуда выполняем следующую команду:

# cd /home/user/MyRepo/
# genbasedir --create --progress --topdir=. x86_64 classic

По результатам выполнения команды в этом же каталоге в подкаталоге x86_64 создается каталог base.

Получается путь:

/home/user/MyRepo/x86_64
├── base
│   ├── pkglist.classic
│   ├── pkglist.classic.bz2
│   ├── pkglist.classic.xz
│   ├── release
│   └── release.classic
└── RPMS.classic

Публикация в сети

Теперь данный каталог (/home/user/MyRepo/x86_64) нужно опубликовать на http, ftp или rsync сервере.

Публикация на Веб-сервере

По статье Веб-сервер:

  • Поставьте пакеты
  • Запустите службу httpd2

Скопируйте каталоги репозитория в каталог Apache:

cp -a /home/user/MyRepo /var/www/html/

Путь получится такой:

var
└── www
    └── html <- каталог Apache для веб-сайтов
        └── MyRepo <- каталог репозитория
            └── x86_64 <- подкаталог для архитектуры x86_64

Прописывание в системе

Если вы опубликовали данный каталог (MyRepo) на веб-сервере по адресу MyRepo/x86_64, полный путь для добавления в систему (в файл sources.list) получается такой:

rpm http://IP/MyRepo x86_64 classic