Soluciones robustas de virtualizaci´on con software libremvidal/docs/virt_es.pdf · An˜aden una...

20
216 II.—Estudio histórico de la época del Fuero sarios que el rey mandaba a las otras cortes, francesas e inglesas en particular, recibían sus qui- taciones de los diezmos que el Rey recibía de estos puertos guipuzcoanos (6). Por último, las minas y el comercio del hierro, que parecen ya funcionar intensamen- te, forman otro elemento esencial de la prosperidad y desarrollo de estos puertos guipuzcoa- nos, algunos de los cuales: Oyarzun, Orio y Ciboure, aparecen especializados en la exporta- ción de dicho mineral, lo que traduce su importancia en la economía portuaria de la región. Y mientras el comercio de telas, utensilios, alimentos y otras mercaderías están en manos tanto de vascos como de castellanos y extranjeros, en cambio, el comercio del hierro aparece monopolizado por los vascos exclusivamente, si juzgamos por los apellidos de los mercaderes. Lo que no deja de tener su interés a la hora de calibrar la importancia del comercio en rela- ción con la importancia del capital necesario al desarrollo del comercio. Este soporte de ca- pital imprescindible al comercio existía y en gran parte estaba en manos de vascos. II El segundo aditivo que quisiera incluir se refiere a un documento del Cartulario de la antigua abadía de Santillana del Mar, fechado en 870 y relativo a la Iglesia de Suances. A mi entender, este documento del año 870 confirma lo que dije sobre la existencia de un camino primitivo por la costa, que se cerró sobre todo a causa de las incursiones normandas, tras lo cual, y para evitar los rodeos que debían darse «per devia Alavae», Sancho el Mayor abrió el suyo, además de las razones económicas ya invocadas. Este documento, como digo, confirma la existencia de un camino de la costa ya que al lanzar, según la fórmula consagrada en esta clase de documentos, el anatema contra los que no acaten la concesión de las tierras de Suances a la Iglesia de Santillana y se alcen contra ella, el autor del privilegio enumera a todos aquellos a quienes les era posible alzarse contra esta concesión, y entre estos cita textualmente: «Sive sit unus, sive plures, seu sit presbiter, dia- conus, monacus, advena, incola, rapacius peregrinus,... (7). Si nos referimos a Cicerón (y sabiendo que Incola indica al «compatriota, indígena, nativo»), y a su frase: «Ne in nostra patria peregrini atque advenae esse videamur» (de Or., I, 249), vemos que Advena servía para indicar al «extrangero residente o domiciliado», y que Peregrinus indicaba al «extrangero de paso». Una primera conclusión que se puede sacar es la siguiente: En el año 870, por Suan- ces y por Santillana del Mar existía este paso de extranjeros, algunos de los cuales se que- daban a residir. Y la segunda conclusión, no menos importante es que al calificar a una parte de esos extranjeros, a los que no se quedaban, de Rapaces, es decir, «ladrones que pillaban y asolaban», el autor del documento hace referencia sin duda a los Normandos que desde prin- cipios del siglo IX asolaban las costas del Cantábrico, ya que para los sarracenos no hubiera empleado esta fórmula de Rapacius peregrinus. Estas dos conclusiones permiten afirmar aún que un camino de la costa existió para ir a Santiago desde el siglo XI, y que los asaltos normandos de los siglos IX y X cerraron este camino, sobre todo a partir del año 960. Para paliar esto, y por razones económicas, San- cho el Mayor abrió el suyo. (6) Op. Cit. Apéndice documental, T. III, pgs. XXIII, XXIV. Real carta n.° 107, pg. LXIX. (7) Cartulario de Santillana del Mar, Madrid 1912, pg. 3, 4, doc. N.° III.

Transcript of Soluciones robustas de virtualizaci´on con software libremvidal/docs/virt_es.pdf · An˜aden una...

Que es la virtualizacionTipos

Soluciones robustas de virtualizacioncon software libre

Morfeo Formacion

Miguel Vidal, Jose Castro

{mvidal,jfcastro}@libresoft.esGSyC/Libresoft – URJC

1 de junio de 2010

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

