Los boot environments son una característica que Solaris introdujo en la versión 8, es decir, hace ya mucho tiempo de aquello. Sin embargo, parece que esta característica pasa desapercibida entre muchos SysAdmin de Solaris y realmente es algo "vital" para nuestros sistemas de producción.
Como decía mi padre, "Los experimentos, con gaseosa", pues bien, los boot environments son lo más parecido a la gaseosa que tenemos en Solaris, ;)
Qué es un boot environment
Como su nombre indica, es un arranque completo y totalmente diferente. Esto, nos permite por ejemplo, parchear un sistema "OnLine" sin tener que detener sus servicios. Comprobar que todo está correcto e iniciar la máquina con el nuevo boot environment si todo está correcto.
De esta forma, pasamos de tener un tiempo de parada de X horas a el tiempo que tarde la máquina en iniciarse -mucho menos que X, por supuesto- y lo más importante, tenemos un proceso de "rollback" rápido y sencillo.
Cómo funcionan los boot environments
La gestión de los boot environments se realiza mediante el comando <beadm> el cual nos proporciona las siguientes opciones:
- Ver todos los boot environments que tenemos disponibles
- Activar/Desactivar boot environments
- Crear/Destruir boot environments
- Montar/Desmontar boot environments
Ver todos BE
Para ver todos los BE que disponemos en el sistema deberemos utilizar la opción <list> del comando <beadm>, por ejemplo:
havoc@h100:~$ pfexec beadm list
BE Active Mountpoint Space Policy Created
-- ------ ---------- ----- ------ -------
HSeries - /mnt 441.51M static 2013-03-07 23:57
solaris - - 3.06M static 2011-04-16 04:06
solaris-1 NR / 103.78G static 2011-04-16 04:41
Los datos más importantes que vamos a ver en esta primera parte son los siguientes:
- BE: Nombre único del boot
- Active: Si es el boot activo, es decir, el que estamos ejecutando ahora mismo
- MountPoint: Dónde esta montado -luego veremos para qué es interesante-
- Space: El espacio que ocupa
- Policy: El tipo de boot -lo veremos con más detalle en la segunda parte-
Para crear un nuevo BE, deberemos utilizar la opción <create> con un nombre de BE nuevo y único -en nuestro caso se llama "PreUpdate"-
havoc@h100:~$ pfexec beadm create PreUpdate
Si ahora volvemos a ver todos los BE que existen en el sistema, veremos cómo hay uno nuevo.
havoc@h100:~$ pfexec beadm list
BE Active Mountpoint Space Policy Created
-- ------ ---------- ----- ------ -------
HSeries - /mnt 489.39M static 2013-03-07 23:57
PreUpdate - - 122.0K static 2013-03-08 10:15
solaris - - 3.06M static 2011-04-16 04:06
solaris-1 NR / 103.81G static 2011-04-16 04:41
Cuándo crear un nuevo BE
Lo cierto es que, tanto si tienes equipos de pruebas, como si no, siempre que quieras hacer algún cambio en los sistemas de producción, deberías comprobar que todo va a ir bien, por ejemplo, si queremos realizar las pruebas de una actualización que vamos a instalar, un nuevo parche, un nuevo paquete, etc.
Destruir un BE
Para destruir un BE deberemos tener en cuenta dos cosas importantes:
- El BE no puede estar montado, es decir, el valor de Mountpoint debe ser "-"
- El BE no puede ser el activo, es decir, el valor de Active debe ser "-"
havoc@h100:~$ pfexec beadm destroy PreUpdate
Are you sure you want to destroy PreUpdate? This action cannot be undone(y/[n]): y
Comprobamos cómo lo ha destruido utilizando la opción <list> -como en casos anteriores-
havoc@h100:~$ pfexec beadm list
BE Active Mountpoint Space Policy Created
-- ------ ---------- ----- ------ -------
HSeries - /mnt 532.16M static 2013-03-07 23:57
solaris - - 3.06M static 2011-04-16 04:06
solaris-1 NR / 103.83G static 2011-04-16 04:41
NOTA: Aunque al destruir un BE se nos avisa, aunque no está de más que lo recordemos: Esta acción no puede deshacerse
Montar un BE en un directorio
Hasta ahora, no hemos hecho más que crear y destruir BE, sin embargo, en sí eso no aporta nada, verdad ...
Es hora de montar nuestro nuevo BE y poder trabajar con él, para ello, deberemos utilizar la opción <mount> seguida del <nombre> y del <path de montaje>.
En nuestro caso el BE será "PreUpdate" y el path de montaje será "/tmp/preupdate" -al igual que sucede con el comando <mount> el path de montaje deberá existir-
havoc@h100:~$ pfexec mkdir /tmp/preupdate
havoc@h100:~$ pfexec beadm create PreUpdate
havoc@h100:~$ pfexec beadm mount PreUpdate /tmp/preupdate
havoc@h100:~$ pfexec beadm list
BE Active Mountpoint Space Policy Created
-- ------ ---------- ----- ------ -------
HSeries - /mnt 546.31M static 2013-03-07 23:57
PreUpdate - /tmp/preupdate 122.0K static 2013-03-08 10:28
solaris - - 3.06M static 2011-04-16 04:06
solaris-1 NR / 103.88G static 2011-04-16 04:41
Si nos situamos en el path de nuestro nuevo BE -/tmp/preupdate- veremos que contiene la estructura idéntica a nuestro "sistema online", realmente, hemos realizado un "snapshoot" del sistema -entraremos en más detalle en la segunda parte-
havoc@h100:~$ cd /tmp/preupdate
havoc@h100:/tmp/preupdate$ ls
bin cdrom devices export kernel media net platform root sbin tmp usr boot dev etc home lib mnt opt proc rpool system u01 var
Desmontar un BE
Para desmontar un BE simplemente deberemos utilizar la opción <umount> seguido del nombre del BE. Continuando con nuestro ejemplo,
havoc@h100:/$ pfexec beadm umount PreUpdate
havoc@h100:/$ pfexec beadm list
BE Active Mountpoint Space Policy Created
-- ------ ---------- ----- ------ -------
HSeries - /mnt 546.31M static 2013-03-07 23:57
PreUpdate - - 144.0K static 2013-03-08 10:28
solaris - - 3.06M static 2011-04-16 04:06
solaris-1 NR / 104.11G static 2011-04-16 04:41
Activar un BE
Una vez tenemos nuestro BE creado, podemos hacer que sea nuestro BE de arranque por defecto. Esto se llama "activar un BE". Para ello, utilizaremos la opción <activate> y el nombre del BE que queremos activar.
Continuando con nuestro ejemplo, queremos activar el BE "PreUpdate" para que la próxima vez que inicie el sistema sea con este BE.
havoc@h100:/$ pfexec beadm activate PreUpdate
havoc@h100:/$ pfexec beadm list
BE Active Mountpoint Space Policy Created
-- ------ ---------- ----- ------ -------
HSeries - /mnt 546.31M static 2013-03-07 23:57
PreUpdate R - 103.83G static 2013-03-08 10:28
solaris - - 3.06M static 2011-04-16 04:06
solaris-1 N / 204.15M static 2011-04-16 04:41
Fijaros en el valor de "Active" que ahora nuestro BE "PreUpdate" tiene una "R" -de Root Boot-. La "N" que aparece en el BE "solaris-1" indica que es el "actual"
Para volver a ponerlo sobre el actual, simplemente activamos el BE que cuente con la opción "Active=N", por ejemplo:
havoc@h100:/$ pfexec beadm activate solaris-1
havoc@h100:/$ pfexec beadm list
BE Active Mountpoint Space Policy Created
-- ------ ---------- ----- ------ -------
HSeries - /mnt 546.31M static 2013-03-07 23:57
PreUpdate - - 166.0K static 2013-03-08 10:28
solaris - - 3.06M static 2011-04-16 04:06
solaris-1 NR / 104.21G static 2011-04-16 04:41
Conclusiones
En esta primera parte, hemos sentado las bases para las siguientes entregas donde veremos realmente la potencia de esta funcionalidad.
Aunque aquí solo hemos expuesto algo muy sencillo, y en apariencia sin mucha utilidad, te aseguro que si dominas los BE estarás mucho más tranquilo con los Upgrades de sistemas de producción.