9 | | TODO |
| 9 | == Instalación == |
| 10 | No realizar el proceso en un sistema en procucción. |
| 11 | Se ha testado con éxito en la ubuntu server 32 bits 10.04, 10.04.2 y 10.10 |
| 12 | |
| 13 | NOTA: el instalador está en "http://www.opengnsys.es/browser/trunk/client/boot-tools/" |
| 14 | {{{ |
| 15 | mv /opt/opengnsys/tftpboot/ogclient /opt/opengnsys/tftpboot/ogclient-old; |
| 16 | svn checkout http://www.opengnsys.es/svn/trunk/client /tmp/opengnsys_installer/opengnsys/client/; |
| 17 | find /tmp/opengnsys_installer/ -name .svn -type d -exec rm -fr {} \; 2>/dev/null; |
| 18 | /tmp/opengnsys_installer/opengnsys/client/boot-tools/ogClientGeneratorV2.sh; |
| 19 | }}} |
| 20 | |
| 21 | DEBUG en el proceso de instalación: |
| 22 | {{{ |
| 23 | Continuar sin instalar grub -> yes |
| 24 | Congigura el console-data |
| 25 | Introduce la clave pub de nuestro servidor(ejecutor del instalador) en el cliente. En el caso de que ya exista un .pub nos pregunta si generar uno nuevo o mantener (N) |
| 26 | Could not find /boot/grub/menu.lst file. Would you like /boot/grub/menu.lst generated for you? (y/N) -> Y |
| 27 | |
| 28 | }}} |
| 29 | |
| 30 | |
| 31 | El proceso que se ha indicado a continuación, genera los elementos del cliente OpenGnsys, basados en la versión de ubuntu que tengamos instalados (mismo kernel y distribución). |
| 32 | |
| 33 | /opt/opengnsys/tftpboot/ogclient/ |
| 34 | {{{ |
| 35 | ./ogvmlinuz (el kernel) |
| 36 | ./oginitrd.img (el initrd) |
| 37 | ./ogclient.img (el sistema raiz, accesible como disco virtual usando schroot desde el host que lo generó, para ser actualizado) |
| 38 | ./ogclient.sqfs (el sistema raiz, comprimido para ser usado por los clientes OpenGnsys) |
| 39 | }}} |
| 40 | |
| 41 | |
| 42 | === Las fases de la instalación === |
| 43 | * Fase 1. Instalación en el equipo donde se ejecuta la instalación de software necesario. |
| 44 | * Fase 2. Asignación de valores, como la versión del kernel, basados en los datos del S.O que ejecuta el instalador, que serán utilizados para generar el cliente. |
| 45 | * Fase 3. Creación del sistema raiz (ogclient.img). Primero se crea un disco duro virtual, y se particiona -ogCleint2nFile()-. En la primera partición se genera un sistema operativo con la herramienta deboobstrap -ogClient2ndFs()-, con parametros basados en la fase2. |
| 46 | * Fase 4. Se configura el acceso al sistema raiz (ogclient.img) para ser usado con la herramienta schroot -ogClientSchrootConf()- |
| 47 | * Fase 5. Se configura o se incluyen los elementos especiales de opengnsys (engine, QTEmbbedbed, pci.ids, browser, ogAdmClient). -ogClient2ndSVN()- |
| 48 | * Fase 6. Ampliación del sistema raiz -- instalación de software con apt, compilación de algunas herramientas, importación de la clave ssh desde el SO que lo generó. |
| 49 | * Fase 7. Generación del initrd. |
| 50 | * Fase 8. Generación del sistema raiz en sqfs. |
| 51 | |
| 52 | == Incorporación del fichero .sqfs (proceso instalación de OpenGnsys) en un fichero .img para su posterior modificación == |
| 53 | NOTA: este subapartado no está terminado de documentar |
| 54 | |
| 55 | NOTA: este procedimiento se ha comprobado en una ubuntu server 10.04 32bits. |
| 56 | |
| 57 | {{{ |
| 58 | export OGCLIENTBASEDIR=/var/lib/tftpboot/ogclient/; |
| 59 | export OGCLIENTFILE=${OGCLIENTBASEDIR}ogclient.img; |
| 60 | export OGCLIENTMOUNT=${OGCLIENTBASEDIR}ogclientmount; |
| 61 | export OGCLIENTSIZEMB=1900; |
| 62 | export OGCLIENTLABEL=ogClient; |
| 63 | |
| 64 | mkdir -p $OGCLIENTMOUNT; |
| 65 | dd if=/dev/zero of=$OGCLIENTFILE bs=1048576 count=$OGCLIENTSIZEMB; |
| 66 | DISKLOOP=$(losetup -f); |
| 67 | losetup $DISKLOOP $OGCLIENTFILE; |
| 68 | echo -e "n\np\n1\n\n\nt\n83\nw" | fdisk $DISKLOOP; |
| 69 | losetup -d $DISKLOOP ; |
| 70 | PARTLOOP=$(losetup -f); |
| 71 | losetup -o 32256 $PARTLOOP $OGCLIENTFILE && mkfs.ext3 -b 4096 -L $OGCLIENTLABEL $PARTLOOP; |
| 72 | losetup -d $PARTLOOP ; |
| 73 | losetup -d $PARTLOOP ; |
| 74 | |
| 75 | mount | grep $OGCLIENTMOUNT || mount $OGCLIENTFILE $OGCLIENTMOUNT -o loop,offset=32256; |
| 76 | |
| 77 | unsquashfs -d /opt/opengnsys/tftpboot/ogclient/ogclientmount/ -f /opt/opengnsys/tftpboot/ogclient/ogclient.sqfs ; |
| 78 | umount $OGCLIENTMOUNT; |
| 79 | echo "fin"; |
| 80 | |
| 81 | |
| 82 | |
| 83 | cp /etc/schroot/schroot.conf /etc/schroot/schroot.conf.`getDateTime` |
| 84 | cat << EOF > /etc/schroot/schroot.conf |
| 85 | [IMGogclient] |
| 86 | type=loopback |
| 87 | file=/var/lib/tftpboot/ogclient/ogclient.img |
| 88 | description=ogclient ubuntu luc IMGi |
| 89 | priority=1 |
| 90 | users=root |
| 91 | groups=root |
| 92 | root-groups=root |
| 93 | mount-options=-o offset=32256 |
| 94 | root-users=root |
| 95 | [DIRogclient] |
| 96 | type=directory |
| 97 | directory=/var/lib/tftpboot/ogclient/ogclientmount |
| 98 | description=ogclient ubuntu lucid DIR |
| 99 | priority=2 |
| 100 | users=root |
| 101 | groups=root |
| 102 | root-groups=root |
| 103 | root-users=root |
| 104 | EOF |
| 105 | cp /etc/schroot/mount-defaults /etc/schroot/mount-defaults.`getDateTime` |
| 106 | cat << EOF > /etc/schroot/mount-defaults |
| 107 | # mount.defaults: static file system information for chroots. |
| 108 | # Note that the mount point will be prefixed by the chroot path |
| 109 | # (CHROOT_PATH) |
| 110 | # |
| 111 | # <file system> <mount point> <type> <options> <dump> <pass> |
| 112 | proc /proc proc defaults 0 0 |
| 113 | #procbususb /proc/bus/usb usbfs defaults 0 0 |
| 114 | #/dev /dev none rw,bind 0 0 |
| 115 | /dev/pts /dev/pts none rw,bind 0 0 |
| 116 | /dev/shm /dev/shm none rw,bind 0 0 |
| 117 | #/home /home none rw,bind 0 0 |
| 118 | /tmp /tmp none rw,bind 0 0 |
| 119 | EOF |
| 120 | |
| 121 | |
| 122 | }}} |