init (Español)
Init (abreviatura del término inglés initialization) es el primer proceso que se inicia durante el arranque del sistema. Es un demonio cuyo proceso continúa ejecutándose hasta que se apaga el sistema. Init es el ancestro directo o indirecto de todos los demás procesos, y adopta automáticamente todos los procesos huérfanos. El kernel lo inicia utilizando un nombre de archivo codificado. Si el kernel no puede iniciarlo, se producirá un «kernel panic». A init generalmente se le asigna el identificador de proceso (PID) 1.
Los scripts de init (o rc) son lanzados para garantizar la funcionalidad básica en el inicio y apagado del sistema. Esto incluye el (des)montaje del sistemas de archivos y el lanzamiento de los daemons. Un gestor de servicios va un paso más allá al proporcionar un control activo sobre los procesos ejecutados, o la supervisión de procesos. Un ejemplo es monitorear los bloqueos y reiniciar los procesos en consecuencia.
Estos componentes se combinan con el sistema init. Algunos inits incluyen el administrador de servicios en el proceso de inicio, o tienen scripts de inicio en estrecha relación con ellos. A estas entradas se hace referencia como «integradas», aunque las entradas en diferentes categorías pueden depender explícitamente entre sí.
Inits (integrados)
- anopa — Sistema de inicialización construido alrededor del conjunto de supervisión s6
- GNU Shepherd — Sistema de inicialización escrito en Guile.
- OpenRC — Sistema de inicialización basado en dependencias.
Inits
Scripts de init
- initscripts-fork — Fork de los scripts de SysVinit mantenido en Arch Linux.
Gestores de servicios
- daemontools — Colección de herramientas para gestionar servicios UNIX.
- https://cr.yp.to/daemontools.html || daemontoolsAUR[enlace roto: package not found]
Configuración
Migrar servicios en ejecución
Para ejecutar demonios bajo el nuevo init, guarde una lista de demonios en ejecución:
$ systemctl list-units --state=running "*.service" > daemons.list
y configure los #Scripts de init en consecuencia. Vea también .
logind
logind requiere que systemd sea el proceso de inicio. Como tal, las sesiones locales y otras funciones no estarán disponibles.
- Permisos del dispositivo
Añada usuarios a los grupos de usuarios respectivos para acceder al dispositivo y reiniciarlo. La pertencia actual al grupo debe verificarse primero con .
# usermod -a -G video,audio,power,disk,storage,optical,lp,scanner user
Consulte también Users and groups#Pre-systemd groups. Para crear reglas de grupo para usar con Polkit, vea Polkit#Bypass password prompt.
- Rootless X (1.16)
Como Xorg.wrap
no verifica si logind está activo , los derechos de root para Xorg deben activarse manualmente:
- Administración de energía
Consulte y acpid para reemplazar la administración de energía con systemd.
Tareas programadas
Arch utiliza los archivos timer en lugar de cron por defecto. Vea archlinux-cronjobs para conocer trabajos cron básicos.
Dbus
Las instancias de usuario de dbus-daemon son lanzadas por systemd/User . Cuando requiera IPC (del inglés «comunicación inter procesos) entre aplicaciones de escritorio, restaure :
/etc/X11/xinit/xinitrc.d/30-dbus.sh
#!/bin/bash # launches a session dbus instance if [ -z "${DBUS_SESSION_BUS_ADDRESS-}" ] && type dbus-launch >/dev/null; then eval $(dbus-launch --sh-syntax --exit-with-session) fi
Consejos y trucos
systemd-nspawn
systemd-nspawn es una herramienta para sistemas systemd. Sin embargo, desde Linux 2.6.19 es posible ejecutar systemd en un sistema no systemd utilizando el espacio de nombres PID. Para ello, el kernel debe configurarse con y ).
El espacio de nombres PID crea una nueva jerarquía de procesos que comienzan con PID 1. Además de esto, systemd requiere que se monte un sistema de archivos raíz enjaulado (chrooteado). Por lo tanto, debe al menos realizar un montaje de «bind», porque de lo contrario algunos servicios fallarán con:
"Failed at step NAMESPACE spawning" due to "Invalid operation"
dado que systemd intentará volver a montar la raíz con la opción .
Para configurar un entorno enjaulado (chroot) con un nuevo espacio de nombre PID puede usar jchroot. . Asegúrese de no montar dentro de la nueva raíz antes de realizar chroot, de lo contrario, systemd detectará el entorno chroot. Puede montarlo más tarde una vez que se esté ejecutando systemd.
Reemplazar udev
- mdev — Administrador de dispositivos para su utilización en sistemas integrados.
Véase también
- Debian init system debate
- How to run s6-svscan as process 1
- Replace systemd with busybox + minirc
- Experiments of Manjaro
- Init vs. runsv
- Demystifying the init system
- A history of modern init systems (1992-2015)
- Comparison of init systems (gentoo wiki)