c© 2010 Miguel Vidal, Jose Castro.Some rights reserved. This work is licensed under a Creative Commons

Attribution-Share Alike 3.0 License, available athttp://creativecommons.org/licenses/by-sa/3.0/

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Agenda

Parte 1: Que es la virtualizacion

Parte 2: Tipos de virtualizacion

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Que es la virtualizacion

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Definicion

Es la combinacion de hardware y software que permite a una unicamaquina comportarse como si fueran varias maquinas.

Esto implica hacer que un recurso fısico (como un servidor, unsistema operativo o un dispositivo de almacenamiento) funcionecomo multiples recursos logicos.Tambien se conoce a la virtualizacion como la abstraccion derecursos de una maquina.

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Orıgenes

El termino “virtualizacion” fue acunado en los anos 60 parareferirse a una maquina virtual (tambien conocido como“pseudo maquina”).

En los 70 se desarrollaron varios sistemas de maquinasvirtuales basadas en IBM: el CP-40, el CP-67, el famosoVM/370...

Un componente llamado Virtual Machine Monitor (VMM)corrıa directamente sobre el hardware “real”.

Se podıan crear varias maquinas virtuales y cada instanciaejecutaba su propio sistema operativo.

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Extensiones de virtualizacion para x86

Desde 2005, Intel y AMD han anadido soporte hardware parala virtualizacion.

Intel Virtualization Technology (VT) codename Vanderpool

AMD Virtualization (AMD-V) codename Pacifica

Anaden una funcionalidad especıfica para permitir a loshipervisores un rendimiento mayor en virtualizacion completa.

La virtualizacion completa es mas sencilla de implementar.

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Hipervisores (I)

Los Virtual Machine Monitors (aka hipervisores) permiten quediferentes sistemas operativos, tareas y configuraciones desoftware coexistan en una misma maquina fısica.

El hipervisor abstrae los recursos fısicos de la maquinaanfitriona para las distintas “maquinas virtuales”.

Los hipervisores garantizan un nivel de aislamiento entre losinvitados.

Los hipervisores tambien proporcionan una interfaz unica parael hardware.

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Hipervisores (y II)

Hay dos clases de hipervisores:

Tipo 1 (o “nativo”, “bare-metal”): el hipervisor es una capaentre el hardware y el sistema operativo. Al sistema operativodel huesped se le llama Dominio de Control y corre sobre elhipervisor.

Tipo 2 (o “hosted”): el hipervisor es una capa de softwareque corre sobre el sistema operativo del huesped.

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Razones para virtualizar

Permite el aislamiento de aplicaciones y usuarios sobre lamisma maquina para que no se interfieran entre sı.

Entorno de servidor: fusiona varios servidores o servicios enuna misma maquina (email, web, dns, etc.).

Ejecutar diferentes sistemas operativos o software especıficopara un tipo de CPU.

Entornos de test faciles y seguros: entornos de depuracion,desarrollo y aislamiento para estudiar virus, gusanos, etc.

Facil desarrollo de software utilizando aplicaciones de softwarevirtuales. Desde la perspectiva del negocio, es posible reducirlos costes totales de propiedad (TCO).

Minimiza el consumo de energıa y la infraestructura derefrigeracion en los datacenters.

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Conceptos basicos

Al sistema operativo que ejecuta el software de virtualizacionse le conoce como anfitrion (host).

El anfitrion controla el hardware real.

Al sistema operativo virtualizado se le conoce como invitado ohuesped (guest).

Hay varios invitados en un mismo anfitrion.Los invitados no deben interferir entre sı ni con el anfitrion.

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Conceptos de virtualizacion

Al software de virtualizacion se le llama:

Hipervisor.Virtual Machine Manager or VMM.

El VMM o hipervisor corre como parte del sistema operativodel anfitrion (o es el anfitrion)

A una instancia del hardware virtualizado se la conoce comoMaquina Virtual o VM.

Los sistemas operativos huespedes corren dentro de una VM.

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Virtualizacion y Cloud Computing

El Cloud Computing no es lo mismo que la gestion de lavirtualizacion.

Pero es cierto que la mayorıa de los entornos de CloudComputing hacen uso de la virtualizacion.

