Virtualización
La virtualización es la provisión de un conjunto de recursos informáticos o su combinación lógica, abstraída de la implementación del hardware y, al mismo tiempo, proporciona un aislamiento lógico entre sí de los procesos informáticos que se ejecutan en el mismo recurso físico.
Un ejemplo del uso de la virtualización es la capacidad de ejecutar múltiples sistemas operativos en una computadora: mientras que cada una de las instancias de dichos sistemas operativos invitados funciona con su propio conjunto de recursos lógicos (procesador, RAM, dispositivos de almacenamiento), cuya provisión desde un grupo común disponible a nivel de hardware es controlado por el sistema operativo host- hipervisor . Las redes de datos , las redes de almacenamiento , la plataforma y el software de aplicación ( emulación )
también se pueden virtualizar .
Tipos de virtualización
Equipo
Sistemas operativos
- virtualización de software
- Difusión dinámica; en la traducción dinámica (binaria), el hipervisor intercepta los comandos problemáticos del sistema operativo invitado .
- Paravirtualización: el sistema operativo interactúa con el programa hipervisor, que le proporciona una API invitada , en lugar de utilizar recursos como la tabla de páginas de memoria directamente.
- Virtualización de hardware : virtualización con soporte para una arquitectura de procesador especial. A diferencia de la virtualización de software, esta técnica permite el uso de sistemas invitados aislados administrados directamente por el hipervisor.
- Virtualización a nivel de sistema operativo : ejecutar múltiples instancias de espacio de usuario dentro de un solo sistema operativo. Los ejemplos serían Docker , LXC
Software
- Virtualización de aplicaciones (también virtualización de escritorio): ejecutar aplicaciones individuales en un entorno separado del sistema operativo principal. Este concepto está estrechamente relacionado con las aplicaciones portátiles. Algunos ejemplos son: Citrix XenApp , Microsoft App-V .
- Virtualización de servicios: emular el comportamiento de los componentes del sistema necesarios para ejecutar una aplicación con fines de depuración y prueba ( Aplicación en prueba ) . En lugar de virtualizar componentes completos, esta tecnología virtualiza solo las partes necesarias. Ejemplos: SoapUI , Parasoft Virtualize .
Memoria
- La virtualización de memoria es la combinación de RAM de varios recursos en una sola matriz. Implementaciones: Oracle Coherence , GigaSpaces XAP .
- La memoria virtual es el aislamiento del espacio de direcciones de una aplicación del espacio de direcciones completo. Se utiliza en todos los sistemas operativos modernos.
Sistemas de almacenamiento
- Virtualización de almacenamiento, que representa un conjunto de medios físicos como un solo medio físico.
- Virtualización de bloques
- virtualización de archivos
- Un sistema de archivos distribuido es cualquier sistema de archivos que permite el acceso a archivos desde múltiples dispositivos utilizando una red informática.
- Un sistema de archivos virtual es una capa de abstracción sobre una implementación concreta de un sistema de archivos. El propósito de VFS es brindar un acceso uniforme para las aplicaciones cliente a diferentes tipos de sistemas de archivos.
- Un hipervisor de almacenamiento esun programa que gestiona la virtualización del espacio de almacenamiento y puede combinar diferentes espacios físicos en un solo arreglo lógico [1] .
- Virtualización de dispositivos de almacenamiento: virtualización de un disco duro (disco lógico) o disco óptico (por ejemplo, DAEMON Tools ).
Base de datos
- La virtualización de datos es la representación de datos en forma abstracta, independientemente de los sistemas de almacenamiento y gestión de datos subyacentes, así como de su estructura. Es un enfoque para unificar datos de múltiples fuentes al mismo nivel para que las aplicaciones, las herramientas de informes y los usuarios finales puedan acceder a los datos sin necesidad de conocer los detalles de las fuentes, ubicaciones y estructuras de datos originales. [2]
Red
- La virtualización de redes es el proceso de combinar recursos de red de hardware y software en una única red virtual.
- Externo, conectando muchas redes en una virtual.
- Interno, creando una red virtual entre contenedores de software dentro del mismo sistema.
- Una red privada virtual es la provisión de una o más conexiones de red a través de otra red.
Virtualización del sistema operativo
Para la virtualización de los sistemas operativos se utilizan una serie de enfoques que, según el tipo de implementación, se dividen en software y hardware [3] .
Virtualización de software
Traducción dinámica
Con la traducción dinámica ( binaria ), los comandos problemáticos del sistema operativo huésped son interceptados por el hipervisor . Una vez que estos comandos se reemplazan por otros seguros, el control vuelve al sistema invitado.
Paravirtualización
La paravirtualización es una técnica de virtualización en la que se preparan sistemas operativos invitados para ejecutarse en un entorno virtualizado, para lo cual se modifica ligeramente su kernel. El sistema operativo interactúa con el programa del hipervisor, que le proporciona una API invitada , en lugar de utilizar directamente recursos como la tabla de páginas de memoria.
El método de paravirtualización permite lograr un mayor rendimiento que el método de traducción dinámica.
El método de paravirtualización es aplicable solo si los sistemas operativos invitados tienen códigos fuente abiertos que pueden modificarse según la licencia, o el hipervisor y el sistema operativo invitado son desarrollados por el mismo fabricante, teniendo en cuenta la posibilidad de paravirtualización del sistema invitado ( aunque siempre que debajo del hipervisor pueda haber un hipervisor de nivel inferior en ejecución, entonces la paravirtualización del propio hipervisor).
El término apareció por primera vez en el proyecto Denali .
Virtualización integrada
ventajas:
- Compartir recursos entre varios sistemas operativos invitados (directorios, impresoras, etc.).
- Interfaz conveniente para ventanas de aplicaciones de diferentes sistemas (ventanas de aplicaciones superpuestas, la misma minimización de ventanas que en el sistema host).
- Cuando se ajusta a la plataforma de hardware, el rendimiento difiere poco del sistema operativo original. Cambio rápido entre sistemas (menos de un segundo).
- Un procedimiento simple para actualizar el sistema operativo invitado.
- Virtualización bidireccional (las aplicaciones de un sistema se ejecutan en otro y viceversa).
Implementaciones:
Virtualización de hardware
ventajas:
- Simplifique el desarrollo de plataformas de software de virtualización proporcionando interfaces de administración basadas en hardware y soporte para invitados virtualizados. Esto reduce la complejidad y el tiempo para el desarrollo de sistemas de virtualización.
- Capacidad para aumentar el rendimiento de las plataformas de virtualización. Los sistemas invitados virtuales son administrados directamente por una pequeña capa de middleware de software, el hipervisor, lo que resulta en un aumento del rendimiento.
- La seguridad mejora, es posible cambiar entre varias plataformas de virtualización independientes en ejecución a nivel de hardware. Cada una de las máquinas virtuales puede funcionar de forma independiente, en su propio espacio de recursos de hardware, completamente aisladas entre sí. Esto le permite eliminar las pérdidas de rendimiento para mantener la plataforma de host y aumentar la seguridad.
- El sistema huésped no está ligado a la arquitectura de la plataforma anfitriona ni a la implementación de la plataforma de virtualización. La tecnología de virtualización de hardware permite ejecutar invitados de 64 bits en sistemas de host de 32 bits (con entornos de virtualización de host de 32 bits).
Tecnología:
Plataformas que utilizan virtualización de hardware:
Virtualización de contenedores
La virtualización de contenedores (virtualización a nivel del sistema operativo) le permite ejecutar sistemas virtuales aislados en un solo host físico, pero no le permite ejecutar sistemas operativos con kernels que son diferentes del tipo de kernel del sistema operativo subyacente. Con este enfoque, no hay una capa de hipervisor separada, sino que el propio sistema operativo host es responsable de compartir los recursos de hardware entre varios sistemas invitados (contenedores) y garantiza su independencia. Algunas implementaciones son FreeBSD Jail (2000), Virtuozzo Containers (2000), Solaris Containers (2005), Linux-VServer , OpenVZ (2005), LXC (2008), iCore Virtual Accounts (2008), Docker (2013).
Aplicaciones de la virtualización
Máquinas virtuales
Una máquina virtual es un entorno que se presenta al sistema operativo "invitado" como hardware. Sin embargo, en realidad es un entorno de software emulado por el software del sistema host. Esta emulación debe ser lo suficientemente robusta para permitir que los controladores invitados funcionen de manera estable. Cuando se utiliza la paravirtualización, la máquina virtual no emula el hardware, sino que ofrece el uso de una API especial .
Ejemplos de aplicación:
- Laboratorios de pruebas y capacitación: las pruebas en máquinas virtuales son útiles para probar aplicaciones que afectan la configuración del sistema operativo, como las aplicaciones de instalación. Debido a la facilidad de implementación de las máquinas virtuales, a menudo se utilizan para entrenar nuevos productos y tecnologías.
- Distribución de software preinstalado: muchos desarrolladores de software crean imágenes de máquinas virtuales listas para usar con productos preinstalados y las proporcionan de forma gratuita o comercial. Estos servicios son proporcionados por Vmware VMTN o Parallels PTN .
Virtualización de recursos
La virtualización de recursos (o uso compartido de recursos , ing. partición ) se puede representar como la división de un nodo físico en varias partes, cada una de las cuales es visible para el propietario como un servidor separado. No es una tecnología de máquina virtual, se implementa a nivel del kernel del sistema operativo.
En los sistemas con un hipervisor de tipo 2 , tanto el sistema operativo invitado como el del hipervisor consumen recursos físicos y requieren licencias por separado. Los servidores virtuales que funcionan en el nivel del kernel del sistema operativo casi nunca pierden velocidad, lo que hace posible ejecutar cientos de servidores virtuales en un servidor físico que no requieren licencias adicionales.
El espacio en disco o el ancho de banda de la red se divide en una serie de componentes más pequeños y, por lo tanto, es más fácil usar recursos del mismo tipo.
Por ejemplo, la implementación del uso compartido de recursos se puede atribuir a OpenSolaris Network Virtualization and Resource Control (Project Crossbow), que le permite crear varias interfaces de red virtuales basadas en una física.
La agregación, distribución o adición de muchos recursos en grandes recursos, o agrupación de recursos. Por ejemplo, los sistemas multiprocesador simétrico combinan varios procesadores; Los administradores de discos y RAID combinan muchos discos en un disco lógico grande; RAID y redes utilizan múltiples canales agrupados para aparecer como un solo canal de banda ancha. En el nivel meta, los clústeres de computadoras hacen todo lo anterior. A veces, esto también incluye sistemas de archivos de red extraídos de los almacenes de datos en los que se construyen, por ejemplo, Vmware VMFS , Solaris / OpenSolaris ZFS , NetApp WAFL .
Virtualización de aplicaciones
La virtualización de aplicaciones es el proceso de usar una aplicación que ha pasado de requerir instalación en el sistema operativo a no requerir instalación (solo se requiere para ejecutar). Para la virtualización de aplicaciones, el software del virtualizador determina cuándo se instala la aplicación que se está virtualizando, qué componentes del sistema operativo son necesarios y los emula. Así, se crea el entorno especializado necesario para esta aplicación virtualizada en particular y, por lo tanto, se asegura el aislamiento de la operación de esta aplicación. Para crear una aplicación virtual, lo virtualizado se coloca en un contenedor , generalmente diseñado como una carpeta. Cuando se lanza una aplicación virtual, se lanza la aplicación que se está virtualizando y el contenedor que es su entorno de trabajo. El tiempo de ejecución se inicia y expone los recursos locales creados previamente, que incluyen las claves de registro, los archivos y otros componentes necesarios para iniciar y ejecutar la aplicación. Este entorno virtual actúa como una capa entre la aplicación y el sistema operativo, evitando así conflictos entre aplicaciones. La virtualización de aplicaciones la proporcionan, por ejemplo, los programas Citrix XenApp [6] , SoftGrid [7] y VMware ThinApp .
ventajas:
- aislamiento de la ejecución de la aplicación: ausencia de incompatibilidades y conflictos;
- cada vez en su forma original: el registro no está abarrotado, no hay archivos de configuración; es necesario para el servidor;
- menores costes de recursos en comparación con la emulación de todo el sistema operativo.
Notas
- ↑ Documento técnico de Enterprise Systems Group, página 5 (enlace no disponible) . Libro blanco de Enterprise Strategy Group escrito y publicado el 20 de agosto de 2011 por Mark Peters. Archivado desde el original el 30 de marzo de 2012. (indefinido)
- ↑ dataWerks: soluciones innovadoras de virtualización de datos que ofrecen un enfoque radicalmente nuevo para brindar información comercial en tiempo real ( enlace inaccesible) . www.datawerks.com. Consultado el 12 de diciembre de 2017. Archivado desde el original el 12 de diciembre de 2017.
- ↑ Natalia Elmanova, Sergey Pakhomov Virtual Machines 2007. Archivado el 7 de octubre de 2011 en Wayback Machine ComputerPress 9'2007
- ↑ www.bluestacks.com/technology.html . Consultado el 31 de mayo de 2011. Archivado desde el original el 28 de mayo de 2011. (indefinido)
- ↑ Capturas de pantalla de BlueStacks (enlace descendente)
- ↑ Citrix News (www.citrixnews.ru) - 30/09/2008 (enlace inaccesible) . Consultado el 20 de junio de 2011. Archivado desde el original el 2 de febrero de 2014. (indefinido)
- ^ John Saville - Aplicaciones virtuales de SoftGrid. - 25.12.07 . Consultado el 13 de junio de 2010. Archivado desde el original el 19 de septiembre de 2010. (indefinido)
Enlaces
- Descripción general de los métodos, arquitecturas e implementaciones de virtualización (Linux) , www.ibm.com
- centro de virtualización , microsoft
- Virtualización de servidores. Neil McAllister , InfoMundo, 2007
- Virtualización de servidores de arquitectura estándar. Leonid Chernyak , Sistemas abiertos, 2008
- Alternativas a los líderes en el canal 2009 , 17 de agosto de 2009
- Tecnologías de virtualización de hardware , ixbt.com, 22 de mayo de 2007
- Espirales de virtualización de hardware. Alexander Alexandrov , Sistemas abiertos
- Virtualización arriesgada. Sergey Chekmasov , Revista "Director del Servicio de Información", No. 03, 2014