administración unix: arranque del sistema y servicios...

29
Administraci ´ on UNIX: Arranque del sistema y servicios b ´ asicos Jes ´ us Montes S ´ anchez jmontes@fi.upm.es Octubre 2014 jmontes@fi.upm.es Administraci ´ on UNIX: Arranque del sistema y servicios b ´ asicos 1/29

Upload: buingoc

Post on 21-Sep-2018

223 views

Category:

Documents


0 download

TRANSCRIPT

Administracion UNIX:Arranque del sistema y

servicios basicosJesus Montes Sanchez

[email protected]

Octubre 2014

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 1/29

Arranque de sistemas UNIX

Secuencia de arranque simplificada

1 Arranque del sistema y comienzo de ejecucion del firmware.2 Inicio del cargador de arranque.3 Carga e inicio del nucleo del sistema operativo.4 Arranque del proceso init.5 Puesta en marcha servicios, sistemas de ficheros, terminales, ...

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 2/29

Cargador de arranque (bootloader)El cargador de arranque

• Lanzado por el firmware del sistema (BIOS/UEFI/coreboot)• Normalmente almacenado en disco.• Carga el nucleo en memoria y le transfiere el control.

Arranque en arquitecturas PC

• La BIOS carga el programa situado en el MBR (master bootrecord) del disco duro principal.

• Ese programa puede ser un cargador de otro programa en elVBR (volume boot record) de la particion activa.

Cargadores de arranqueGRUB (Linux, Solaris, ...), lilo (Linux), Boot Camp (Apple),bootblk/ufsboot (Solaris).

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 3/29

Inicializacion del kernel

Carga

• La localizacion de la imagen del nucleo varıa entre SO(/boot/vmlinuz (Linux), /unix (AIX), /kernel (FreeBSD),/kernel/geunix (Solaris)).

• El cargador de arranque sabe como acceder al sistema deficheros y cargar el nucleo en memoria.

• Tras la carga se cede el control al nucleo, pudiendo pasarlealguna opcion en este instante (ej. init=/path/to/bin,acpi=off, single).

• Una particularidad de Linux es el initrd (Initial RAM disk), undisco RAM temporal con utilidades y modulos para montar elsistema de ficheros raız.

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 4/29

Inicializacion del kernel

ArranqueEn cuanto el nucleo recibe el control ejecuta una serie de pasosantes de lanzar el primer proceso.

1 Detectar la memoria disponible y reservarse algo.2 En Linux, descomprimir initrd y montarlo.3 Detectar y configurar el hardware.4 Montar el sistema de ficheros (normalmente como solo lectura).5 Lanzar procesos espontaneos internos (kjournald, kswapd,

etc.).6 Lanzar el proceso init.

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 5/29

GRUBGRand Unified Bootloader

• Es el cargador de arranque por defecto de la gran mayorıa de lasdistribuciones Linux sobre architecturas Intel.

• El proceso de carga se divide en dos etapas. Una en el MBR oVBR y la otra en /boot/grub.

Funcionalidades• Arranca cualquier SO que cumpla con la especificacionmultiboot.

• Consola interactiva tipo bash.• Menu configurable.• Soporte para varios sistemas de ficheros.• Opciones para el nucleo y cargadores initrd.• Transferencia del control a otro cargador (chain loading).

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 6/29

GRUB

GRUB Legacy (GRUB 1)

• Version antigua, sin desarrollo a dıa de hoy• Carga en ∼2 etapas:

• Etapa 1, desde el sector de MBR (o VBR)• Etapa 1.5 desde 30KB contiguos al primer sector de la particion.

Contiene codigo para entender el sistema de ficheros donde sehaya la etapa 2.

• Etapa 2. El codigo de GRUB en sı.

• Los ficheros de configuracion se localizan en /boot/grub, enparticular el menu de arranque es menu.lst

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 7/29

GRUB

GRUB 2• Reescritura de GRUB para mejorar el soporte multiplataforma,

internacionalizacion, carga de modulos, ...• A dıa de hoy es el cargador de arranque usado en Debian,

CentOS (y RHEL), openSUSE, Ubuntu, Solaris...• El proceso de carga es muy similar, pero la etapa 1 es mas

flexible a la hora de cargar la siguiente.• Los ficheros del cargador tambien estan en /boot/grub, pero

son distintos.• El fichero menu.lst desaparece en favor de grub.cfg, el cual

soporta un lenguaje parecido a bash.• En algunos Linux (Ubuntu...) ese fichero no esta pensado para

ser editado a mano sino por update-grub. Las directivasrelacionadas estan en /etc/grub.d/ y /etc/default/grub.

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 8/29

GRUB

Ejemplos (GRUB version 1)

• Arranque de un sistema Linuxgrub> root (hd0,0)grub> kernel /boot/vmlinuz root=(hd0,0)grub> initrd /boot/initrd.imggrub> boot