La gestion del hardware esta totalmente abstraıda.

La capacidad de la infraestructura en Cloud Computing eselastica (tanto para crecer como para menguar).

Las nubes son recursos hardware convertidos en un “pool derecursos”.

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Tipos de virtualizacion

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Tipos de virtualizacion

El objetivo es crear la impresion de tener hardware separado en ununico sistema fısico. Hay 4 maneras de hacer esto:

1 Emulacion

2 Virtualizacion completa

3 Paravirtualizacion

4 Virtualizacion a nivel de sistema operativo

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Emulacion

La maquina virtual simula el hardware completo.

Huespedes sin modificar de diferentes arquitecturas hardwarecorren dentro de una VM.

Utilizado para crear nuevos sistemas operativos o microcodifopara nuevos disenos de hardware antes de que el hardwareeste disponible fısicamente.

Ventajas: Simular hardware que no esta fısicamentedisponible.

Desventajas: Bajo rendimiento y baja densidad (coste alto)

Ejemplo: basilisk II, un emulador de Mac (m68k) para x86.

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Emulacion: grafico

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Virtualizacion completa

Parecido a la emulacion, anfitriones sin modificar.

Se diferencia de la emulacion en que los sistemas operativos avirtualizar estan disenados para correr en la mismaarquitectura que el anfitrion.

Combinado con hardware: CMT, Intel VT, AMD-V, estasCPUs controlan el acceso a instrucciones de virtualizacion.

Ventajas: Flexibilidad, ejecuta diferentes sistemas operativosde distintos fabricantes.

Desventajas: No se pueden emular otras arquitecturas.Rendimiento.

Ejemplos: VirtualBox, KVM, Xen + Intel VT.

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Virtualizacion completa: grafico

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Paravirtualizacion

El hipervisor ofrece una version modificada del anfitrion.

La VM ofrecida tiene la misma arquitectura que el anfitrion.

Ventajas: Rendimiento (ligero y rapido), escalabilidad yfacilidad de gestion; fuerte aislamiento; permite virtualizar sinnecesidad de CPUs especiales.

Desventajas: Para la misma arquitectura. Requiere modificarel SO del invitado.

Ejemplo: Xen con CPUs estandar.

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Paravirtualizacion: grafico

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Virtualizacion a nivel de SO

La virtualizacion se hace con la imagen tradicional del SO (sinhipervisor).

El SO esta modificado para permitir multiples procesos endiferentes espacios de usuario aislados unos de otros.

Ventajas: Rapido, capa ligera de virtualizacion. Rendimientocercano al nativo. Densidad.

Desventajas: Es difıcil implementar el aislamiento fuerte.

Ejemplos: Linux VServers, jaulas de FreeBSD,zonas/contenedores de OpenSolaris

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Otros tipos de virtualizacion

Virtualizacion de bibliotecas: biblioteca Wine (subconjuntode la API de Win32 para poder ejecutar aplicacionesWindows)

Virtualizacion de aplicacion: entorno de ejecucion virtual(con una API para la ejecucion en diferentes plataformas).Ejemplo: Java Virtual Machine.

Virtualizacion de almacenamiento: se provee de un poolde discos para el almacenamiento. Ejemplos: LVMs en Linuxy ZFS en OpenSolaris.

Virtualizacion de escritorio: se implementa el escritoriocomo servicio. Ejemplo: SunVDI.

Virtualizacion de red: la tecnologıa Crossbow (nativa deOpenSolaris 2009.06) permite crear switches e interfaces dered virtuales.

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Xen: Caracterısticas

Xen utiliza paravirtualizacion, lo que significa que el sistemaoperativo huesped tiene que estar modificado para usar elhipervisor.

Tambien permite virtualizacion asistida por hardware (IntelVTo AMD-V) para huespedes sin modificar: es un desarrollosignificativo ya que permite que sistemas operativospropietarios (como Microsoft Windows) puedan servirtualizados.

Es capaz de hacer migracion de maquinas virtuales.

