17117 Gestión Avanzada con OpenGnsys 1ramon/articulos/GestionOpengnsys-1.1.pdf · • Soporte para...

66
17117 Gestión Avanzada con OpenGnsys 17117 Gestión Avanzada con OpenGnsys 1.1 Pablo M. Bermudo Garay (pablombg ARROBA gmail.com) Ramón M. Gómez Labrador (ramongomez ARROBA us.es) Irina Gómez Gutiérrez (irinagomez ARROBA us.es) Mayo de 2017

Transcript of 17117 Gestión Avanzada con OpenGnsys 1ramon/articulos/GestionOpengnsys-1.1.pdf · • Soporte para...

17117 Gestión Avanzada con OpenGnsys

17117 Gestión Avanzada con OpenGnsys 1.1

Pablo M. Bermudo Garay(pablombg ARROBA gmail.com)Ramón M. Gómez Labrador

(ramongomez ARROBA us.es)Irina Gómez Gutiérrez(irinagomez ARROBA us.es)

Mayo de 2017

17117 Gestión Avanzada con OpenGnsys

Índice

• Introducción• Arquitectura• Instalación, configuración y gestión• El cliente OpenGnsys• API del motor de clonación• Creación de scripts personalizados• Creación de menús personalizados• Arranque desde Grub• API REST• Actualización y desinstalación

17117 Gestión Avanzada con OpenGnsys

Introducción (I)

• Proyecto interuniversitario promovido por el Grupo de Trabajo Docencia-Net de RedIRIS

• Flexibilidad para instalación de componentes• Clonación de diversos tipos de sistemas de

archivos con postconfiguración• Soporte para tablas de particiones MSDOS y GPT• Administración centralizada mediante interfaz web• Cliente gráfico con modos de ejecución para

usuario normal y administrador• Acceso por SSH a los clientes• API de funciones extensible

17117 Gestión Avanzada con OpenGnsys

17117 Gestión Avanzada con OpenGnsys

Introducción (II)

• Soporte experimental para imágenes diferenciales• Detección de inventario de hardware y software• Ejecución de órdenes en clientes enviadas desde

la consola web• Asistentes web que muestran las funciones que se

van a ejecutar en el cliente• Ejecución directa de funciones y scripts en el

cliente (modo administración)• Creación automática y personalizada de menús de

clientes• Internacionalización de los mensajes

17117 Gestión Avanzada con OpenGnsys

17117 Gestión Avanzada con OpenGnsys

Introducción (III)

Novedades versión 1.1.0:• API REST• Agentes de sistemas operativos (incluido macOS)• Repositorio común para varias UO• Cambio de repositorio durante la sesión• Cliente OpenGnsys de 64 bits• Exportar/importar base de datos• Mejoras en datos de configuración de equipos:

Porcentaje de uso del sistema de archivosAviso de imagen no actualizada

• Browser de cliente con reloj en barra de estado

17117 Gestión Avanzada con OpenGnsys

17117 Gestión Avanzada con OpenGnsys

Arquitectura (componentes)

17117 Gestión Avanzada con OpenGnsys

17117 Gestión Avanzada con OpenGnsys

Arquitectura (servicios)

Repo 1UA 2

Repo 2UA 2

Repo 1 UA 1

Consola Central

17117 Gestión Avanzada con OpenGnsys

17117 Gestión Avanzada con OpenGnsys

OpenGnsys Server(directorios)

/opt/opengnsys– bin - binarios y utilidades– client - exporta por Samba la estructura de

directorios del cliente– etc - ficheros de configuración del servidor– lib - librerías de las utilidades– log - registro principal de incidencias– sbin - binarios de servicios– tftpboot - ficheros de TFTP/PXE– www – páginas web consola de gestión

menus – menús personalizados (HTML o PHP)

17117 Gestión Avanzada con OpenGnsys

17117 Gestión Avanzada con OpenGnsys

OpenGnsys Repository (directorios)

