wiki:InitrdCliente

Version 19 (modified by ramon, 15 years ago) (diff)

Instlación de paquetes udeb

TOC(heading=Índice)?

Cliente Initrd

El cliente initrd.gz es sistema muy liviano que nos permitirá instalar sistemas con un arranque muy rápido. El initrd.gz es un archivo comprimido que tiene un sistema de ficheros completo. Modificar el initrd.gz puede ser bastante molesto, así que nuestro objetivo es no tener que modificarlo nunca más, pero que funcione en todos los ordenadores posibles sin que haya que actualizarlo continuamente. Para ello hemos creado un script que lo genera automáticamente descargándolo de internet. El script lo que hace es usar el initrd.gz de Ubuntu y modificarle simplemente el arranque. Este arranque evita que se ejecute la instalación y ejecuta un script determinado montado por NFS.

Además el script va a ser mejorado, pudiendo elegir entre Ubuntu o Debian, permitir descargar el núcleo o no,etc. y se está intentando borrarle todo lo que tenga que ver con la instalación de Ubuntu. Cualquier cosa que queramos agregarle al sistema lo haremos a través de NFS. Ejemplos de cosas que se podrían agregar a través NFS sería:

  • Arranques polimórficos. El cliente buscará que hacer en el servidor, que puede ofrecerle un script distinto cada vez.
  • Ejecutables compilados estáticamente. Estáticamente para que no haya que mantener todos los programas compilados con las misma librería, menos manteniento. Es importante modificar el PATH en el script de arranque para agregar las rutas nuevas de los ejecutables nuevos.
  • Módulos para el kernel. Podríamos coger módulos de la propia Ubuntu para que haya incompatibilidad y poder hacer insmod a través de NFS, por ejemplo el del ratón que no viene por defecto.

¿Qué debe hacer el script de arranque?

  • Primero debería montar por NFS todo lo necesario.
  • Si se montan directorios con ejecutables hay que agregarlo al PATH, por ejemplo las librerias de instalación/restauración del sistema.
  • Si se montan directorios con módulos como el psaux.ko hay que hacerles insmod para los que queramos.
  • Si queremos usar el modo gráfico hay que arrancarlo con framebuffer y montar por NFS el ejecutable browser. Más información en browser.
  • Si queremos usar el ratón hay que añadir necesariamente el módulo psmouse.ko.

¿Qué hace el initrd-generator?

Lo primero que hace es ir al directorio de archivos temporales y lo descarga y descomprime.

BusyBox

Este tipo de instalación (debian en modo consola) se basan en usar la herramienta BusyBox. Es un ejecutable que proveé la mayoria de las herramientas unix en un espacio reducido. Entonces si miramos por ejemplo el directorio /bin del initrd veremos que sólo son enlaces a la herramienta busybox. Un 'ls -l' se ejecutaría como un 'busybox ls -l' dentro de la instalación. Todo lo que no tenga el busybox es lo que deberemos agregar por NFS y compilación estática. Busybox es también EL init. Sabe usar el /etc/inittab pero no tiene soporte para arranque multinivel. El fichero /etc/inittab es el fichero que usa el primer proceso llamada "init" para saber que tiene que hacer. Para más informacción man inittab. El fichero que trae el initrd.gz de Ubuntu lo primero que hace es llamar a debian-installer-startup que llama, a su vez, a los scripts de /etc/rcS.d/. Si agregáramos nuestros scripts directamente en ese directorio, como viene en el apartado "Modificar el arranque" conseguiríamos ejecutar nuestro código antes que la instalación de Ubuntu, y sí al final ponemos un restart o un shutdown nadie sabría que es una instalación de Ubuntu. Se podría intentar eliminar todo rastro de la instalación pero trae problemas a la hora de arrancar (produce kernel panics), así que de momento sólo añade cosas.

Modificar el arranque

En el directorio /etc/rcS.d/ creamos los archivos SxxNombreDescriptivo siendo xx números de prioridad.

Recomprimir initrd.gz

