Mkimage-profiles: различия между версиями

Материал из ALT Linux Wiki
м (→‎Цели: и это тоже)
м (подновил описание и страничку в целом; ветку 1.4 сопровождает antohami@)
(не показано 16 промежуточных версий 4 участников)
Строка 3: Строка 3:
__TOC__
__TOC__
= Суть =
= Суть =
{{pkg|mkimage-profiles}}, или ''m-p'' — результат осмысления и обобщения опыта создания семейств дистрибутивов свободного программного обеспечения на базе ALT Linux, [[Regular|применяемый]] [[Starterkits|на практике]].
{{pkg|mkimage-profiles}}, или ''m-p'' — система управления конфигурацией [[starterkits|семейств]] [[releases|дистрибутивов]] свободного программного обеспечения из репозиториев ALT для различных платформ.


Входит в [[Starterkits/builder|стартеркит builder]] в готовом к употреблению виде.
Входит в [[Starterkits/builder|стартеркит builder]] в готовом к употреблению виде.
{{main|Mkimage/history|l1=история}}
{| style="border:1px solid #AAA; background:#F9F9F9; width:100px; margin: 0 0 1em 1em; padding:.2em; text-align:left; float: right;" class=noprint
{| style="border:1px solid #AAA; background:#F9F9F9; width:100px; margin: 0 0 1em 1em; padding:.2em; text-align:left; float: right;" class=noprint
|-
|-
Строка 13: Строка 12:
| '''[[Mkimage/Profiles/m-p/examples|1.&nbsp;git&nbsp;clone<br />2.&nbsp;make<br />3.&nbsp;...<sup>*</sup>]]'''
| '''[[Mkimage/Profiles/m-p/examples|1.&nbsp;git&nbsp;clone<br />2.&nbsp;make<br />3.&nbsp;...<sup>*</sup>]]'''
|}
|}
= Цель =
Создание дистрибутивных образов<ref>iso, img, tar...</ref> на нашей [[branches|пакетной]] [[sisyphus|базе]].
Отличие от [[Mkimage/Profiles/Desktop|предыдущего поколения]]<ref>...а также от большинства известных аналогов</ref> — возможность простого и управляемого наследования конфигурации при её создании из существующих «строительных блоков».
{{main|Mkimage/history|l1=история}}
= Средства =
Языки реализации — <tt>make</tt> и <tt>shell</tt>, как и в [[mkimage]].  Для внесения изменений может потребоваться заметный опыт администрирования и базовый — разработки.


= Цели =
: ''Документация книжкой: '''[http://nightly.altlinux.org/docs/mkimage-profiles.html HTML]'''/'''[http://nightly.altlinux.org/docs/mkimage-profiles.pdf PDF]'''''
Основная — создание прикладных образов на пакетной базе ALT Linux; подчинённые:
# поощрение совместной работы
# относительно низкая трудоёмкость использования
# пригодность к '''[[Mkimage/Profiles/m-p/examples|применению]]''' разработчиками разного уровня для разных задач