• Arranque de un Windows con chain loadinggrub> rootnoverify (hd0,1)grub> makeactivegrub> chainloader +1grub> boot

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 9/29

GRUB

Ejemplos (GRUB version 2)

• Arranque de un sistema Linuxgrub> set root=(hd0,1)grub> linux /boot/vmlinuz root=(hd0,1)grub> initrd /boot/initrd.imggrub> boot

• Arranque de un Windows con chain loadinggrub> insmod ntfsgrub> insmod chaingrub> set root=(hd0,2)grub> chainloader +1grub> boot

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 10/29

Proceso init

Padre de todos los procesos

• El proceso init es el proceso de PID 1 y el encargado dearrancar todos los servicios y dar acceso al sistema.

• El nucleo ejecuta por defecto el proceso /sbin/init

Secuencia de arranque multiusuario

1 Comprobar raız y montar en modo lectura-escritura.2 Comprobar otros sistemas (/etc/fstab) y montarlos.3 Activar el area de intercambio.4 Limpieza (ej. borrar /tmp).5 Arrancar demonios locales.6 Configurar la red y arrancar demonios de red.7 Habilitar el login.

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 11/29

Proceso init

• El codigo de la secuencia de arranque no es parte del procesoinit en sı mismo.

• Esta secuencia se implementa como una coleccion de scriptsque son ejecutados por init de acuerdo con unas reglaspreestablecidas.

• Una vez termina la secuencia de arranque el proceso init notermina (nunca lo hace), si no que queda a la espera de:

• La terminacion de cualquier proceso hijo para capturar su valor deretorno y evitar que quede zombie.

• Alguna senal que indice que debe reconfigurarse el sistema.

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 12/29

Modo monousuario

• Tambien llamado modo de mantenimiento.• Modo de arranque especial para la solucion de problemas.• Consola root, sin red ni login.

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 13/29

Apagado del sistema

SecuenciaCuando se da la orden de apagado se lleva a cabo:

1 Notificacion a los usuarios el apagado con un mensaje.2 Se envıa la senal SIG TERM a todos los procesos en ejecucion.3 Init comienza la secuencia de terminacion de servicios.4 Paso a modo monousuario:

• Se envıa SIG KILL a los procesos que al cabo de 5 segundos delenvıo de SIG TERM aun no terminaron.

• Se desconecta a los usuarios y bloquea el acceso.

5 Sincronizacion de los sistemas de ficheros y desmontado.6 Apagado o reinicio.

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 14/29

Configuracion del arranque

Tipos de init

• Estilo BSD: NetBSD, FreeBSD, OpenBSD• System V: AIX, HP-UX, Linux, Solaris• Asıncrono: Launchd (Mac OS/X), Upstart, systemd (Linux)

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 15/29

Configuracion estilo System VEste es el modo de configuracion clasico de la mayorıa de los UNIX yforma parte de Linux Standard Base (Basado en SUS).

RunlevelsConcepto basico que se refiere al estado de sistema.

• telinit n cambia el sistema al estado n.• who -r devuelve el estado actual.• shutdown es un script para pasar al runlevel de apagado.

Componentes

• Fichero de reglas /etc/inittab.• Scripts primarios rcn (normalmente enlaces simbolicos).• Scripts secundarios (/etc/rc.d, /etc/init.d).• Ficheros de configuracion adicionales (/etc/default).

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 16/29

Clasificacion de Runlevels

• 0: Halt, para apagado seguro.• 1: Administracion mantenimiento.• S y s: Modo monousuario (pide contrasena de root).• 2: Modo multiusuario sin servicios de red.• 3: Modo multiusuario con servicios de red.• 4, 7, 8 y 9: Por definir por el administrador,• 5: Igual que 3 con consola grafica• 6: Reinicio• Q y q: Pseudo estado para forzar la re-lectura /etc/inittab.• a, b, c Pseudo-runlevel: No cambian el estado numerico. Solo

ejecutan los mandatos presentes /etc/inittab.

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 17/29

Fichero inittab

SintaxisUn serie de lıneas con el formato

id:niveles:accion:proceso args

• id: Identificador unico.• niveles: Niveles en los que se ejecuta.• accion: Modo de ejecucion.• proceso args: Mandato que ejecutar y argumentos.

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 18/29

Fichero inittab

Tipos de accionesEl campo accion le indica a init como debe ejecutar el proceso.Los tipos de accion habituales son:wait Se espera a que la tarea acabe.respawn Si la tarea termina, se relanza automaticamente.once Comenzar el proceso si no esta funcionando ya.boot Ejecutar solo al arranque.bootwait Ejecutar solo al arranque, esperando a que termine.initdefault Para definir el nivel por defecto

(no se especifica proceso en este caso).sysinit Actividades previas a que init acceda a la consola.off Terminar el proceso si esta ejecutando.otros man inittab.

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 19/29