Una vez modificado el arranque lo comprime y lo mueve al directorio actual. Hace lo mismo con el núcleo.

Futuro

En el futuro deberá parsear opciones para:

  • Descargar el núcleo opcionalmente.
  • Permitir descargar distintas versiones.
  • Permitir descargar Debian también.
  • Permitir hacer sólo algunos pasos y otros no. (Para crear initrd.gz personalizados).
  • Borrar restos de la instalación de Ubuntu. (very very very low priority).

PXE

Generando el initrd

Nos vamos al directorio donde vayamos a situar el initrd y ejecutamos el script trunk/opengnsys-client/boot/initrd-generator

cd /opt/opengnsys/tftpboot
cp .../initrd-generator .
./initrd-generator

Al finalizar tendremos el initrd.gz y el kernel (archivo llamado linux).

Fichero de configuración PXE:

Dentro de /opt/opengnsys/tftpboot/pxelinux.cfg creamos el archivo de configuración PXE, llamado default o 01-MAC_equipo (ej: 01-00-25-ed-78-a9-ff) . Tenemos un ejemplo en trunk/opengnsys-server/PXE/pxelinux.cfg/default

Recursos compartidos por nfs NFS

Nos basamos en la propuesta de estructura de directorio descrita en Estructura de Directorios de los Componentes

En /opt/opengnsys/client situamos lo que encontramos en el subversión de trunk/opengnsys-client/nfsexport.

Dentro de del directorio /opt/opengnsys/client/lib/engine/bin situamos el contenido del subversión de trunk/opengnsys-client/engine.

Observamos que tenemos tres subdirectorios vacíos (cache, images y logs) serán puntos de montaje para la partición cache y dos recursos nfs con permiso de escritura.

Queda por determinar donde estarán los script de arranque y las páginas de inicio del navegador. Inicialmente los script de arranque están situados en /opt/opengnsys/client/init. Ejemplo: trunk/opengnsys-client/boot/ej_script_init.sh

Archivo de configuración NFS

Tenemos un ejemplo de /etc/export en trunk/opengnsys-server/NFS/exports.

Paquetes udeb

Propuesta para sustituir algunas compilaciones estáticas. Lista de todos los paquetes disponibles trunk/opengnsys-doc/udeb.list y lista de los que se están usando ahora trunk/opengnsys-client/install-udeb. Los paquetes están ahora mismo en trunk/opengnsys-client/nfsexport/lib/udeb Para poder descargar los paquetes udeb con sus dependencias o agregamos una línea al /etc/apt/sources.list o creamos un fichero con la línea en /etc/apt/sources.list.d/ :

deb http://es.archive.ubuntu.com/ubuntu/ jaunty main/debian-installer

Luego ejecutar:

apt-get update
mkdir -p /tmp/udeb/partial
apt-get install -o dir::cache::archives=/tmp/udeb -d `cat install-udeb`

Y estarán todos los paquetes udeb en el directorio /tmp/udeb que se deberán copiar al /opt/opengnsys/client/lib/udeb/ en el proceso de instalación.

Se ha creado el script upgrade-clients-udeb.sh que realiza automáticamente el proceso de descarga, selección y copiado de paquetes udeb, según las instrucciones anteriores.

Dicho script utiliza un fichero de configuración donde se indican los paquetes a descargar y aquellos que no deben ser copiado a las librerías de los clientes. Cada línea del fichero udeblist.conf indica la operación a realizar con cada uno de los paquetes seleccionados, con el siguiente formato:

install:nombrepaquete
remove:nombrepaquete

Compilaciones estáticas de los principales programas

(Puede que esté obsoleto y no sea exactamente así)

La mayoría de las fuentes se han conseguido a través de "apt-get source paquete" en una Ubuntu Jaunty. Si no se dice nada se supondrá que se ha obtenido de esa manera. Para instalar las dependencias necesarias se puede hacer de esta manera "apt-get build-dep paquete". No olvidar ejecutar strip después de compilarlo ya que puede disminuir mucho el tamaño del ejecutable final.