/opt/opengnsys– bin - binarios y utilidades– etc - ficheros de configuración– images – almacén de imágenes (montar en un

sistema de archivos independiente)– log - registro principal de incidencias– sbin - binarios de servicios

17117 Gestión Avanzada con OpenGnsys

17117 Gestión Avanzada con OpenGnsys

OpenGnsys Client (directorios)

/opt/opengnsys– bin (ro) - binarios de las utilidades asociadas– cache – almacén de datos del disco local– etc (ro) - ficheros de configuración

• init (ro) – arranque del cliente OpenGnSys– images (user=ro, admin=rw) – almacén de

imágenes del repositorio– lib (ro) - librerías de las utilidades

• engine/bin (ro) - librerías de la API de clonación– log (rw) - registro principal de incidencias– scripts (ro) – scripts de ejecución de tareas

17117 Gestión Avanzada con OpenGnsys

17117 Gestión Avanzada con OpenGnsys

Relación entre componentes Samba

Repositorio Cliente

Recurso: ogclientDir: /opt/opengnsys/client

Dir: /opt/opengnsysPermisos: ro

Recurso: ogimagesDir: /opt/opengnsys/images

Dir: /opt/opengnsys/imagesPermisos: rw

Recurso: oglogDir: opt/opengnsys/log/clients

Dir: /opt/opengnsys/logPermisos: rw

Recurso: tftpbootDir: /opt/opengnsys/tftpboot

Dir: /opt/oglive/tftpbootPermisos: ro

• ro – solo lectura • rw – lectura y escritura

17117 Gestión Avanzada con OpenGnsys

17117 Gestión Avanzada con OpenGnsys