= Средства =
= Свойства =
* двухуровневость:
* двухуровневость:
** метапрофиль более объёмен и сложен, но выгоден для долгосрочной разработки
** сам метапрофиль объёмный и сложный, но выгодней для долгосрочной разработки
** сгенерированный дистрибутивный профиль более легко обозрим и модифицируем как одноразовый форк
** сгенерированный дистрибутивный профиль легче прочитать и поправить одноразово
* наследственность на уровне индивидуальных особенностей и образов в целом
* наследственность на уровне особенностей (features) и образов в целом
* прозрачность и диагностируемость формирования конфигурации
* прозрачность и диагностируемость формирования конфигурации (distcfg.mk)
* документированность
* документированность
{{main|Mkimage/Profiles/m-p/howto|l1=howto}}
{{main|Mkimage/Profiles/m-p/howto|l1=howto}}
= '''[[Mkimage/Profiles/m-p/examples|Примеры использования]]''' =
= '''[[Mkimage/Profiles/m-p/examples|Примеры использования]]''' =
# '''выполняем начальные инструкции по [http://git.altlinux.org/people/mike/packages/?p=mkimage-profiles.git;a=blob;f=QUICKSTART;hb=HEAD документации]'''
# '''выполняем начальные инструкции по [http://git.altlinux.org/people/mike/packages/?p=mkimage-profiles.git;a=blob;f=QUICKSTART;hb=HEAD документации]'''
# '''{{cmd|git clone git://git.altlinux.org/people/mike/packages/mkimage-profiles.git}}'''
# '''{{cmd|git clone git://git.altlinux.org/gears/m/mkimage-profiles.git}}'''
# '''{{cmd|cd mkimage-profiles}}'''
# '''{{cmd|cd mkimage-profiles}}'''
# '''{{cmd|make help}}'''
# '''{{cmd|make help}}'''
Строка 38: Строка 40:
Конфигурация образа — тоже объект ''сборки''.
Конфигурация образа — тоже объект ''сборки''.
{{main|Mkimage/Profiles/m-p/design|l1=дизайн}}
{{main|Mkimage/Profiles/m-p/design|l1=дизайн}}
{| style="border:1px solid #AAA; background:#F9F9F9; width:250px; margin: 0 0 1em 1em; padding:.2em; text-align:right; float: right;" class=noprint
| <sup>*</sup> ''Если серьёзно, то создание дистрибутивов не приносит доход само по себе — его может принести польза, которую они дают людям. А может и не.''
|}
= [[Mkimage/Profiles/m-p/style|Пожелания к коллегам]] =
= [[Mkimage/Profiles/m-p/style|Пожелания к коллегам]] =
Давайте стараться [http://lib.ru/MEMUARY/ERSHOW_W/zapiski_ezdowogo_psa.txt сделать ''красиво''].
Давайте стараться [http://lib.ru/MEMUARY/ERSHOW_W/zapiski_ezdowogo_psa.txt делать ''красиво''].
{{main|Mkimage/Profiles/m-p/style|l1=стиль}}
{{main|Mkimage/Profiles/m-p/style|l1=стиль}}
= [[Mkimage/Profiles/m-p/objects|Объекты воздействия]] =
= [[Mkimage/Profiles/m-p/objects|Объекты воздействия]] =
Образ, субпрофиль, фича и список пакетов.  Перед правкой профиля ознакомьтесь!
Образ, субпрофиль, фича и список пакетов.  Перед правкой профиля ознакомьтесь с ними.
{{main|Mkimage/Profiles/m-p/objects|l1=объекты}}
{{main|Mkimage/Profiles/m-p/objects|l1=объекты}}
= [[Mkimage/Profiles/m-p/news|Состояние]] =
= [[Mkimage/Profiles/m-p/news|Состояние]] =
[http://git.altlinux.org/people/mike/packages/?p=mkimage-profiles.git Публичная бета]; см. тж.:
[http://git.altlinux.org/people/antohami/packages/?p=mkimage-profiles.git Стабильная ветка]; см. тж.:
* [https://www.openhub.net/p/mkimage-profiles анализ кода на openhub],
* [https://www.openhub.net/p/mkimage-profiles анализ кода на openhub],
* [http://0x1.tv/Категория:Михаил_Шигорин доклады]:
* [http://0x1.tv/Категория:Михаил_Шигорин доклады]:
Строка 55: Строка 53:
** [http://lvee.org/ru/abstracts/63 LVEE 2013W],
** [http://lvee.org/ru/abstracts/63 LVEE 2013W],
** [http://lvee.org/ru/abstracts/87 LVEE 2013],
** [http://lvee.org/ru/abstracts/87 LVEE 2013],
** [https://docviewer.yandex.ru/?url=ya-serp%3A%2F%2Fold.linux.kiev.ua%2F~mike%2Fdocs%2Fpresentations%2Fprotva-shigorin-mkimage-profiles.pdf&name=protva-shigorin-mkimage-profiles.pdf&c=561cffa935c3 Обнинск];
** [http://lvee.org/uploads/image_upload/file/364/shigorin-lvee2014-rescue.pdf LVEE 2014] (PDF про [[rescue]]),
* документация книжкой ([http://nightly.altlinux.org/docs/mkimage-profiles.html HTML]/[http://nightly.altlinux.org/docs/mkimage-profiles.pdf PDF]).
** [https://docviewer.yandex.ru/?url=ya-serp%3A%2F%2Fftp.altlinux.org%2Fpub%2Fpeople%2Fmike%2Fdoc%2Fconference%2Fprotva-shigorin-mkimage-profiles.pdf&name=protva-shigorin-mkimage-profiles.pdf&c=561cffa935c3 Обнинск].


Осень 2014: разрабатываются ветки 1.0.x и 1.1.x; регулярно публикуется метапрофиль ([http://git.altlinux.org/people/mike/packages/?p=mkimage-profiles.git git], [http://packages.altlinux.org/mkimage-profiles rpm]), при помощи которого можно собрать сразу несколько '''дистрибутивов''', '''шаблонов виртуальных окружений''', '''образов виртуальной машины''' для i586/x86_64<ref>{{cmd|git checkout 1.0}} — в 1.1.x bin/tar2vm по состоянию на март 2014 интересно сломан</ref>, '''образов ФС для ARM'''<ref>а вот ARM в 1.1.x как раз работает</ref>; чруты собраны и для PowerPC.  Из всего этого налажены '''[[Regular|регулярные сборки]]''' и '''[[Starterkits|стартеркиты]]''', среди прочего.
Осень 2020: разрабатывается ветка 1.4.x; [[Mkimage/Profiles/m-p/news|регулярно]] публикуется метапрофиль ([http://git.altlinux.org/people/mike/packages/?p=mkimage-profiles.git git], [http://packages.altlinux.org/mkimage-profiles rpm]), при помощи которого можно собрать сразу несколько '''дистрибутивов''', '''шаблонов виртуальных окружений''', '''образов виртуальной машины''' для i586/[[ports/x8664|x86_64]], [[ports/aarch64|aarch64]]/[[ports/arm|armh]], [[ports/mipsel|mipsel]], [[ports/e2k|e2k]], ppc64el, [[ports/riscv64|riscv64]].  Из всего этого налажены '''[[Regular|регулярные сборки]]''' и '''[[Starterkits|стартеркиты]]''', среди прочего.


Работаем без спешки, как для себя.  Метабаг — [https://bugzilla.altlinux.org/show_bug.cgi?id=26300 #26300].
Работаем без спешки, как для себя.  Метабаг — [https://bugzilla.altlinux.org/show_bug.cgi?id=26300 #26300].
{{main|Mkimage/Profiles/m-p/news|l1=новости}}
{{main|Mkimage/Profiles/m-p/news|l1=новости}}
= Примечания =
<references/>
[[Категория:Mkimage]]
[[Категория:Mkimage]]
{{Category navigation|title=mkimage-profiles|category=mkimage-profiles|sortkey=*}}
{{Category navigation|title=mkimage-profiles|category=mkimage-profiles|sortkey=*}}

Версия от 12:07, 28 сентября 2020

M-p.png

Суть

mkimage-profiles, или m-p — система управления конфигурацией семейств дистрибутивов свободного программного обеспечения из репозиториев ALT для различных платформ.

Входит в стартеркит builder в готовом к употреблению виде.

Information.svg
1. git clone
2. make
3. ...*

Цель

Создание дистрибутивных образов[1] на нашей пакетной базе.

Отличие от предыдущего поколения[2] — возможность простого и управляемого наследования конфигурации при её создании из существующих «строительных блоков».

Основная статья: история

Средства

Языки реализации — make и shell, как и в mkimage. Для внесения изменений может потребоваться заметный опыт администрирования и базовый — разработки.

Документация книжкой: HTML/PDF

Свойства

  • двухуровневость:
    • сам метапрофиль объёмный и сложный, но выгодней для долгосрочной разработки
    • сгенерированный дистрибутивный профиль легче прочитать и поправить одноразово
  • наследственность на уровне особенностей (features) и образов в целом
  • прозрачность и диагностируемость формирования конфигурации (distcfg.mk)
  • документированность
Основная статья: howto

Примеры использования

  1. выполняем начальные инструкции по документации
  2. git clone git://git.altlinux.org/gears/m/mkimage-profiles.git
  3. cd mkimage-profiles
  4. make help
  5. make regular-rescue.iso
Основная статья: примеры

Решения при дизайне

Конфигурация образа — тоже объект сборки.

Основная статья: дизайн

Пожелания к коллегам

Давайте стараться делать красиво.

Основная статья: стиль

Объекты воздействия

Образ, субпрофиль, фича и список пакетов. Перед правкой профиля ознакомьтесь с ними.

Основная статья: объекты

Состояние

Стабильная ветка; см. тж.:

Осень 2020: разрабатывается ветка 1.4.x; регулярно публикуется метапрофиль (git, rpm), при помощи которого можно собрать сразу несколько дистрибутивов, шаблонов виртуальных окружений, образов виртуальной машины для i586/x86_64, aarch64/armh, mipsel, e2k, ppc64el, riscv64. Из всего этого налажены регулярные сборки и стартеркиты, среди прочего.

Работаем без спешки, как для себя. Метабаг — #26300.

Основная статья: новости
  1. iso, img, tar...
  2. ...а также от большинства известных аналогов