Sobre arquitectura x86, el codigo de un kernel Xen anfitrionejecuta en el anillo de proteccion 0 mientras que los dominioshuespedes ejecutan en el anillo 1 o anillo 3 (anillos: dominiosde proteccion jerarquica)

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Xen: Prestaciones

Independencia entre los sistemas virtualizados. Se puedereiniciar y crear independientemente.

Uso mejorado del hardware: balanceo de recursos. Unamaquina virtual puede hacer uso de los recursos que noutilizan las otras maquinas virtuales.

Backup sencillo. Solo con copiar la maquina virtual se puedelevantar en un nuevo servidor. Xen tambien permite lamigracion en caliente, siendo muy flexible y minimizando eltiempo de recuperacion en caso de fallo.

Se pueden modificar parametros como la RAM, el numero deCPUs y el espacio en disco para cada necesidad especıfica decada maquina virtual.

Entornos de prueba y desarrollo: multiples maquinas virtualesen un unico servidor fısico para probar y desarrollar.

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Como funciona

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Kernel-based Virtual Machine (KVM)

KVM es un infraestructura de virtualizacion exclusiva delkernel Linux.

Virtualizacion nativa (completa) utilizando los micros Intel VTy AMD-V.

Estructura modular: la primera version fue incluida en Linux2.6.20 (febrero 2007).

Una amplia variedad de sistemas operativos funcionanvirtualizados con KVM: Linux, BSD, Solaris, Windows,ReactOS y existe una version parcheada para poder ejecutarMacOS X.

No requiere emulacion: un programa en espacio de usuario(Qemu) utiliza la interfaz /dev/kvm para configurar el espaciode direcciones de las VMs hospedadas.

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Proyectos xVM OpenSolaris

VirtualBox: VMs para todo. Diferentes plataformas.

xVM server: Xen en Opensolaris 2009.06.

Dominios logicos (LDOMs): Hipervisor tipo 1, “completo”,para plataformas SPARC.

Zonas: virtualizacion ligera para OpenSolaris.

Otros: Sun XVM Ops Center, Sun xVM VDI.

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Contenedores y zonas

Tipo de virtualizacion que ejecuta varias instancias del mismosistema operativo (y el mismo kernel).

Zona Global y Zonas Locales: no se puede acceder al sistemade ficheros global (un chroot mejorado).

Sin hipervisor ni hardware especıfico para virtualizacion.

Despliegue y administracion muy simple: zonecfg y zoneadm.

x86: con soporte para “branding”.

Desde 2005 forma parte de Solaris 10 (y OpenSolaris).

Parecido a las jaulas de FreeBSD, OpenVZ (contenedoresLinux) o Linux-VServer.

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Virtualizacion con LDOMs

“Virtualizacion completa”, basada en un hipervisor tipo 1.

Requiere CPUs especiales (Chip Multithreading = CMT).

Cada dominio es una maquina virtual completa con unconjunto configurable de recursos.

Los sistemas operativos que corren dentro del Dominio Logicopueden iniciarse, pararse y reiniciarse de forma independiente.

OS base: Solaris 10 / Opensolaris 2009.06

OS de maquina virtual: Solaris 10, Opensolaris 2009.06, SparcLinux y otros que soporten estan arquitectura.

Pero por ahora, tan solo SunOS esta soportado.

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Chip Multithreading (CMT)

UltraSparc T1 / T2.

Multithread. Un thread es similar a una CPU.

Ejemplo: T1 tiene 8 cores con 4 threads/core.

SSL directamente soportado por el hardware (1 MAU/core).

LDOMs pueden asignar cores a las VMs.

El hipervisor ejecuta en el firmware del servidor.

Free/Open Hardware: http://www.opensparc.net

Sun Fire T / Enterprise T / Blade T servers.

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre

Que es la virtualizacionTipos

Referencias

Amit Singh “An Introduction to Virtualization” (2004):http://www.kernelthread.com/publications/virtualization/

Comparison of platform virtual machines:http://en.wikipedia.org/wiki/Comparison of platform virtual machines

Jeanne Matthews et al. Running Xen. Prentice Hall, 2008(Chapter 1: “Background and Virtualization Basics”)

Miguel Vidal, Jose Castro Soluciones robustas de virtualizacion con software libre