Máquina virtual
En informática, una máquina virtual es un software que simula un sistema de computación y puede ejecutar programas como si fuese una computadora real. Este software en un principio fue definido como "un duplicado eficiente y aislado de una máquina física". La acepción del término actualmente incluye a máquinas virtuales que no tienen ninguna equivalencia directa con ningún hardware real.
Una característica esencial de las máquinas virtuales es que los procesos que ejecutan están limitados por los recursos y abstracciones proporcionados por ellas. Estos procesos no pueden escaparse de esta "computadora virtual".
Uno de los usos domésticos más extendidos de las máquinas virtuales es ejecutar sistemas operativos para "probarlos". De esta forma podemos ejecutar un sistema operativo que queramos probar (GNU/Linux, por ejemplo) desde nuestro sistema operativo habitual (Mac OS X por ejemplo) sin necesidad de instalarlo directamente en nuestra computadora y sin miedo a que se desconfigure el sistema operativo primario.
Hipervisor
Las máquinas virtuales son software huésped ejecutado sobre un software especial llamado Hipervisor o VMM (Virtual Machine Monitor). Esta VMM crea una capa de abstracción del hardware de la máquina física (host) y se la ofrece al sistema operativo de la máquina virtual.[1]
La capa de software VMM maneja, gestiona y arbitra los cuatro recursos principales de una computadora (CPU, Memoria, Dispositivos Periféricos y Conexiones de Red). Así podrá repartir dinámicamente estos recursos entre todas las máquinas virtuales definidas en el computador central. Esto hace que se puedan tener varios ordenadores virtuales ejecutándose en el mismo ordenador físico.
Tipos de máquinas virtuales
Las máquinas virtuales se pueden clasificar en dos grandes categorías según su funcionalidad y su grado de equivalencia a una verdadera máquina.
- Máquinas virtuales de sistema (en inglés System Virtual Machine)
- Máquinas virtuales de proceso (en inglés Process Virtual Machine)
Máquinas virtuales de sistema
Las máquinas virtuales de sistema, también llamadas máquinas virtuales de hardware son el tipo de máquina virtual que se usa en la virtualización de hardware. Este tipo de virtualización permite a una máquina física subyacente multiplicarse en varias máquinas virtuales, cada una ejecutando su propio sistema operativo. A la capa de software que permite la virtualización se la llama monitor de máquina virtual o hipervisor. Un monitor de máquina virtual puede ejecutarse o bien directamente sobre el hardware o bien sobre un sistema operativo ("host operating system").
Máquinas virtuales de proceso
Una máquina virtual de proceso, a veces llamada "máquina virtual de aplicación" o PVM (siglas del inglés Process-level Virtual Machine), se ejecuta como un proceso normal dentro de un sistema operativo sirviendo de enlace entre un lenguaje de programación y el sistema operativo, realizando una interpretación u otra técnica de enlace entre fuente y código máquina. La máquina se inicia automáticamente cuando se lanza el proceso que se desea ejecutar o manualmente para ejecutar código interactivamente y se detiene para cuando este finaliza o se le pide terminar al entorno de ejecución. Su objetivo es el de proporcionar un entorno de ejecución independiente de la plataforma de hardware y del sistema operativo, que oculte los detalles de la plataforma subyacente y permita que un programa se ejecute siempre de la misma forma sobre cualquier plataforma.
El ejemplo más conocido actualmente de este tipo de máquina virtual es la máquina virtual de Java que interpreta un código intermedio entre Java y código máquina. Otra máquina virtual muy conocida es la del entorno .Net de Microsoft que se llama "Common Language Runtime".
Otros ejemplos de este tipo de máquinas virtuales son las usadas por herramientas de ofuscación de código con virtualización, como por ejemplo VMProtect, Code Virtualizer y Themida.[2]
Inconvenientes de las máquinas virtuales
Uno de los inconvenientes de las máquinas virtuales es que agregan gran complejidad al sistema en tiempo de ejecución. Esto tiene como efecto la ralentización del sistema, es decir, el programa no alcanzará la misma velocidad de ejecución que si se instalase directamente en el sistema operativo "anfitrión" (host) o directamente sobre la plataforma de hardware. Sin embargo, a menudo la flexibilidad que ofrecen compensa esta pérdida de eficiencia.
Lista de hardware con soporte para virtualización
- AMD-V (anteriormente llamado Pacifica)
- ARM TrustZone
- Boston Circuits gCore (grid-on-chip) con núcleos 16 ARC 750D y módulo de virtualización de hardware Time-machine.
- Freescale PowerPC MPC8572 y MPC8641D
- IBM System/370, System/390 y mainframes ZSeries
- Intel VT (anteriormente llamado Vanderpool)
- SPARC de Sun Microsystems
Lista de máquinas virtuales
Descripciones ampliadas para aplicaciones de virtualización seleccionadas
Los productos de software siguientes son capaces de virtualizar el hardware de modo que varios sistemas operativos puedan compartirlo.
- Adeos es una Capa de Abstracción de Hardware que puede ser cargado como un módulo del núcleo Linux. Esto permite la carga de un núcleo en tiempo real como módulo, al mismo tiempo que se ejecuta Linux, pero con una prioridad más alta.
- Denali utiliza la paravirtualización para proporcionar máquinas virtuales de alto rendimiento sobre procesadores x86.
- utiliza el software libre L4 (micronúcleo) como un hypervisor para proporcionar una solución de virtualización de alto rendimiento para sistemas embebidos.
- OpenVZ para Linux
- Parallels
- QEMU puede emular una variedad de arquitecturas de CPU sobre muchas plataformas distintas.
- Virtual Iron
Véase también
Referencias
- (html). INCIBE. 9 de enero de 2020. Archivado desde el original el 9 de enero de 2020. Consultado el 9 de enero de 2020. «El dispositivo físico que hará las veces de anfitrión se conoce como host, este será el encargado de alojar los diferentes recursos virtualizados conocidos como máquinas virtuales o VM, por sus siglas en inglés «Virtual Machine». Para gestionar las máquinas virtuales es necesario instalar en el host una herramienta específica denominada software de virtualización, que puede ser de dos tipos: Nativo. En este caso el software de virtualización también actuará como sistema operativo ejecutándose directamente sobre el hardware del dispositivo anfitrión o host. Hosted o alojado. El software de virtualización se ejecuta sobre el sistema operativo del host.»
- VMGuards: A Novel Virtual Machine Based Code Protection System with VM Security as the First Class Design Concern. Zhanyong Tang et ali. mdpi.com. 12 de Mayo de 2018
Enlaces externos
- Virtualización, ParaVirtualizacion, FullVirtualizacion Todas las Plataformas
- (Universidad Nacional de Educación a Distancia (España))
- (en inglés)
- Máquinas virtuales en Github (en inglés)
- J. L. Medina - vExpert 2009. «Be Virtual, My Friend - Blog de virtualizacion en Castellano».