mkimage-profiles/conf.d
Anton Midyukov 6b76ff841c engineering.mk: not cleanup docs and rpmdb for live
enineering-live does not contain livecd-installer
2022-02-20 22:16:21 +07:00
..
alt-server.mk alt-server.mk: switch to grub-efi for bootloading iso on x86_64 UEFI 2022-01-20 09:31:03 +07:00
basealt.mk basealt.mk: specify network backend for netplan in alt-workstation-cloud 2022-02-13 21:16:01 +07:00
desktop.mk desktop.mk: hide broken targets 2021-12-10 21:04:16 +07:00
e2k.mk e2k.mk: added firmware-linux to alt-rescue.img 2021-10-28 01:11:36 +07:00
education.mk education.mk: add +vmguest to vm/alt-education 2021-12-28 16:11:24 +07:00
engineering.mk engineering.mk: not cleanup docs and rpmdb for live 2022-02-20 22:16:21 +07:00
homeros.mk speech-*: refactored and unified 2013-11-22 21:28:37 +04:00
kworkstation.mk - kwrk: add use/stage2/net-install 2021-10-18 20:17:43 +07:00
live.mk live.mk: drop tintii 2022-02-02 16:36:07 +07:00
Makefile check-recipe: generalize dependency control 2017-01-29 15:50:58 +03:00
mixin-alt-server.mk mixin-alt-server.mk, centaurus: add a group of pve-backup-server 2021-12-10 21:02:37 +07:00
mixin-basealt.mk workstation: Disable systemd-userdbd service by default 2021-12-10 20:50:34 +07:00
mixin.mk mixin.mk: add polkit-rule-admin-root to mixin/regular-desktop 2022-02-16 11:16:01 +07:00
README Add COMMON_LISTS variable support by analogy COMMON_PACKAGES 2021-08-31 00:42:31 +07:00
realtime.mk Drop STARTERKIT variable, need not 2021-09-01 22:52:14 +07:00
regular-vm.mk regular-vm.mk, regular.mk: set mirror repos http/yandex for all regulars 2022-02-02 16:36:07 +07:00
regular.mk regular.mk: exclude xorg-conf-synaptics for not x86 2022-02-20 22:13:50 +07:00
server-v.mk server-v: use crio instead of docker with k8s 2022-01-19 20:28:51 +07:00
server.mk Drop net-eth support 2021-04-12 23:13:57 +07:00
slinux.mk slinux.mk: add +vmguest to vm/slinux 2021-12-28 16:09:31 +07:00
test.mk test.mk: add package availability test in all package lists 2021-08-23 21:09:07 +07:00
ve.mk ve.mk: replace ve/pgsql94 to ve/pgsql 2021-11-15 22:47:45 +07:00
vm.mk vm.mk: Add sr_mod to initrd modules for vm/cloud-systemd 2021-09-17 13:34:10 +03:00

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

== conf.d ==

Этот каталог содержит включаемые фрагменты конфигурации образов с тем,
чтобы было удобнее параллельно разрабатывать специфические образы
без излишних merge conflict'ов.

Следует понимать, что основная цель появления mkimage-profiles на свет
-- это уменьшение "форков" внутри семейства дистрибутивных профилей.
Поэтому при возможности следует всё-таки работать над общей базовой
частью, включая скриптовые хуки и списки пакетов, а также оптимизировать
граф зависимостей между конфигурациями образов.

Попросту говоря, copy-paste -- тревожный признак.

Вместо него нередко может помочь выделение кусочков конфигурации
в пределах включаемого файла в цели mixin/*, которые не являются
самостоятельными или даже промежуточными, но включают полезные
группы настроек, нужных в различных образах, не наследующих
друг другу -- посмотрите существующие примеры использования.

По переменным (см. тж. doc/pkglists.txt):

* для пользовательского окружения (live, main) предназначены
  THE_PACKAGES, THE_LISTS, THE_GROUPS, THE_PACKAGES_REGEXP

* для "обычного общего" (live, main, rescue) есть COMMON_PACKAGES и
  COMMON_LISTS
  (NB: тоже попадают в базовую установку, ve/ и vm/ сборки)

* SYSTEM_PACKAGES стоит применять крайне осторожно -- эти пакеты попадут
  во все стадии, в том числе в образ чувствительной к объёму install2
  (в stage1 -- только в инструментальный чрут); применяйте для того,
  что обязано быть и в инсталяторе, и в готовой системе (но не в rescue)

* для направленного действия служат:
** STAGE1_PACKAGES, STAGE1_PACKAGES_REGEXP (первая стадия загрузки)
** STAGE2_PACKAGES (инсталятор и спасательная/"живая" система)
** INSTALL2_PACKAGES (инсталятор)
** BASE_PACKAGES, BASE_LISTS, BASE_PACKAGES_REGEXP (базовая система)
** MAIN_PACKAGES, MAIN_LISTS, MAIN_PACKAGES_REGEXP (дополнительные пакеты)
** LIVE_PACKAGES, LIVE_LISTS, LIVE_PACKAGES_REGEXP ("живая" система)

* аналогично по kernel-modules-*:
** THE_KMODULES попадут в "пользовательскую" среду (live, main)
** STAGE1_KMODULES доступны в производных от stage2 (install2, live, rescue)
** BASE_KMODULES попадут в установку по умолчанию
** MAIN_KMODULES будут доступны для установки с носителя
** LIVE_KMODULES предназначены для LiveCD/LiveFlash

Не стоит бояться такого разнообразия, для большинства задач достаточно THE_*.

По подстановкам:

* $(VAR) подставляются перед их записью в $(CONFIG), который distcfg.mk
* $$(VAR) раскрываются позже, при включении $(CONFIG) и востребовании
  значений; в этом случае их значения могут изменяться до окончания
  конфигурации, а также зависеть от значений других переменных

По спискам пакетов:

* на этапе экспериментирования можно забивать прямо в описание образа
* при фиксации состояния стоит воспользоваться существующими списками,
  а дополнительные оформить как можно более чётко обособленными по тем
  задачам, для решения которых они и подобраны
* повторяющиеся логически связанные группы списков может иметь смысл
  выделить в фичу (см., например, power или x11)
* если явной фичи не наблюдается, но у группы дистрибутивов намечается
  заметная общая часть -- её можно выделить в промежуточную цель вида
  distro/.name, не являющуюся самостоятельно собираемой