Fichero inittab

Ejemploid:3:initdefault:

l0:0:wait:/etc/init.d/rc 0l1:1:wait:/etc/init.d/rc 1l2:2:wait:/etc/init.d/rc 2l3:3:wait:/etc/init.d/rc 3

2:2345:respawn:/sbin/mingetty tty2

ca::ctrlaltdel:/sbin/shutdown -r -t 4 now

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 20/29

Scripts de inicializacion rcn

• El valor de n indica el runlevel.• Uno o varios scripts normalmente en /etc/rcn.d.• Los scripts secundarios se almacenan en /etc/init.d y se

enlazan desde los directorios /etc/rcn.d/ o/etc/init.d/rcn.d/

• Los scripts secundarios se etiquetan y ejecutan en un ordenpredeterminado.

• Existen herramientas para manejar dependencias entre scripts yetiquetar los enlaces automaticamente (innserv, chkconfig,sysv-rc-conf)

K09cron K15portmap S01dbus S08nfsK11nfsserver K16avahi-daemon S02consolekit S10kbdK11postfix K16syslog S03haldaemon S10powersavedK11xdm K17network S05network S10sshdK12cups K19haldaemon S06avahi-daemon S11nfsserver

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 21/29

Arranque, parada, reinicio deservicios

Gestion manual• El estado de los servicios presentes en /etc/init.d puede

manipularse manualmente.• El estado se cambia ejcutando el script con uno de los

argumentos:• start Arranca el servicio si no esta arrancado• stop• restart Para y rearranca el servicio• otros

• Los scripts de /etc/inid.d se pueden ejecutar directamentepero es recomendable usar el mandato service paraproporcionar un entorno mas seguro.

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 22/29

Arranque, parada, reinicio deservicios

Gestion automatica• Normalmente la parada y arranque de servicios esta gestionada

por init a traves de los scripts /etc/init.d/rc, el cual seinvoca desde /etc/inittab al cambiar de nivel de ejecucion.

• Al pasar de un runlevel inferior a uno superior X , los scripts/etc/rcX.d que empiezan por S se ejecutan en ordenascendente pasando el argumento start.

• Al pasar de un runlevel inferior a uno superior X , los scripts/etc/rcX.d que empiezan por K se ejecutan en ordendescendent pasando el argumento stop.

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 23/29

Init asıncronoEl init System V arranca los diferentes servicios de forma secuencial.

• No aprovecha la posibilidad de arranque concurrente dedeterminados servicios.

• Es poco flexible a la hora de organizar dependencias entreservicios.

AlternativaImplementaciones mas modernas, que gestionan el arranque deforma mas eficiente.

• Organizan los servicios en trabajos y/o tareas.• Permiten especificar dependencias entre tareas, condiciones de

arranque/parada automaticas, etc.• La secuencia de arranque de servicios no es fija, ya que

depende de la configuracion de casa tarea.

Launchd (Mac OS/X), Upstart, systemd (Linux).

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 24/29

Udev

Sistema para gestionar nodos de dispositivo en /dev

• Soporta nombrado estatico basado en UUIDs.• Funciona en espacio de usuario.

Arquitectura

• Biblioteca libudev.• Demonio udevd.• Herramienta udevadm para diagnostico.• El kernel se comunica con el demonio por medio de un socketnetlink.

• El demonio funciona por medio de reglas en/etc/udev/rules.d

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 25/29

D-bus

Introduccion• Bus de sistema que proporciona mecanismos IPC (inter-process

communication).• Permite intercambio de mensajes entre aplicaciones basado en

un esquema de emisor/subscriptor.• Desarrollado por el proyecto freedesktop.org• Usado por GNOME, KDE (>4) y Qt 4.

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 26/29

D-bus

Arquitectura

• Existe un demonio de sistema (dbus-daemon) y otro por sesionde usuario para dar servicio al resto aplicaciones.

• La funcionalidad de bajo nivel se implementa en una bibliotecaen C (libdbus).

• La communicacion se establece a traves de sockets UNIX.• Existen envolturas de la biblioteca de bajo nivel para varios

entornos y lenguajes (Glib, Qt, C++, Python).

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 27/29

D-bus

Conceptos

• Nombres de bus org.freedesktop.DBus.• Interfaces org.nombre.interfaz.• Objetos (identificados con nombres similares a un sistema de

ficheros /org/aso2013/test.• Metodos.

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 28/29

Servicios: programacion de tareas

Existen mutitud de tareas de adminsitracion que deben realizarse deforma periodica

• Actualizacion de software• Comprobaciones de seguridad• Realizacion de back-ups• etc.

Herramientas comunes• cron y crontab (parte del estandar SUS)• anacron

[email protected] Administracion UNIX: Arranque del sistema y servicios basicos 29/29