= 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 lo que vamos a hacer es usar el initrd.gz de Ubuntu y modificarle simplemente el arranque. Además podemos borrarle todo lo que tenga que ver con la instalación de Ubuntu. Cualquier cosa que querramos 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 libreria, 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. Podriamos 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 tener el script de arranque? = * Primero deberia 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 ogn-browser. Más información en ogn-browser. * Si queremos usar el ratón hay que añadir necesariamente el módulo psmouse.ko. = ¿Cómo se ha creado el initrd.gz? = == Descargar == Nos descargamos un initrd.gz base y el núcleo linux de la distribición. En la primera versión usamos la versión del instalador de red de Ubuntu/Jaunty: {{{ mkdir /tmp/initrd cd /tmp/initrd wget http://archive.ubuntu.com/ubuntu/dists/jaunty/main/installer-i386/current/images/netboot/ubuntu-installer/i386/initrd.gz wget http://archive.ubuntu.com/ubuntu/dists/jaunty/main/installer-i386/current/images/netboot/ubuntu-installer/i386/linux }}} El núcleo linux no hace falta modificarlo, se usa tal cual. == Descomprimirlo == Una vez obtenido vamos a descomprimirlo para modificarlo para suplir nuestras necesidades. {{{ mkdir -p /tmp/initrd/newroot cd /tmp/initrd/newroot gzip -dc ../initrd.gz | cpio -id }}} Esto te crea en /tmp/initrd/newroot el sistema de ficheros que tendrías al arrancar con el núcleo y el initrd. Cualquier modificación que le hagamos al sistema de ficheros se verá afectado cuando se vuelva a comprimir. == 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 tiene un 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 agregaramos nuestros scripts directamente en ese directorio, como viene en el apartado "Modificar el arranque" conseguiriamos 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. Una mejor manera es borrar todo sobre la instalación de Ubuntu scripts, librerias, configuración, etc. para que quede mucho más claro y ocupe menos espacio. Si se quiere crear un initrd de prueba, rápido y sucio puedes pasar directamente a "Modificar el arranque". == Borrando restos de Ubuntu/Debian (Sin acabar) == Modificamos el inittab por este otro: Borramos los siguientes ficheros de la instalación de Ubuntu: {{{ find -name *debian* -exec rm -rf {} \; cd bin/ file * | grep shell | awk -F ":" '{print $1}' | xargs rm rm anna archdetect choose-mirror log rm -rf apt-install choose-mirror deb* env2debconf ethdetect fetch-url rm -rf lib/main-menu.d }}} == Modificar el arranque == En el directorio /tmp/initrd/newroot/etc/rcS.d/ podemos crear los scripts que queremos que se ejecuten al inicio. Se crean ficheros dentro que empicen por SxxNombreDescriptivo siendo xx dos números con el orden de ejecución. Yo he creado los siguientes tres archivos: * S01dhclient {{{ # It gets an IP from the DHCP server. mkdir -p /var/state/dhcp /sbin/dhclient }}} * S02montarnfs {{{ # Montamos por NFS para ejecutar el script de inicio que tendrá en nombre de nuestra ip DHCP_SERVER=`grep -h dhcp-server-identifier /var/lib/dhcp3/dhclient.* | sed 's/[^0-9]*\(.*\);/\1/' | head -1` IP=`grep -h fixed-address /var/lib/dhcp3/dhclient.* | sed 's/[^0-9]*\(.*\);/\1/' | head -1` mount -t nfs -onolock $DHCP_SERVER:/var/netboot/ /mnt /mnt/$IP.sh }}} * S99restart {{{ # Reiniciamos reboot }}} == Recomprimir initrd.gz == {{{ cd /tmp/initrd/newroot/ find ./ | cpio -H newc -o > /tmp/initrd-netboot gzip -9 /tmp/initrd-netboot }}} Eso genera un /tmp/initrd-netboot.gz que podremos sustituir al initrd.gz original por él. = Compilaciones estáticas de los principales programas = 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. == chntpw == {{{ make chntpw.static }}} == ctorrent == {{{ LDFLAGS=-static ./configure make }}} == s/fdisk == El paquete es el util-linux. {{{ LDFLAGS=-static ./configure --with-fsprobe={blkid,volume_id} make }}} == kexec-tools == {{{ LDFLAGS=-static ./configure make }}} == ntfsclone == {{{ LDFLAGS=-static ./configure make }}} == parted == Para compilar se necesita gcc-4.2, la version 4.3 da errores. {{{ LDFLAGS='-static' ./configure --disable-Werror make }}} == partimage == Descargado directamente desde: http://sourceforge.net/projects/partimage/files/stable/partimage-0.6.4-static.tar.bz2/download == tftp == {{{ LDFLAGS='-static' ./configure --without-tcpwrappers make }}}