Ficheros de configuración• DHCP: /etc/dhcp/dhcpd.conf• TFTP/PXE: /opt/opengnsys/tftpboot/menu.lst/*• Samba (repositorio): /etc/samba/*• OpenGnsys

– Server: /opt/opengnsys/etc/ogAdmServer.cfg– Repository: /opt/opengnsys/etc/ogAdmRepo.cfg– Agent: /opt/opengnsys/etc/ogAdmAgent.cfg– Client: /opt/opengnsys/client/etc/ogAdmClient.cfg– Clientes instalados:

/opt/opengnsys/etc/ogliveinfo.json– Web Console: /opt/opengnsys/www/controlacceso.php– Servicios iniciados: /etc/default/opengnsys

17117 Gestión Avanzada con OpenGnsys

17117 Gestión Avanzada con OpenGnsys

Instalación en el curso

Instalar OpenGnsys en máquinas virtuales:• Servidor/repositorio unificado

– Distribución Ubuntu Server 16.04 LTS– OpenGnsys 1.1.0pre– Configuración de servicios

• Cliente modelo– Sistemas operativos instalados

• Cliente para restauración– Prácticas de distribución de disco– Restauración de sistemas de archivos

17117 Gestión Avanzada con OpenGnsys

17117 Gestión Avanzada con OpenGnsys

Instalación

• Descargar script de instalación (en desarrollo)http://opengnsys.es/svn/branches/version1.1/installer/opengnsys_installer.sh

• Ejecutar script de instalación

• Introducir parámetro de configuración:

– clave root de MySQL– usuario de la consola web– clave del usuario de consola– clave del usuario del cliente

sudo bash opengnsys_installer.sh

17117 Gestión Avanzada con OpenGnsys

Post-instalación

• MySQL (opcional):– Instalar PhpMyAdmin

• DHCP:– Añadir definición de clientes– Reiniciar el servicio

• PXE:– Verificar parámetros de arranque– Incluir cliente modelo en arranque modo “admin”

• Samba:– Cambiar clave de acceso

17117 Gestión Avanzada con OpenGnsys

Configuración inicial

• Revisar ficheros de configuración de OpenGnSys• Súper-administrador web (opcional):

– Definir unidades administrativas– Definir usuarios gestores para cada UA

• Gestor de Unidad Administrativa– Definir aulas y grupos de aulas– Incorporar clientes a aulas según el DHCP– Asignar repositorio por defecto– Crear perfil de hardware para cada modelo de

cliente

17117 Gestión Avanzada con OpenGnsys

Scripts de administración (I)

• setserveraddr – cambia la configuración de la dirección IP del servidor principal

sudo /opt/opengnsys/bin/setsmbpass

• setsmbpass – cambia la clave de acceso Samba y la clave de “root” para conexión SSH al cliente

sudo /opt/opengnsys/bin/setserveraddr Interfaz

• listclientmode, setclientmode – lista/asigna la plantilla de arranque de un cliente o de un aula

sudo /opt/opengnsys/bin/listclientmode Cliente|Aulasudo /opt/opengnsys/bin/setclientmode Plantilla Cliente|Aula Modo

17117 Gestión Avanzada con OpenGnsys

Scripts de administración (II)

• comparedhcpopengnsys – compara fichero de configuración de DHCP con la BD de OpenGnsys

sudo /opt/opengnsys/bin/comparemac

• comparemac – compara las direcciones MAC detectadas en la red con la BD de OpenGnsys

• registeredsoftware – lista el inventario de software asignado a una imagen del repositorio

sudo /opt/opengnsys/bin/comparedhcpopengnsyssudo DHCPFILE=Fich /opt/opengnsys/bin/comparedhcpopengnsys

sudo /opt/opengnsys/bin/registeredsoftware Imagen

17117 Gestión Avanzada con OpenGnsys

Gestionar clientes ogLive

• oglivecli – gestión de distribuciones ogLive que pueden ser enviadas por PXE al iniciar los clientes

sudo /opt/opengnsys/bin/oglivecli Comando [Opción]

• ogLive con Kernel 3.2 soporta arranque en caliente de Windows

• ogLive con último Kernel de 64 bits mejora el soporte de nuevos dispositivos y sistemas de archivos

17117 Gestión Avanzada con OpenGnsys

17117 Gestión Avanzada con OpenGnsys

Modos de ejecución

Modo administración• Escritura en repositorio• Browser completo• Servidor SSH local

Modo usuario• Lectura en repositorio• Browser simple• Servidor SSH local

Barra de direcciones

Salida de proceso y terminal

Barra de estado con reloj

MenúPestañas

Menú

Barra de estado con reloj

17117 Gestión Avanzada con OpenGnsys

17117 Gestión Avanzada con OpenGnsys

Arranque del cliente

PXE

Directo al gestor de arranque local

Directo al arranque del SO

Cliente completo con Browser en

modo usuario

Cliente completo con Browser en

modo admin.

17117 Gestión Avanzada con OpenGnsys

Arranque PXE

Asignación de plantillas de arranque PXE para los equipos del aula

Administración de las plantillas PXE desde la

sección de administrador de la

consola web

17117 Gestión Avanzada con OpenGnsys

Parámetros de plantillas PXEParámetro Descripciónquiet Mostrar menos información del arranque

vga=NNN Resolución de pantalla para el Browser

acpi=on, acpi=off, acpi=noapic

Activar, desactivar o elegir tipo de ahorro de energía

ogprotocol=smb,ogprotocol=local

Conexión con el servidor por Samba o arranque local en modo offline

ogactiveadmin=true,ogactiveadmin=false

Cliente con Browser en modo administrador o modo usuario

ogdebug=true,ogdebug=false

Modo depuración del arranque o arranque sin mensajes de depuración

ogupdateinitrd=true Copiar ficheros de inicio a la caché local

oglivedir=Directorio Cliente ogLive alternativo (bajo TFTP)

INFOHOST NO TOCAR, usado por la consola web

17117 Gestión Avanzada con OpenGnsys

Arranque desde Grub

• ogGrubInstallPartition – instala Grub en la partición con los datos sólo de dicha partición

ogGrubInstallMbr numdisk numpart [configurar] [parámetros]

• Nota: Si sólo tenemos Windows y sin caché, la configuración por defecto lo prepara para que lo arranquemos desde la partición con PXE

ogGrubInstallPartition numdisk numpart [configurar] [parámetros]

• ogGrubInstallMbr – instala Grub en el MBR con los datos de todos los sistemas operativos– Se puede instalar en caché

17117 Gestión Avanzada con OpenGnsys

Configuración Grub en MBR

• ogGrubDeleteEntry – borra una entrada ocultando una partición que no queremos utilizar

ogGrubHidePartitions numdisk numpart

ogGrubDeleteEntry numdisk numpart numpart_borrar

• ogGrubHidePartitions – incluye código para que al elegir una entrada de Grub oculte las particiones que no se inician

17117 Gestión Avanzada con OpenGnsys

Estructura del código

•Comandos del sistemaoperativo

•Scripts de operaciones: • Desarrollan operaciones completas• Funcionalidad íntegra sin capas superiores

•Scripts de interfaz web: • Objetivo: independencia entre capas (sin lógica)

•API del motor de Clonación: funciones específicas

de OpenGnsys

•Consola web: • Interfaz gráfico sencillo al usuario

17117 Gestión Avanzada con OpenGnsys

API del motor de clonación

• Escrita en funciones BASH• Documentación automática con Doxygen• Funciones agrupadas en librerías de propósito

común• Definición de tipos de datos propios• Definición de códigos y mensajes de error• Internacionalización de mensajes y errores

17117 Gestión Avanzada con OpenGnsys

Librerías de funciones

• Boot: arranque y postconfiguración de sistemas operativos

• Cache: gestión de caché de disco local• Disk: gestión de discos y particiones• File: gestión básica de ficheros y directorios• FileSystem: gestión de sistemas de archivos• Image: funciones de clonación y restauración• Inventory: recopilación de inventario• Net: gestión de conexión a la red• PostConf: postconfiguración de sistema operativo• Registry: gestión del registro de Windows• System: funciones básicas del sistema

17117 Gestión Avanzada con OpenGnsys

Documentación de la API• Información completa en

http://www.opengnsys.es/doxygen/

ogGetOsVersion help | int_ndisk int_nfilesysDevuelve la versión del sistema operativo instalado en un sistema de archivos

Parámetros:int_ndisk nº de orden del discoint_nfilsys nº de orden del sistema de archivos

Devuelve:OSType:OSVersionOSType = { Linux, Windows, MacOS, ... }

Excepciones:OG_ERR_FORMAT Formato incorrectoOG_ERR_NOTFOUND Disco o particion no corresponden con un dispositivoOG_ERR_PARTITION Tipo de partición desconocido o no se puede montar

17117 Gestión Avanzada con OpenGnsys

Tipos de datos simples

• Disco: número de orden de disco (>0)• Partición: número de orden de partición (>0)• Sistema de archivos: mnemónico identificador

del tipo de sistema de archivos• Tamaño: capacidad de disco, partición o

sistema de archivos (en KB)• Repositorio: mnemónico del almacén de datos

(local o remoto)• Camino: camino de un fichero relativo a su

sistema de archivos, a su repositorio o la caché

17117 Gestión Avanzada con OpenGnsys

Tipos de datos compuestos

• Identificador de partición: dupla de valores formada por disco y partición (2 parámetros)

1 1• Definición de partición: pareja de valores

formada por tipo de partición y tamaño, separados por ":" (1 parámetro compuesto)

NTFS:20000000• Camino completo: parámetro compuesto por

identificador de partición o repositorio y el camino relativo de un fichero (2 o 3 parámetros)

CACHE /windows/system321 1 /windows/system32

17117 Gestión Avanzada con OpenGnsys

Tipos de discos

• MSDOS: disco real con tabla de particiones MSDOS• GPT: disco real con tabla de particiones GPT• LVM: grupo de volúmenes (LVM)• ZPOOL: pool de volúmenes ZFS

17117 Gestión Avanzada con OpenGnsys

17117 Gestión Avanzada con OpenGnsys

Tipos de particionesTipo de partición

Tabla MSDOS Tabla GPT

Vacía o no definida EMPTY EMPTY

Caché de disco local CACHE CACHE

Extendida EXTENDED No usada

Arranque EFI EFI, BIOS-BOOT

Para GNU/Linux LINUX LINUX, LINUX-RESERV

Paginación Linux LINUX-SWAP LINUX-SWAP

Linux RAID y LVM LINUX-RAID, LINUX-LVM LINUX-RAID, LINUX-LVM

Para Windows NTFS, HNTFS,FAT32, FAT16, FAT12,HFAT32, HFAT16, HFAT12

WINDOWS, WIN-RESERV

Para macOS HFS HFS

Para FreeBSD FREEBSD FREEBSD, FREEBSD-BOOT

Para Solaris SOLARIS, SOLARIS-BOOT SOLARIS, SOLARIS-BOOT

Para Chrome OS CHROMEOS

17117 Gestión Avanzada con OpenGnsys

17117 Gestión Avanzada con OpenGnsys

Tipos de sistemas de archivos

• EMPTY: sistema de archivos no formateado• CACHE: caché de disco local• FAT12, FAT16, FAT32, EXFAT: FAT 12/16/32/64• NTFS: NTFS (Windows)• EXT2, EXT3, EXT4: extendida 2/3/4 (Linux)• REISERFS, REISER4: Reiser 3/4 (Linux)• BTRFS, JFS, XFS: transaccionales (Linux)• F2FS, NILFS2: con estructura de registro (Linux)• LINUX-SWAP: paginación para Linux (swap)• HFS, HFSPLUS: HFS/HFS+ (macOS)• UFS, ZFS: otros sistemas para Unix

17117 Gestión Avanzada con OpenGnsys

17117 Gestión Avanzada con OpenGnsys

Errores

• OG_ERR_FORMAT: formato de ejecución incorrecto• OG_ERR_NOTFOUND: fichero o dispositivo no

encontrado• OG_ERR_PARTITION: partición no reconocida o no se

puede montar• OG_ERR_FILESYS: sistema de archivos no accesible• OG_ERR_LOCKED: partición o fichero bloqueado• OG_ERR_IMAGE: error al crear o restaurar imagen• OG_ERR_NOTOS: sin sistema operativo o no iniciable• OG_ERR_NOTEXEC: programa o función no ejecutable• OG_ERR_OUTOFLIMIT: valor fuera de rango

17117 Gestión Avanzada con OpenGnsys

Personalización del motor de clonación

Parámetro DescripciónOGENGINECONFIGURATE Personalizar motor de clonación (booleano)

OGWINCHKDISK Comprobar disco tras restaurar Windows (booleano)

IMGREDUCE Reducir sistema de archivos antes de crear imagen (booleano)

OGSLEEP Tiempo de espera antes de apagado para notificar fin de operación (segundos)

RESTOREPROTOCOLNOTCACHE Protocolo para restaurar si no existe caché o si no hay espacio en ella (UNICAST, MULTICAST, NONE)

DEFAULTSPEED Velocidad de conexión por defecto (en Mb/s)

17117 Gestión Avanzada con OpenGnsys

• Fichero de configuración del motor de clonación:/opt/opengnsys/client/etc/engine.cfg

17117 Gestión Avanzada con OpenGnsys

Scripts de clonación• Distribución de scripts BASH de ejemplo para las

funciones más comunes• Ejercicios de personalización para el entorno

– Copia de archivos y directorios a sistemas de archivos locales

– Configuración y arranque de sistemas operativos

– Creación de imágenes de sistemas de archivos– Restauración de imágenes y modificación de

sistemas de archivos– Tareas programadas

17117 Gestión Avanzada con OpenGnsys

Plantilla de script#!/bin/bash# Comentarios

if [ $# -ne NºParámetros ]; then ogRaiseError $OG_ERR_FORMAT "Formato" exit $?fi

ogEcho [Fichero ...] “[Porcentaje] Mensaje”

Función || ogRaiseError Fichero ... $OG_ERR_CODIGO "Mensaje” || exit $?Función && exit (ogRaiseError Fichero ... $OG_ERR_CODIGO "Mensaje”; echo $?)Función || exit $?

VARIABLE=$(Función)Función

ogExecAndLog Fichero ... Función ogExecAndLog Fichero ... Función || exit $?

Comentarios y descripción

Bloque de control de parámetros

Mensaje de progresión

Ejecución con control

Ejecución normal

Ejecución con log

17117 Gestión Avanzada con OpenGnsys

Operación: particionado

Asistente de particionado

Particionado personalizado ejecutando funciones

Particionado personalizado con procedimientos

17117 Gestión Avanzada con OpenGnsys

Operación: formateado

Comando Particionar y Formatear

Formateado personalizado ejecutando funciones

Formateado personalizado con procedimientos

17117 Gestión Avanzada con OpenGnsys

La caché local

Partición 1Sistema de

archivos

Partición 2Sistema de

archivos

Partición 3Extendida Espacio

libre

Partición 4Cachélocal

• Se define por defecto en la partición 4 del disco 1• Se almacena al final del disco• Guarda copias de imágenes locales y del cargador

del cliente OpenGnsys• Funciones independientes (librería Cache)

TablaMSDOS

Partición 1Sistema de

archivos

Partición 2Sistema de

archivosEspacio

libre

Partición 4Cachélocal

TablaGPT

Part. 5Sist.

archiv.

Part.5 Part.6 P.7

Part. 3Sistema de

archivos

17117 Gestión Avanzada con OpenGnsys

17117 Gestión Avanzada con OpenGnsys

Arranque de cliente en caché

updateBootCache

• El cliente de OpenGnsys tiene tres partes: el kernel, el initrd y el segundo sistema de ficheros

• updateBootCache – Sitúa el kernel y el initrd de OpenGnsys en la caché local.

• ogGrubAddOgclient – incluye como entrada por defecto el inicio de cliente de OpenGnsys

ogGrubAddOgclient numdisk numpart [timeout]

• Si ogupdateinitrd=true al iniciar, actualiza si es necesario. Si no existen, no los copia.

• ogGrubAddOgclient – incluye como entrada por defecto el inicio de cliente de OpenGnsys

17117 Gestión Avanzada con OpenGnsys

Operación: inventario

Inventario de hardware del cliente

Inventario de particiones y sistemas operativos instalados

Inventario de aplicaciones instaladas en los sistemas operativos

17117 Gestión Avanzada con OpenGnsys

Operación: crear imagen

Crear imagen en caché local o en repositorio desde la consola web

Crear imagen en caché local o en repositorio desde el Browser en modo admin.

Soporta personalización de operaciones antes y después de la creación

17117 Gestión Avanzada con OpenGnsys

Operación: crear imagen

Si existe el script personalizado de creación de imágenes; Ejecutar script de creación (createImageCustom).Si no; Si existe la imagen; Hacer copia de seguridad (renombrar ficheros).

Comprobar errores en el sistema de archivos. Borrar ficheros temporales y de paginación. Reducir el sistema de archivos al tamaño de los datos, si es necesario.

Crear la imagen.

Extender el sistema de archivos a su tamaño original.

17117 Gestión Avanzada con OpenGnsys

Personalizar script de crear imagen

• Editar plantilla createImageCustom.template– Añadir código para realizar control de errores de los parámetros

de entrada (recomendado)– Añadir código para el proceso previo antes de la creación de la

imagen en el equipo modelo (opcional)– Sustituir, si se desea, la llamada al proceso estándar de creación

de imagen por código personalizado– Añadir código para el proceso posterior tras la creación de la

imagen (opcional)

• Renombrar plantilla createImageCustom.template por script createImageCustom

• Añadir permiso de ejecución a createImageCustom

17117 Gestión Avanzada con OpenGnsys

Operación: desplegar imagen

Desplegar desde caché a partición local

Desplegar desde partición remota

Desplegar desde repositorioSoporta personalización de operaciones de postconfiguracion tras la restauración

17117 Gestión Avanzada con OpenGnsys

Operación: desplegar imagen

Si se va a restaurar desde caché local y el repositorio tiene contenido nuevo; Actualizar la caché local con los nuevos datos del repositorio

Si existe el script personalizado de restauración de imágenes; Ejecutar script de creación (restoreImageCustom).Si no; Ejecutar script genérico de creación.

Si existe el script personalizado de postconfiguración; Ejecutar script de postconfiguración (configureOsCustom).Si no; Ejecutar script generico de postconfiguración.

17117 Gestión Avanzada con OpenGnsys

Personalizar script de restaurar imagen

• Editar plantilla restoreImageCustom.template– Añadir código para realizar control de errores de los parámetros

de entrada (recomendado)– Añadir código para el proceso previo antes de la restauración de

la imagen en los equipos (opcional)– Sustituir, si se desea, la llamada al proceso estándar de

restauración de imagen por código personalizado– Editar la plantilla configureOsCustom para añadir el código

personalizado para el proceso de postconfiguración de los clientes (no incluir aquí dicho código)

• Renombrar plantilla restoreImageCustom.template por script restoreImageCustom

• Añadir permiso de ejecución a restoreImageCustom

17117 Gestión Avanzada con OpenGnsys

Personalizar script de postconfiguración

• Editar plantilla configureOsCustom.template– Añadir código para realizar control de errores de los parámetros

de entrada (recomendado)– Añadir código personalizado de postconfiguración atendiendo al

tipo de sistema operativo y/o tipo de sistema de ficheros (puede llamarse al script genérico configureOs, pero puede afectar al orden de aplicación de los comandos)

• Renombrar plantilla configureOsCustom.template por script configureOsCustom

• Añadir permiso de ejecución a configureOsCustom

17117 Gestión Avanzada con OpenGnsys

Tipos de imágenes

Imagendiferencial

Imagen básica Sist. archivos

Libre

Imagen monolíticaSist. archivos

Comparar

En pruebas

17117 Gestión Avanzada con OpenGnsys

Protocolos de clonación

Unicast

Multicast

Bittorrent (necesita caché)

17117 Gestión Avanzada con OpenGnsys

Modos de clonación

Clonación directa desde cliente sin usar repositorio

Clonación personalizada desde el repositorio

Clonación básica desde el repositorio

17117 Gestión Avanzada con OpenGnsys

Eliminar imagen

• sudo /opt/opengnsys/bin/deleteimage [-b|-r] Imagen

En repositorio• Comando de la consola

web (solo si repositorio en el mismo servidor)

• Mediante script

En caché local• Usando comando de la

consola web

17117 Gestión Avanzada con OpenGnsys

Operación: arrancar cliente

Arranque genérico:•iniciar cliente OpenGnsys•solicitar al servidor comandos pendientes•cargar menú asignado

Script de arranque personalizado:•para un cliente específico•para todos los clientes de un aula

#!/bin/bash#/opt/opengnsys/client/etc/preinit/10.1.30.13.shif [[ "$(date +"%w")" =~ [06] ]]; then if [ -n "$(ogGetOsVersion 1 2)" ]; then bootOs 1 2 fifi$OGETC/init/default.sh

17117 Gestión Avanzada con OpenGnsys

Menú de clienteMenú automático creado a partir de los procedimientos definidos en la consola web

Menú personalizado basado en página web con

ejecución de comandos

17117 Gestión Avanzada con OpenGnsys

Menú personalizado• Menú de arranque de cliente creado en

HTML con URLs modificadas:– Ejecución de una orden o script

command:Comando– Ejecución con confirmación

commandwithconfirmation:Comando

<html><body><h1>Men&uacute; de opciones</h1><ul><li><a href="command:bootOs 1 1">Arrancar Windows 10</a></li> <li><a href="commandwithconfirmation:restoreImage REPO win10 1 1”> Restaurar Windows 10</a></li> <li><a href="command:poweroff">Apagar equipo</a></li></ul></body></html>

17117 Gestión Avanzada con OpenGnsys

OGAgent: Nuevo agente de sistema operativo

● Comunicación con el servidor a través de un API RESThttp://opengnsys.es/wiki/ApiRest#RutasdefinidasenOGAgent

● Acepta los comandos del cliente anterior (Windows, Linux o macOS)○ status: encendido, apagado, login y logout○ poweroff○ reboot

● Nuevos comandos○ logoff: Lanzar un proceso para cerrar la sesión del usuario matando

todos sus procesos. ○ script: Lanzar un subproceso para ejecutar un script en el cliente

(codificado en Base64). Distingue modo sistema o modo usuario (por defecto)

○ popup: Lanzar un proceso para mostrar una ventana emergente con un mensaje en la sesión del usuario activo (la ventana se mostrará como mucho durante 1 minuto).

17117 Gestión Avanzada con OpenGnsys

● Se instala en el equipo modelo (puede requerir instalar dependencias).

● Los paquetes de instalación están el la consola en las propiedades del equipo.

● Script de despliegue modifica el archivo de configuración con la IP del servidor.

OGAgent: Instalación y uso

17117 Gestión Avanzada con OpenGnsys

OGAgent: Configuración

C:\Program Files (x86)\OGAgent\cfg\ogagent.cfgC:\Program Files\OGAgent\cfg\ogagent.cfg

/usr/share/OGAgent/cfg/ogagent.cfg

/Applications/OGAgnet.app/cfg/ogagent.cfg

[opengnsys]master=https://IPServidor/opengnsys/rest

17117 Gestión Avanzada con OpenGnsys

API REST

• URL base de la API REST: https://Servidor/opengnsys/rest

• Formato de transferencia de datos en JSON• Solo acepta conexiones HTTPS• Clave de acceso a la API en cabecera• Control de errores de comunicación• Definición inicial de la API REST con

información de la estructura y propiedades de los objetos web

17117 Gestión Avanzada con OpenGnsys

Documentación API REST

17117 Gestión Avanzada con OpenGnsys

Actualización

• Ejecutar script de actualización

• Seguir las instrucciones

sudo bash /opt/opengnsys/lib/opengnsys_update.sh

El script solo actualiza el código con la última versión del servidor OpenGnsys, no modifica la BD ni las imágenes

17117 Gestión Avanzada con OpenGnsys

Desinstalación

• Ejecutar script de desinstalación

• Seguir las instrucciones

sudo bash /opt/opengnsys/lib/opengnsys_uninstall.sh

El script no elimina ni desconfigura paquetes del sistema operativo, ni borra el directorio de imágenes

17117 Gestión Avanzada con OpenGnsys

Colaborar

• Web del Proyecto OpenGnsys: http://www.opengnsys.es/ – Documentación (wiki)– Repositorio de código– Gestión de incidencias– Foros de discusión

• Redes sociales– @OpenGnsys en Twitter– Proyecto OpenGnSys en LinkedIn

17117 Gestión Avanzada con OpenGnsys

OpenGnsys es un proyecto libre y abierto con licencia GNU GPLv3+ (excepto software de terceros) y está aprobado en el Directorio de Software Libre de la FSF

Licencia

El presente curso se oferta dentro del Plan de Formación para el personal informático de la Universidad de Sevilla para el año 2017 y toda su documentación asociada está bajo licencia Creative Commons con reconocimiento 4.0 o superior(http://creativecommons.org/licenses/by/4.0/deed.es)