ACII - Livro WP
Transcrição
ACII - Livro WP
104 VirtualizaÅÉo VirtualizaÅÇo x86 Na computaÅÉo, o software de virtualizaÅÇo de x86 com emulaÅÉo de processador e hardware x86. Um "convidado" ou "virtual" OS pode funcionar como um processo em um "hospedeiro" ou "fàsica" do sistema com pouca ou nenhuma modificaÅÉo para o sistema operacional convidado. Uma mÑquina virtual (VM) á um ambiente criado por um virtualizador (como o VirtualBox). Clientes executam sistemas operacionais em mÑquinas virtuais. O cenÑrio a seguir ilustra o tàpica virtualizaÅÉo x86 desktop: í Um PC desktop padrÉo (a mÑquina fàsica hospedeira) á executado a 32-bit sistema operacional Linux Ubuntu. í A "VMware Player para Linux" [1] á executado no sistema. í A compilaÅÉo padrÉo do Microsoft Windows XP (o sistema convidado) á instalado e executado no "VMware Player para Linux" como uma mÑquina virtual x86. í Os usuÑrios vãem um desktop normal do Windows XP dentro da janela do aplicativo VMware Player com nenhuma instalaÅÉo ou hardware dedicado para a mÑquina virtual. í Os usuÑrios podem iniciar e parar a mÑquina virtual na vontade de usÑ-lo como um computador fàsico executando um OS com acesso a hardware, rede local e ë Internet. í A mÑquina virtual aparece para a mÑquina hospedeira do sistema operacional como um aplicativo nativo que criar e gerenciar uma coleÅÉo de arquivos no disco ràgido do hospedeiro e usa a memÄria RAM da mÑquina hospedeira quando estÑ em execuÅÉo. Esse aplicativo nativo, um programa Linux, neste cenÑrio, aÅÇes de entrada e saàda sÉo exibidas na Ñrea de trabalho virtual. Tàcnicas de Software VMware introduziu o primeiro produto de virtualizaÅÉo de x86 em 8 de Fevereiro de 1999. O "VMware Virtual Platform", foi baseado em pesquisas anteriores de fundadores da VMware na Universidade de Stanford. VMware arquivou para uma patente sobre suas tácnicas em Outubro de 1998, e recebeu Patente 6.397.242 [2] em 28 de Maio de 2002. Software de virtualizaÅÉo VMware e similares para a famàlia de processador x86 deve empregar tácnicas de traduÅÉo binÑria para interceptar e virtualizar a execuÅÉo de determinadas instruÅÇes. Estas tácnicas incorrer em alguma sobrecarga de desempenho em comparaÅÉo com uma VM em execuÅÉo em uma arquitetura nativa virtualizadora (como o IBM System/370 ou Motorola MC68020). Microsoft oferece trãs opÅÇes de produtos baseado virtualizaÅÉo x86 no Windows: Microsoft Virtual PC e Microsoft Virtual Server, baseado na tecnologia adquirida da Connectix e Hyper-V,mais soluÅÉo empresarial avanÅada. SoluÅÇes em cÄdigo aberto incluir QEMU, Kernel-based Virtual Machine (em inglãs: KVM) e VirtualBox. Os sistemas de investigaÅÉo Denali, L4 e Xen fornecem alto desempenho de virtualizaÅÉo de x86 atravás da implementaÅÉo de uma mÑquina virtual que difere do hardware primario. Esta abordagem, conhecida como paravirtualizaÅÉo, envolve portar sistemas operacionais para rodar em mÑquina virtual resultante, que nÉo implementar as partes do conjunto de instruÅÇes x86 reais que sÉo difàceis de virtualizar. A partir da versÉo 3.0 Xen suporta a virtualizaÅÉo completa com um sistema operacional convidado nÉo modificado. Isso pressupÇe que o sistema hospedeiro suporta virtualizaÅÉo assistida por hardware (tais como Intel VT ou AMD-V). VirtualizaÅÉo x86 105 Suporte de Hardware A arquitetura do processador x86, inicialmente, nÉo cumprir o "Formal Requirements for Virtualizable Third Generation Architectures", uma especificaÅÉo para a virtualizaÅÉo criado em 1974 por Gerald J. Popek e Robert P. Goldberg. Assim, os desenvolvedores acharam difàcil implementar uma plataforma de mÑquina virtual na arquitetura x86, sem sobrecarga significativa na mÑquina hospedeira. Em 2005 e 2006, Intel e AMD (trabalho independente) resolveu este problema criando novas extensÇes "Processadoras" para a arquitetura x86. Embora a aplicaÅÉo efectiva das extensÇes do processador diferem entre AMD e Intel, tanto alcanÅar o mesmo objetivo. Ambos permitem um hypervisor da mÑquina virtual para executar um sistema operacional modificado, sem incorrer em penalidades de desempenho significativo de emulaÅÉo. AMD VirtualizaÅÇo (AMD-V) AMD mercados de virtualizaÅÉo extensÇes para arquitetura 64-bit x86 como AMD Virtualization, abreviado AMD-V. î ainda referida como "Pacifica", o processador AMD codenome interno do projeto pelo manual de usuÑrio Xen (http://bits.xensource.com/Xen/docs/user.pdf). Em 23 de maio de 2006, a AMD lanÅou o Athlon 64 ( "Orleans"), o Athlon 64 X2 ( "Windsor") e o Athlon 64 FX ( "Windsor") como o primeiro processador AMD para suportar esta tecnologia. AMD-V tambám possui a capacidade Athlon 64 e Athlon 64 X2 famàlia de processadores com "F" ou "G" no soquete AM2 (nÉo o soquete 939), Turion 64 X2 e Opteron de 2nd geraÅÉo [3] e 3rd-geraÅÉo [4] , Phenom e os processadores Phenom II. Processadores Apenas Sempron exceto Sable e Huron nÉo incluem suporte para processadores AMD-V. AMD Phenom Matriz da CPU ComeÅando com a linha Barcelona, AMD Opteron CPUs virtualizadoras uma tecnologia de hardware chamado Rapid Virtualization Indexing, posteriormente adaptado pela Extended Page Tables(EPT). Tecnologia de VirtualizaÅÇo da Intel para o x86 (Intel VT-x) Anteriormente denominados "Vanderpool", VT-x representa a tecnologia de virtualizaÅÉo da Intel para a plataforma x86. Intel inclui Extended Page Tables (EPT), [5] uma tecnologia de virtualizaÅÉo page-table [6] na arquitetura Nehalem. [7] [8] A partir de 2009 nem todos os recentes processadores Intel suportam VT-x - A Intel usa o recurso para o seu segmento de mercado. [9] Para uma completa lista e actualizada consulte o site da Intel. [10] Os seguintes processadores Intel inclui suporte para VT-x: [11] VirtualizaÅÉo x86 í Pentium 4 662 e 672 í Pentium Extreme Edition 955 e 965 (e nÉo Pentium 4 Extreme Edition com HT) í Pentium D 920-960 exceto 945, 935, 925, 915 í Core Duo T2300, T2400, T2500, T2600, T2700 (Yonah) í Core 2 Duo E6300, E6400, E6320, E6420, E6540, E6550, E6700, E6750, E6850 (Conroe) í Core 2 Duo E5400, E7600, E8200, E8300, E8400, E8500, E8600 e algumas versÇes do E7400 e E7500 (Wolfdale) í Mobile Core 2 Duo T5500, T5600, T6670, T7100, Intel Core i7 CPU (Bloomfield) T7200, T7250, T7300, T7400, T7500, T7600, T7600G, T7700, T7800, U7500, L7200, L7300, L7400, L7500, L7700, U7500, U7600, U7700 (Merom) í Mobile Core 2 Duo SU9300, SU9400, SU9600, SL9300, SL9380, SL9400, SL9600, SP9300, SP9400, SP9600, P7370, P7570, P8400, P8600, P8700, P8800, P9500, P9600, P9700, T8100, T8300, T9300, T9400, T9500, T9550, T9600, T9800, T9900 (Penryn) í Core 2 Quad Q6600, Q6700 (Kentsfield) í Core 2 Quad Q8400, Q8400S, Q9300, Q9400, Q9400S, Q9450, Q9550, Q9550S, Q9650 e algumas versÇes do Q8300 (Yorkfield) í Core 2 Extreme X6800 ( Conroe XE ) í Core 2 Extreme QX6700, QX6800, QX6850 (Kentsfield XE) í Core 2 Extreme QX9650, QX9770, QX9775 (Yorkfield XE) í Xeon 3300 e +, 5000, 7000 series í Atom Z520, Z530, Z540, Z550 (Silverthorne) í Todos os processadores Intel Core i7 í Todos os processadores Intel Core i5 í Pentium Dual-Core E6300, E6500 e algumas versÇes do E5300 e E5400* [12] í Celeron E3200, E3300, E3400 (que serÑ lanÅado em 2010) Nota: Se nÉo tiver certeza se um processador Intel suporta Intel VT-x ou nÉo, verificar o Intel Processor Spec Finder [13] para obter informaÅÇes oficiais. Importante: Mesmo que alguns modelos parecem suportar Intel VT, nem todas as CPUs do mesmo modelo suportam. Exemplo: Intel Core 2 Duo T5500 parece suportar Intel VT [14], mas dos quatro modelos deste processador, [15] apenas um (SL9U8 [16]) suporta Intel VT. IOMMU Uma entrada/saàda da unidade de gerenciamento de memÄria (IOMMU) permite que as mÑquinas virtuais hospedeiras usem diretamente os dispositivos perifáricos, tais como Ethernet, placas aceleradors grÑficas e controladores de disco ràgido, atravás da DMA e remapeamento de interrupÅÇes. Tanto a AMD e a Intel lanÅaram especificaÅÇes: í A especificaÅÉo da AMD, "AMD-Vi" (anteriormente apenas IOMMU) í "Intel Virtualization Technology for Directed I/O" (VT-d) 106 VirtualizaÅÉo x86 Uma nota aos convidados de 64-bit Pode-se executar um 64-bits em um 32-bit OS anfitriÉo se o processador subjacente á executado em modo de 64 bits e suporta as extensÇes de virtualizaÅÉo necessÑrias. Nem todas as plataformas suportam isso. VirtualizaÅÇo de recursos de ativaÅÇo Intel VT-x caracteràstica necessÑria de ativaÅÉo na BIOS antes dos aplicativos fazerem uso dele. A maioria dos fabricantes de computador e placa-mÉe/BIOS/chipset o suporte esta desabilitado por padrÉo, mas basta ativar estÑ opÅÉo. Software usando AMD-V e/ou Intel VT O seguinte software condicionalmente faz uso de recursos de tecnologia de virtualizaÅÉo: í Kernel-based Virtual Machine(em inglãs: KVM) - um mÄdulo de Linux e o hypervisor. Ele suporta ambas as arquiteturas (AMD-V e VT-x) e requer uma delas. Suporta os clientes em tempo real. í VirtualBox roda em Windows, FreeBSD, Linux, Mac OS X e Solaris. Ele oferece suporte a Intel VT e AMD-V.[17] í Xen - um sistema operacional separado e independente, estruturada com o Xen hypervisor como a camada mais baixa e mais privilegiadas. Ele oferece suporte a Intel VT e AMD-V. í Blue Pill (prova de conceito de malware) í VMware ESX Server - tambám conhecido como vSphere. Produto de virtualizaÅÉo da VMware suporta Intel VT e AMD-V.[18] í Hyper-V - Hyper-V - a plataforma da Microsoft/Hypervisor que á executado no Windows Server 2008. Ele requer Intel VT ou AMD-V.[19] í LynxSecure - Secure MILS Hypervisor da LynuxWorks [20]. Suporta Intel VT-x e VT-d. í Microsoft Virtual Server (tambám com a marca Microsoft Virtual PC ou o Virtual PC com Windows) - Virtual Server 2005 R2 SP1 oferece suporte a virtualizaÅÉo assistida por hardware.[21] [22] í Oracle VM - Oracle VM Server á (licenÅa GPL) usa o Xen hypervisor, enquanto que o Oracle VM Manager á de cÄdigo fechado.[23] í Bochs á um emulador multiplataforma da plataforma x86. Isso quer dizer que ele pode executar SO's compilados para a plataforma x86.[24] í Parallels Workstation e Parallels Desktop para Mac - hypervisor leve com suporte a Intel VT-x e AMD-V . Requer suporte de hardware para executar mÑquinas virtuais de 64 bits. í Parallels Server - Enterprise versÉo do Parallels Workstation e Desktop para Mac. IrÑ suporte a IOMMU Intel VT-d. Requer suporte de hardware para executar mÑquinas virtuais de 64 bits. í Padded Cell - tecnologia de mÑquina virtual da Green Hills Software [25] hospedados na INTEGRITY em tempo real do sistema operacional. Suporta ambas as arquiteturas. í Real-Time Systems [26] RTS Real-Time Hypervisor para x86. í Sun xVM - xVM Server, baseado no Xen em x64. í Virtual Iron - suporta ambas as arquiteturas. í VirtualLogix [27] - suporta ambas as arquiteturas. í VMware Workstation, VMware Fusion, VMware Server Å a partir de 2009 , as versÇes recentes suportam ambas as arquiteturas.[28] í VMware Server - Exige suporte de hardware para executar 64-bit mÑquinas virtuais. í TenAsys [29] Virtualization Platform EVM para Windows. í Windows Virtual PC 7 [30] - (a partir de 2009 versÉo mais recente do Microsoft Virtual PC, rodando no Windows 7) e XP Mode [31] (Windows da mÑquina virtual XP rodando dentro do Windows 7). 107 VirtualizaÅÉo x86 í acontis technologies [32] baseadas em x86 RTOSVisor que estÑ disponàvel como Type1 e Real-Time Type2 Hypervisor, como Type2 nÉo exigir o Intel VT ou AMD-V e tambám suporta os processadores single core.[33] í Wind River Hypervisor [34] fornece virtualizaÅÉo em tempo real para sistemas embarcados utilizando Intel VT. Convidados de 64 bits Em algumas plataformas, á possàvel executar um cliente de 64 bits em um 32-bit OS hospedeiro se o processador subjacente á executado no modo de 64 bits e suporta as extensÇes de virtualizaÅÉo necessÑria.[35] Exemplo cenÉrios de virtualizaÅÇo x86 Executando uma ou mais aplicaÅÇes que nÉo sÉo suportados pelo sistema operacional hospedeiro Uma mÑquina virtual rodando o sistema operacional convidado exigido poderia permitir que as aplicaÅÇes desejadas para ser executado, sem alterar o sistema operacional hospedeiro. AvaliaÅÉo de um sistema operacional alternativo O novo sistema operacional pode ser executado dentro de uma VM, sem alterar o sistema operacional hospedeiro. A virtualizaÅÉo de servidores Måltiplos servidores virtuais poderÉo ser executados em um ånico servidor fàsico, a fim de aproveitar melhor os recursos de hardware do servidor fàsico. Duplicando ambientes especàficos Uma mÑquina virtual pode, dependendo do software de virtualizaÅÉo utilizado, ser repetido e instalado em vÑrias mÑquinas. Criando um ambiente protegido Se um convidado OS rodando em uma mÑquina virtual torna-se infectado com malware o sistema operacional do hospedeiro, a exposiÅÉo ao risco pode ser limitado, dependendo da configuraÅÉo do software de virtualizaÅÉo. Veja tambàm í VirtualizaÅÉo de Desenvolvimento í í í í í í í í MÑquina virtual A comparaÅÉo da plataforma de mÑquinas virtuais ComparaÅÉo da aplicaÅÉo de mÑquinas virtuais Emulador VirtualizaÅÉo assistida por hardware VirtualizaÅÉo de rede ParavirtualizaÅÉo VirtualizaÅÉo de nàvel de sistema operacional 108 VirtualizaÅÉo x86 Referencias [1] http:/ / www. vmware. com/ products/ player [2] http:/ / www. google. com/ patents?vid=6397242|US [3] http:/ / www. amd. com/ us-en/ Processors/ ProductInformation/ 0,,30_118_8796_8806~111165,00. html#111166 What are the main differences between Second-Generation AMD Opteron processors and first-generation AMD Opteron processors? [4] http:/ / www. amd. com/ us-en/ Processors/ ProductInformation/ 0,,30_118_8796_8806~119722,00. html#119726 What virtualization enhancements do Third-Generation AMD Opteron processors feature? [5] Neiger, Gil; A. Santoni, F. Leung, D. Rodgers, R. Uhlig. " Intel Virtualization Technology: Hardware Support for Efficient Processor Virtualization (http:/ / download. intel. com/ technology/ itj/ 2006/ v10i3/ v10-i3-art01. pdf)". Intel Technology Journal 10 (3): 167Ä178. Intel. DOI: 10.1535/itj.1003.01 (http:/ / dx. doi. org/ 10. 1535/ itj. 1003. 01). [6] Gillespie, Matt (2007-11-12). Best Practices for Paravirtualization Enhancements from Intel Virtualization Technology: EPT and VT-d (http:/ / software. intel. com/ en-us/ articles/ best-practices-for-paravirtualization-enhancements-from-intel-virtualization-technology-ept-and-vt-d). Intel Software Network. Intel. PÑgina visitada em 2008-07-06. [7] First the Tick, Now the Tock: Next Generation Intel Microarchitecture (Nehalem) (http:/ / www. intel. com/ pressroom/ archive/ reference/ whitepaper_Nehalem. pdf) (application/pdf). Intel. PÑgina visitada em 2008-07-06. [8] Technology Brief: Intel Microarchitecture Nehalem Virtualization Technology (http:/ / download. intel. com/ business/ resources/ briefs/ xeon5500/ xeon_5500_virtualization. pdf) (application/pdf). Intel (2009-03-25). PÑgina visitada em 2009-11-03. [9] http:/ / arstechnica. com/ microsoft/ news/ 2009/ 05/ r2e-microsoft-intel-goof-up-windows-7s-xp-mode. ars [10] http:/ / ark. intel. com/ VTList. aspx [11] Intel Processor Number Details (http:/ / www. intel. com/ products/ processor_number/ chart/ index. htm). Intel. Intel (2007-12-03). PÑgina visitada em 2008-10-03. [12] http:/ / ark. intel. com/ VTList. aspx [13] http:/ / processorfinder. intel. com/ [14] http:/ / ark. intel. com/ Product. aspx?id=27253 [15] http:/ / processorfinder. intel. com/ List. aspx?ParentRadio=All& ProcFam=0& SearchKey=t5500 [16] http:/ / processorfinder. intel. com/ details. aspx?sSpec=SL9U8 [17] VirtualBox architecture (http:/ / www. virtualbox. org/ wiki/ VirtualBox_architecture). InnoTek. [18] http:/ / www. vmware. com/ products/ vsphere/ [19] http:/ / www. microsoft. com/ windowsserver2008/ en/ us/ hyperv-faq. aspx#SetupandRequirements and http:/ / videos. techielife. com/ windows-server-2008-presentation-virtualization/ video-online/ 2008/ 11/ 28 [20] http:/ / www. lynuxworks. com/ virtualization/ hypervisor. php [21] Virtual Server 2005 R2 SP1 Beta 1 download link and availability details (http:/ / blogs. technet. com/ jhoward/ archive/ 2006/ 04/ 28/ 426703. aspx). technet.com (2006-04-28). [22] Virtual Server 2005 R2 SP1 - beta 2 feature listing (http:/ / www. microsoft. com/ windowsserversystem/ virtualserver/ downloads/ servicepack. mspx). Microsoft. [23] Oracle VM Technical Information (http:/ / www. oracle. com/ technologies/ virtualization/ technical. html) [24] Site Oficial do Bochs (http:/ / bochs. sourceforge. net/ ) [25] http:/ / www. ghs. com/ products/ rtos/ integrity_pc. html [26] http:/ / www. real-time-systems. com/ real-time_hypervisor/ index. php [27] http:/ / www. virtuallogix. com/ [28] Hardware and firmware requirements for 64bit guest operating systems (http:/ / kb. vmware. com/ selfservice/ microsites/ search. do?language=en_US& cmd=displayKC& externalId=1003945). VMware, Inc. (2009-12-17). PÑgina visitada em 2009-12-30. [29] http:/ / www. tenasys. com/ evm/ [30] http:/ / www. microsoft. com/ windows/ virtual-pc/ [31] http:/ / www. microsoft. com/ windows/ virtual-pc/ get-started. aspx [32] http:/ / www. acontis. de/ eng [33] AT-RTOSVisor: Real-time Hypervisor Plattform (http:/ / www. acontis. com/ produkte/ at-rtosvisor/ index. php), acontis technologies GmbH, retrieved on 2009-11-21 [34] http:/ / www. windriver. com/ products/ hypervisor/ [35] VMware Server FAQs: What does 64-bit operating system support mean? (http:/ / www. vmware. com/ products/ server/ faqs. html), VMware Inc. retrieved on 2010-04-07 109 IBM System/370 110 IBM System/370 O IBM System/370 (ou simplesmente, S/370) foi uma famàlia de mainframes da IBM lanÅada em 30 de junho de 1970 como sucessora da sárie IBM System/360. A sárie mantinha compatibilidade reversa com o S/360, permitindo uma migraÅÉo fÑcil para os utilizadores; isto, alám de uma performance aprimorada, eram os temas dominantes no lanÅamento do produto. As novas caracteràsticas que o distinguiam do S/360 incluàam: capacidade padrÉo para processor dual; suporte total para memÄria virtual e aritmática de 128 bits em ponto flutuante. Nem todas estas caracteràsticas, contudo, faziam parte do S/370 inicial quando do seu lanÅamento. A sárie 370 de computadores possuàa arquitetura big endian de 32 bits (diferentemente dos microprocessadores de 32 bits, tal como a sárie x86, que utilizaram arquiteturas little endian). LigaÅÑes externas í IBM 370 no Museu Virtual de InformÑtica [1] í Museu do Computador - Processando Dados e mais Dados [2] ReferÖncias [1] http:/ / piano. dsi. uminho. pt/ museuv/ 1970ibm370. html [2] http:/ / www. museudocomputador. com. br/ hist_histbrasil2. php MÉquina virtual Na ciãncia da computaÅÉo, mÉquina virtual á o nome dado a uma mÑquina, implementada atravás de software, que executa programas como um computador real. Uma mÑquina virtual (Virtual Machine Ä VM) pode ser definida como Éuma duplicata eficiente e isolada de uma mÑquina realÑ. A IBM define uma mÑquina virtual como uma cÄpia isolada de um sistema fàsico, e esta cÄpia estÑ totalmente protegida. MÑquinas virtuais sÉo extremamente åteis no dia-a-dia, pois permitem ao usuÑrio rodar outros sistemas operacionais dentro de uma janela, tendo acesso a todos os softwares que precisa. VirtualBox 2.0.4 no Ubuntu rodando o Fedora 10 DefiniÅÇo O termo mÑquina virtual foi descrito na dácada de 1960 utilizando um termo de sistema operacional: uma abstraÅÉo de software que enxerga um sistema fàsico (mÑquina real). Com o passar dos anos, o termo englobou um grande nåmero de abstraÅÇes Ä por exemplo, Java Virtual Machine Ä JVM que nÉo virtualiza um sistema real. MÑquina virtual Ao invás de ser uma real, isto á, um computador real feito de hardware e executando um sistema operacional especàfico, uma mÑquina virtual á um computador fictàcio criado por um programa de simulaÅÉo. Sua memÄria, processador e outros recursos sÉo virtualizados. A virtualizaÅÉo á a interposiÅÉo do software (mÑquina virtual) em vÑrias camadas do sistema. î uma forma de dividir os recursos de um computador em måltiplos ambientes de execuÅÉo. Os emuladores sÉo mÑquinas virtuais que simulam computadores reais. SÉo bastante conhecidos os emuladores devàdeogames antigos e os emuladores de microcomputadores, como o VMware, o Bochs e o VM VirtualBox, software livre da Oracle. Tipos As mÑquinas virtuais podem ser divididas em dois tipos: í Tipo 1: Sistema em que o monitor á implementado entre o hardware e os sistemas convidados (guest system). í Tipo 2: Nele o monitor á implementado como um processo de um sistema operacional real, denominado sistema anfitriÉo (host system). í Tipos Hàbridos: Os monitores de tipo 1 e 2 raramente sÉo usados em sua forma conceitual em implementaÅÇes reais. Na prÑtica, vÑrias otimizaÅÇes sÉo inseridas nas arquiteturas apresentadas, com o objetivo principal de melhorar o desempenho das aplicaÅÇes nos sistemas convidados. Como os pontos cruciais do desempenho dos sistemas de mÑquinas virtuais sÉo as operaÅÇes de I/O, as principais otimizaÅÇes utilizadas em sistemas de produÅÉo dizem respeito a essas operaÅÇes. Outra importante categoria de mÑquinas virtuais sÉo as mÑquinas virtuais para computadores fictàcios projetados para uma finalidade especàfica. Atualmente a mais importante mÑquina virtual desta famàlia á a JVM (mÑquina virtual Java). Existem simuladores para ela em quase todos os computadores atuais, desde computadores de grande porte atá telefones celulares, o que torna as aplicaÅÇes Java extremamente portÑveis. Uma importante vantagem sem duvida de se escrever cÄdigo para uma mÑquina virtual á a de se poder compilar o cÄdigo sem que seja perdida a portabilidade, melhorando-se a velocidade em relaÅÉo ë programaÅÉo interpretada, que tambám á portÑtil, porám mais lenta, jÑ que neste caso cada linha serÑ traduzida e executada em tempo de execuÅÉo, e no caso da mÑquina virtual cada mnemÖnico da mÑquina virtual á convertido no equivalente em linguagem de mÑquina (ou assembly) da mÑquina real. Vantagens á Facilita o aperfeiÅoamento e testes de novos sistemas operacionais. á Possibilita a comparaÅÉo de vÑrios sistemas operacionais utilizando o mesmo equipamento. á Executa diferentes sistemas operacionais sobre o mesmo hardware, simultaneamente. á Simula alteraÅÇes e falhas no hardware para testes ou reconfiguraÅÉo de um sistema operacional, provendo confiabilidade e escalabilidade para as aplicaÅÇes. á DiminuiÅÉo de custos com hardware. á Facilidades no gerenciamento, migraÅÉo e replicaÅÉo de computadores, aplicaÅÇes ou sistemas operacionais. á ConfianÅa e disponibilidade: A falha de um software nÉo prejudica os demais serviÅos. 111 MÑquina virtual Desvantagens á Gerenciamento: Os ambientes virtuais necessitam ser, monitorados, configurados e salvos . Existem produtos que fornecem essas soluÅÇes, mas esse á o campo no qual estÉo os maiores investimentos na Ñrea de virtualizaÅÉo, justamente por se tratar de um dos maiores contratempos na implementaÅÉo da virtualizaÅÉo. á Desempenho: Atualmente, nÉo existem mátodos consolidados para medir o desempenho de ambientes virtualizados. No entanto, a introduÅÉo de uma camada extra de software entre o sistema operacional e o hardware, o VMM ou hypervisor, gera um custo de processamento superior ao que se teria sem a virtualizaÅÉo. Outro ponto importante de ressaltar á que nÉo se sabe exatamente quantas mÑquinas virtuais podem ser executadas por processador, sem que haja o prejuàzo da qualidade de serviÅo. SeguranÅa Embora a mÑquina necessite do sistema real para sua inicializaÅÉo, trabalha de maneira independente como se fosse outro computador, isto requer tambám um sistema de seguranÅa independente, ou seja, a ocorrãncia de infecÅÉo por vàrus na mÑquina virtual nÉo afeta a mÑquina real. ReferÖncias í Marcos Laureano, MÅquinas Virtuais e Emuladores - Conceitos, TÑcnicas e AplicaÄÖes [1]. Novatec Editora. ISBN 85-7522-098-5. í Marcos Laureano, DetecÄÇo de IntrusÇo em MÅquinas Virtuais [2]. DissertaÅÉo de mestrado apresentada na Pontàficia Universidade CatÄlica do ParanÑ. í Marcos Laureano, Carlos Maziero, VirtualizaÄÇo: Conceitos e AplicaÄÖes em SeguranÄa [3]. Mini-curso do VIII SimpÄsio Brasileiro em SeguranÅa da InformaÅÉo e de Sistemas Computacionais, 2008. í Diogo Menezes Ferrazani Mattos, Vantagens e Desvantagens [4]. ReferÖncias [1] http:/ / www. novateceditora. com. br/ livros/ maquinasvirtuais/ [2] http:/ / www. laureano. eti. br/ projetos/ deteccao-de-intrusao-em-maquinas-virtuais/ [3] http:/ / www. ppgia. pucpr. br/ ~maziero/ lib/ exe/ fetch. php/ research:2008-sbseg-mc. pdf [4] http:/ / www. gta. ufrj. br/ grad/ 08_1/ virtual/ VantagenseDesvantagens. html 112 Emulador Emulador Na computaÅÉo, um emulador á um software que reproduz as funÅÇes de um determinado ambiente, a fim de permitir a execuÅÉo de outros softwares sobre ele. Pode ser pela transcriÅÉo de instruÅÇes de um processador alvo para o processador no qual ele estÑ rodando, ou pela interpretaÅÉo de chamadas para simular o comportamento de um hardware especàfico. O emulador tambám á responsÑvel pela simulaÅÉo dos circuitos integrados ou chips do sistema de hardware em um software. Basicamente, um emulador expÇe as funÅÇes de um sistema para reproduzir seu comportamento, permitindo que um software criado para uma plataforma funcione em outra. VisÇo geral Os ambientes computacionais geralmente sÉo formados por camadas. A quantidade e o papel de cada camada pode variar de acordo com o ambiente, e seu grau de dependãncia. Alguns ambientes sÉo puramente fàsicos como os terminais de mainframe, e portanto, sua emulaÅÉo cabe apenas o tratamento dos dados enviados do terminal ou para ele, e reproduzir a interaÅÉo com o usuÑrio. Outros ambientes podem nÉo possuir um firmware (algumas vezes chamado de bios), sendo que os programas que serÉo executados conhecem todo o hardware, e sua emulaÅÉo seria basicamente a interpretaÅÉo das chamadas ao hardware para reproduzir seu comportamento. Alguns ambientes possuem firmware mas nÉo possuem sistema operacional. Nestes casos serÑ necessÑrio emular tambám o firmware ou obter um com o fabricante. HistÄria O primeiro emulador foi criado em 1964 por Larry Moss, na ápoca funcionÑrio da IBM, consistindo em um Software que fazia com que os programas criados para o 7070 mainframe rodassem na mais nova linha de computadores da IBM, os System/360. O emulador foi um sucesso e ajudou bastante o System/360 a se tornar um best-seller na dácada de 1970. PopularizaÅÇo A popularizaÅÉo dos emuladores veio junto com a Internet e os emuladores de vàdeo games. As imagens extraàdas de cartuchos de vàdeo games sÉo chamadas de ROMs e aliadas ë programaÅÉo em baixo nàvel de jogos para sistemas antigos tornou fÑcil a possibilidade de criaÅÉo de emuladores de sistemas como o Chip-8 e depois de vàdeo games mais populares como o Atari 2600 e NES. Apesar de um emulador nem sempre ser a coisa mais fÑcil de configurar, com pouco conhecimento hoje jÑ á possàvel rodar um jogo de Playstation em um PC atravás de um emulador sem muitos problemas, muitas vezes atá com qualidade superior ao prÄprio vàdeo game, jÑ que podem-se aplicar efeitos como anti-aliasing que o vàdeo game nÉo possui e rodar os jogos em resoluÅÇes muito mais altas que o original. 113 Emulador AplicaÅÑes/Vantagens í í í í Rodar jogos de vàdeo games. Testar cÄdigos cross-compilado com maior facilidade. Reaproveitamento de softwares escritos para sistemas antigos. Rodar jogos de diferentes plataformas. Desvantagens í Para obtermos uma execuÅÉo satisfatÄria do sistema que estÑ sendo emulado, ou seu uso em ambiente de produÅÉo, o emulador e o ambiente que o executa precisam possuir um desepenho superior ao do sistema original. í Quanto maior a complexidade, ou a incompatibilidade entre o ambiente emulado e o que estÑ executando o emulador, maior a complexidade da implementaÅÉo do emulador, e maior exigãncia de hardware. í Alguns perifáricos e caracteràsticas do sistema original, por serem fàsicos, serÉo emulados apenas em nàvel de software, podendo nÉo oferecer transparãncia ao usuÑrio final. Uso comercial de emuladores Emuladores no geral O processo de emular nÉo constitui crime. VÑrios processos jÑ foram movidos com este assunto e nenhum obteve ãxito. Um exemplo de um processo perdido foi o da Creative Labs fabricante da placa de som Sound Blaster, que na ápoca era hardware bÑsico para algumas aplicaÅÇes que utilizavam sons. Outras placas de som emularam o hardware da Sound Blaster para ficarem compativeis com tais aplicativos. Quando emular esta associado a um hardware, com exemplo vàdeo games, o emulador faz o trabalho do console, que por sua vez necessita de Roms que á o Jogo copiado de um cartucho ou CD. As roms ou jogos para emuladores sÉo softwares como qualquer outro. Portanto á crime obter uma rom ou jogo e executÑ-lo em um emulador ou hardware sem que vocã tenha o jogo original. Computadores em computadores Dentre os emuladores comerciais que emulam computadores estÉo o Softmac que emula Macintosh no PC. Sistemas mais antigos como Atari ST tambám possuem emuladores oficiais entre eles o Gemulator. VÜdeo games em computadores LanÅado em 1999, o Virtual Game Station (VGS) foi um emulador de Playstation desenvolvido pela Connectix originalmente para Macintosh e posteriormente portado para PC. A Connectix sofreu aÅÇes judiciais por parte da Sony, desenvolvedora do Playstation. ApÄs algum tempo de batalhas judiciais, o emulador foi adquirido pela Sony e descontinuado. A empresa encerrou suas atividades em 2003. Tambám lanÅado em 1999, o bleem! foi um emulador comercial de Playstation para PC desenvolvido pela bleem Company. Posteriormente ganhou uma versÉo para Dreamcast, chamada de bleemcast!. A Sony tambám moveu aÅÇes judicias contra a bleem Company. Apesar da Sony nÉo ter vencido nenhum dos processos judiciais, os custos advocatàcios, o surgimento de emuladores gratuitos e o encerramento na produÅÉo do Dreamcast fizeram com que a bleem Company terminasse suas atividades em 2001. 114 Emulador VÜdeo games em video games A Microsoft utiliza emulaÅÉo em seu console de nova geraÅÉo, o Xbox 360, para executar jogos de seu console anterior, o Xbox. O Live Arcade traz jogos antigos mas eles nÉo sÉo emulados e sim re-programados e rodam nativamente no hardware do console. A Sony usa um emulador para emular o PlayStation original no PlayStation Portable. Esse emulador tambám á usado em todos os modelos de PS3 para emular jogos do primeiro console. A Sony ainda usou um emulador de Emotion Engine nos modelos de 80GB/60GB-europeus para emular o PlayStation 2. Esse emulador á capaz de setar jogos do PS2 em altas resoluÅÇes: 720p e 1080p. A Nintendo usa extensamente emuladores no Wii Virtual Console. Entre os sistemas emulados, estÉo o NES, Super Nintendo, Mega Drive, Neo-Geo, PC Engine e Nintendo 64. Entretanto, os jogos de Gamecube nÉo sÉo emulados e sim rodam nativamente no hardware do console. A partir de 2006 muitas empresas lanÅaram jogos em coletÜneas que rodam em um emulador. Esses emuladores oferecem uma emulaÅÉo mais refinada se comparada aos emuladores de terceiros. Entre as empresas/jogos estÉo: í Sega (Sega Genesis Collection) í Namco (Namco Museum) í Capcom (Capcom Classics Collection) í Taito (Taito Classics) í Atari (Atari Anthology) Recentemante algumas empresas embutiram jogos antigos emulados em jogos comerciais como um bÖnus para o jogador. Entre eles estÉo: í í í í Prince of Persia: Sands of Time - (Prince of Persia original do PC) Ninja Gaiden (Xbox) - (Ninja Gaiden 1, 2 e 3 versÉo NES) Tekken 5 - (Tekken 1, 2 e 3 de Playstation) Zelda: Wind Waker - (Zelda: Ocarina of Time de Nintendo 64) Uso nÇo-comercial (caseiro) de emuladores Muitos emuladores sÉo livres e programados por terceiros. SÉo denominados tambám de homebrews. Entre eles estÉo: Computadores em computadores Algumas arquiteturas de computadores podem ser emuladas em outro computador. Entre eles o x86 (PC comum) (Bochs), o MSX (BRSMS), DOS (DOSBox), AmigaOS (WinUAE), Mac OS (PearPC). î importante esclarecer que um emulador á diferente de uma mÑquina virtual usadas em sistemas como VMWare, VirtualPC e QEMU. Num emulador, todos os recursos do sistema sÉo processados nele ao contrÑrio da virtualizaÅÉo que á uma ponte entre o hardware nativo e as chamadas do sistema operacional. Outro erro comum á dizer que o WINE á um emulador de Windows - ele á um conjunto de APIs que cria uma camada de compatibilidade ao contrÑrio de emulador que processa todo sistema num ånico conjunto de software. Video games em computadores A lista de consoles de video games emulados á extensa, á raro um sistema nÉo ser emulado geralmenre os mais novos levam tempo para conseguir emular. Entre eles, o Xbox e o Gamecube ainda nÉo sÉo satisfatoriamente emulados apesar de existir emuladores prematuros para eles. O PlayStation 2 á bem emulado no PCSX2 mas necessita de um potente computador; O Dreamcast tambám á bem emulado no nullDC. O PlayStation Portable e Nintendo DS ainda nÉo sÉo 100% emulados, mas no caso do DS o emulador NO$GBA roda perfeitamente alguns jogos. Os videogames da nova geraÅÉo: Xbox 360 e PlayStation 3 nÉo sÉo emulados mas a histÄria mostra que 115 Emulador certamente serÉo no futuro. JÑ o Wii jÑ possui emulaÅÉo primÑria a partir da versÉo open-source do Dolphin (originalmente um emulador de GameCube). Video games em video games î possàvel emular consoles de videogames antigos num video game atual. Para isso os consoles devem estar destravados com um Modchip ou ter seu sistema firmware modificado para possibilitar o uso de programas nÉo-autorizados. O primeiro emulador a conseguir esse feito foi PNESX que possibilitou emular o NES num PlayStation. O Xbox por ser um PC x86 teve dezenas de emuladores convertidos e adaptados para ele. O PlayStation 2 e o Gamecube tambám tiveram emuladores para rodar Super Nintendo e Mega Drive. LigaÅÑes externas Em PortuguÖs í í í í í í í í í í í í Roxdownload - Desde 2004 o melhor site de emulaÅÉo do Brasil [1] Emuladores.com.br - Diversos Emuladores para Download. [2] EmuPortugal.info - VÑrios Emuladores para diversas consolas de videojogos. [3] SuperNES - Muitas ROMS para vocã [4] ArcadeBR - Site Brasileiro sobre Arcades [5] Emulabite - Portal de emulaÅÉo com download de emuladores e roms [6] Emuladores e Roms de diversos sistemas [7] RoxRoms [8] EmuladorTotal - Emuladores para quase todos consoles, computadores e arcades [9] MoreROMs - Acervo de emuladores e ROMs [10] SNK-Neofighters - Portal do qual faz parte o site do emulador NeoRageX [11] ZuQuEtO.CoM - Emuladores e Roms para diversos consoles dentre eles Atari, SNES, Mega Drive e etc. [12] Em InglÖs í í í í í Emulation64 [13] Emulexgames [14] Ngemu [15] Vintage Gaming Emulators [16] Zophar - Diversos Emuladores. [17] ReferÖncias [1] http:/ / www. roxdownload. net/ emuladores [2] http:/ / www. emuladores. com. br [3] http:/ / www. emuportugal. info/ [4] http:/ / supernes. us/ [5] http:/ / www. arcadebr. com. br/ [6] http:/ / www. emulabite. com [7] http:/ / emuladoreseroms. buscasulfluminense. com [8] http:/ / www. roxroms. net/ [9] http:/ / www. emuladortotal. blogspot. com [10] http:/ / www. moreroms. info [11] http:/ / www. snk-neofighters. com [12] http:/ / www. zuqueto. com [13] http:/ / emulation64. com [14] http:/ / www. emulexgames. com [15] http:/ / ngemu. com 116 Emulador 117 [16] http:/ / www. vg-network. com [17] http:/ / www. zophar. net VirtualBox VirtualBox VirtualBox rodando Fedora, sob hospedeiro Ubuntu Desenvolvedor InnoTek, Oracle VersÉo estÑvel 4.0.4 (17 de Fevereiro de 2011) Sistema Op. Multiplataforma Gãnero(s) MÑquina virtual LicenÅa ProprietÑria/GPL PÑgina oficial www.virtualbox.org [1] Portal das Tecnologias de informaÅÇo VirtualBox á um software de virtualizaÅÉo desenvolvido pela Sun Microsystems que posteriormente foi comprada pela Oracle que, como o VMware Workstation, visa criar ambientes para instalaÅÉo de sistemas distintos. Ele permite a instalaÅÉo e utilizaÅÉo de um sistema operativo dentro de outro, assim como seus respectivos softwares, como dois ou mais computadores independentes, mas compartilhando fisicamente o mesmo hardware. HistÄria Criado pela empresa Innotek, inicialmente oferecia uma licenÅa proprietÑria, existia uma versÉo do produto para uso pessoal ou de avaliaÅÉo sem custo. Em Janeiro de 2007 á lanÅado a versÉo VirtualBox OSE (Open Source Edition) com a licenÅa GPL (GNU General Public License), versÉo 2. Em Fevereiro de 2008 a empresa Innoteck á adquirida pela Sun Microsystems. No dia 20 de Abril de 2009 a Oracle compra a Sun Microsystems e todos o seu produtos, incluindo o VirtualBox. CaracterÜsticas O VirtualBox tem um desenho extremamente modular com interfaces de programaÅÉo interna bem definidas e um desenho cliente/servidor. Isso torna fÑcil o controle de vÑrias interfaces de uma sÄ vez. Por exemplo: vocã pode iniciar uma mÑquina virtual em uma mÑquina tàpica virtual de interface grÑfica e, em seguida, controlar essa mÑquina a partir da uma linha de comando, ou possivelmente remotamente. O VirtualBox tambám vem com um kit completo desenvolvimento de software: embora seja de cÄdigo aberto, vocã nÉo tem que cortar a fonte de escrever uma nova interface para VirtualBox. As definiÅÇes de configuraÅÉo de mÑquinas virtuais sÉo armazenados em XML e sÉo totalmente independentes das mÑquinas locais. Por isso, as definiÅÇes podem ser facilmente transferidos para outros computadores. VirtualBox O VirtualBox tem um software especial que pode ser instalado dentro das mÑquinas virtuais Windows e Linux para melhorar o desempenho e fazer integraÅÉo muito mais perfeita. Entre os recursos fornecidos por essas adiÅÇes clientes sÉo integraÅÉo do ponteiro do mouse o e soluÅÇes arbitrÑrias de tela (por exemplo, o redimensionamento da janela do cliente). Tal como muitos outras soluÅÇes de virtualizaÅÉo, para facilitar a troca de dados entre os hospedeiros e convidados, o VirtualBox permite a declaraÅÉo dos diretÄrios de certos hospedeiros como "pastas compartilhadas", que pode ser acessadas de dentro de mÑquinas virtuais. Recursos restritos O VirtualBox possui uma sárie de recursos disponàveis somente na versÉo completa. Por exemplo, ele implementa um controlador virtual USB e permite-lhe arbitrariamente ligar dispositivos USB em suas mÑquinas virtuais sem ter que instalar um drivers de dispositivo especàfico ao host. Diferente de qualquer outro software de virtualizaÅÉo, o VirtualBox apÄia inteiramente o padrÉo Remote Desktop Protocol (RDP). Uma mÑquina virtual pode atuar como um servidor RDP, o que lhe permite "executar" a mÑquina virtual remotamente em alguns serviÅos que exibem os dados RDP. JÑ com o recurso de USB durante RDP, uma mÑquina virtual que atua como um servidor RDP pode acessar dispositivos USB que estÉo conectados ë RDP cliente. Dessa forma, uma poderosa mÑquina servidor pode virtualizar um lote de serviÅos que necessitam dados RDP e dispositivos USB conectados. LigaÅÑes externas í Sàtio oficial [2] (em inglãs) ReferÖncias [1] http:/ / www. virtualbox. org/ [2] http:/ / www. virtualbox. org 118 VMware 119 VMware VMware Red Hat Linux 9 rodando sob o VMware. Desenvolvedor VMware VersÉo estÑvel 7.0 (2009) Sistema Op. Multiplataforma Gãnero(s) MÑquina virtual, EmulaÅÉo LicenÅa ProprietÑria PÑgina oficial www.vmware.com [1] Portal das Tecnologias de informaÅÇo VMware á um software/mÑquina virtual que permite a instalaÅÉo e utilizaÅÉo de um sistema operacional dentro de outro dando suporte real a software de outros sistemas operativos. Usando software de virtualizaÅÉo como o VMware á possàvel executar um ou mais sistemas operacionais simultÜneamente num ambiente isolado, criando computadores completos (virtuais) a executar dentro de um computador fàsico que pode rodar um sistema operacional totalmente distinto. Do ponto de vista do utilizador e do software nem sequer se nota a diferenÅa entre a mÑquina real e a virtual. î muito usado em centros de dados, pois permite criar redundÜncia e seguranÅa adicional sem recorrer a tantas mÑquinas fàsicas e distribuindo e aproveitando melhor os recursos das mÑquinas hospedeiras. A empresa desenvolvedora A empresa desenvolvedora do VMware, a VMware Inc., localiza-se em Palo Alto, CalifÄrnia, Estados Unidos e á uma subsidiÑria da EMC Corporation. O nome á um jogo de palavras com Virtual Machine (mÑquina virtual), que á o nome tácnico dado a um sistema operacional rodando sob o VMware. VersÑes do produto VMware Workstation î voltado ao uso no desktop, em ambientes de desenvolvimento. Atualmente estÑ na versÉo 7.1.0, e roda em CPU's Intel e AMD de 32 e 64 bits. Permite rodar vÑrios "computadores virtuais" dentro de um sistema operacional (windows, versÇes GNU/LINUX, MAC OS, etc), cada um destes computadores pode rodar seu prÄprio sistema operacional. O computador simulado pode ter uma quantidade de RAM definida (atá 3600 MB no VMware 5.5.3; atá 8GB, desconsiderando limitaÅÇes do hardware, no VMware 6.0) e um disco virtual delimitado (atá 950GB) VMware Ele pode "simular" um drive de CD-ROM,drive de disquete, placas de rede (atá 3 no VMware 5.5.3; atá 10 no VMware 6.0 beta), discos ràgidos e portas USB (USB 1.1 na versÉo 5.5.3; USB 2.0 na versÉo 6.0). Recursos importantes: í Possibilidade de "unir" vÑrias mÑquinas virtuais, permitindo que todas elas sejam iniciadas ou desligadas com um mesmo comando. Tambám á possàvel definir redes internas. í Suporte a 3 modos de rede: Bridged (a mÑquina virtual á vista como um outro computador na rede, com IP obtido via DHCP); NAT (a mÑquina virtual se conecta ao computador host, que por sua vez se conecta ë rede); e Host-Only (a mÑquina virtual apenas se conecta ao host). í Possibilidade de criar registros instantÜneos ("snapshots") de uma mÑquina virtual num dado momento. Assim, á possàvel testar configuraÅÇes, e se elas derem errado pode-se reverter. VMware Server (anteriormente VMWare GSX Server) Voltado ao uso em servidores de pequeno e mádio porte. Tornou-se gratuito em 12 de Junho de 2006. î um produto de "entrada" para o mercado. Conta com boa parte dos recursos da versÉo Workstation, e adiciona recursos åteis ao seu uso em servidores, como o gerenciamento remoto (usando uma versÉo modificada do VNC). Isto resulta em perda de desempenho na interface grÑfica, porám nÉo á um problema para servidores que rodam "headless", ou seja, sem monitor ou interface grÑfica. VMware ESX Server Voltado ao uso em servidores de grande porte. î um sistema operacional dedicado, que usa um nåcleo proprietÑrio, baseado no SimOS [2]. O Red Hat Linux á usado para prover os diversos serviÅos, como gerenciamento remoto. Por rodar em um nàvel mais prÄximo do hardware, elimina-se o overhead de ter um sistema base, e aumenta-se a seguranÅa. Por este motivo ele á usado em servidores de grande porte. VMware Player Executa mÑquinas virtuais prontas; Oficialmente (VersÇes anteriores ë versÉo 3.0), nÉo á possàvel criar mÑquinas virtuais novas, mas á possàvel pular esta limitaÅÉo de 3 formas: í Instalando uma versÉo de avaliaÅÉo do VMware Workstation e criando mÑquinas virtuais novas. í Usando appliances (mÑquinas virtuais fornecidas pela comunidade, que operam como soluÅÇes prontas, onde basta apenas rodar). í Usando sites nÉo oficiais, como o EasyVMX [3]. í Usando a versÉo 3.0 ou superior. VMware Fusion Uma versÉo para o Mac OS X rodando em Macintosh com CPU Intel. O produto se encontra em sua terceira versÉo, com suporte inclusive a acereraÅÉo 3d por hardware. Pode-se obter uma versÉo de teste [4]. Outros produtos í í í í VMware ThinApp, um programa que permite a criaÅÉo de "aplicaÅÇes portÑteis" ("portable apps") VMware P2V, uma ferramenta para migrar servidores fàsicos para mÑquinas virtuais. VMware VirtualCenter, uma ferramenta para centralizar o gerenciamento de instalaÅÇes do VMware. VMotion, uma ferramenta para transferir mÑquinas virtuais entre servidores, de forma tÉo transparente quanto possàvel, resultando no mànimo de downtime (tempo com o servidor fora do ar) 120 VMware Funcionamento Ao contrÑrio de muitos mitos divulgados pela Internet, o VMware nÇo á um emulador. Vai a um nàvel mais baixo, onde o processador chega por vezes a executar diretamente o cÄdigo da mÑquina virtual. Quando isto nÉo á possàvel, o cÄdigo á convertido de forma a que o processador nÉo precise trocar para o modo real, o que seria uma perda de tempo. Utilidade O VMware á åtil para: í Ambientes de desenvolvimento, onde á necessÑrio testar uma aplicaÅÉo em vÑrias plataformas: Muitas empresas tãm produtos multiplataforma, que precisam ser testados em Windows e em diversas distribuiÅÇes do Linux. í Ambientes de suporte, onde á necessÑrio dar suporte a diversas aplicaÅÇes e sistemas operacionais. Um tácnico de suporte pode rapidamente usar uma mÑquina virtual para abrir um ambiente Linux ou Windows. í MigraÅÉo e consolidaÅÉo de servidores antigos: á muito comum vermos redes com diversos servidores antigos, que resultam em um custo de manutenÅÉo maior. Com o VMware podemos concentrÑ-los em uma mÑquina sÄ. í ManutenÅÉo de aplicaÅÇes antigas e teste de sistemas novos: o uso do VMware para testar sistemas operacionais á um dos usos mais comuns do produto. Por exemplo, á possàvel usÑ-lo para executar o Windows dentro do Linux ou o oposto. í Manter a compatibilidade de hardware. Alguns hardwares nÉo tãm drivers para o Linux ou para versÇes mais recentes do Windows. Neste caso, á possàvel usar hardwares (ligados pela porta paralela ou USB) com uma mÑquina virtual. í SimulaÅÉo de instalaÅÇes complexas de rede. í ApresentaÅÉo de demonstraÅÇes de sistemas completos prontos a usar, tipicamente referidas como VMware appliances. í Num ambiente protegido á tàpico usar balanceador de carga, vÑrias firewall e 4 servidores fàsicos para alojar com seguranÅa um ånico site que use servidor web e base de dados. Com mÑquinas virtuais á possàvel criar redundÜncia contra falhas e seguranÅa adicional contra intrusÉo sem recorrer a tantas mÑquinas fàsicas e distribuindo e aproveitando melhor os recursos das mÑquinas hospedeiras. í Desde a versÉo ESX 3.0, virtualizaÅÉo com VMware pode ser utilizado para produÅÉo com total seguranÅa. LimitaÅÑes Algumas limitaÅÇes do VMware: í HÑ apenas suporte experimental ë aceleraÅÉo 3D, tornando o VMware inviÑvel para o uso de jogos. í Existem alguns problemas com o uso de placas de rede sem fio (Wireless), sendo necessÑrio usar o modo NAT. í NÉo hÑ suporte para placas PCI. Funcionalidades Descrevendo as funcionalidades: í Hypervisor: á o nucleo da soluÅÉo de virtualizaÅÉo, responsÑvel por particionar, encapsular e isolar os recursos da maquina para a utilizacao em ambientes virtualizados. í VMFS: VMware file system á a base para se criar o datacenter virtual e permite que sejam montados pools de recursos distribuidos. í Virtual SMP Ä permite que maquinas virtuais tenham mais de um processador virtual. í Update Manager Ä Automatiza e facilita o update no ESX server e em maquinas virtuais. í Virtual Center Agent Ä agente que troca informacoes com o Virtual Center Management Server, para gerenciamento do pool de recursos 121 VMware í Consolidated Backup Ä facilita a realizacao de backups do datacenter virtual. í HA - High availability Ä funcionalidade que permite que a infra-estrutura do datacenter virtual identifique que houve uma queda de um servidor fisico e em um tempo muito curto religue as maquinas virtuais que estavam naquele servidor fisico em outro. í Vmotion Ä funcionalidade que permite movimentar um servidor virtual entre servidores fisico SEM DESLIGAMENTO DO SERVIDOR VIRTUAL. Essa caracteràstica á muito importante pois reduz significativamente as paradas planejadas de sistema, ao mesmo tempo em que se torna um excelente aliado na alocacao dinamica de recursos do pool (flexibilidade). í Storage Vmotion Ä permite movimentar as maquinas virtuais entre dois storages para evitar gargalos de IO, sem desligamento do servidor virtual. í DRS Å Distributed Resource Scheduler á uma funcionalidade que permite ao datacenter virtual fazer balanceamento de carga das maquinas virtuais para adequar-se a mudancas na demanda de cada aplicacao/maquina virtual. í DPM Å Dynamic Power Management permite ao sistema reduzir o consumo de energia em momentos de baixo consumo de recursos.(***ainda nÉo recomendado para produÅÉo***) LigaÅÑes externas í Sàtio oficial [1], onde o usuÑrio pode fazer o download de uma versÉo de avaliaÅÉo do VMWare Workstation, ou dos produtos freeware (Server e Player). í Virtual Machine Marketplace, onde á possàvel obter mÑquinas virtuais prontas [5] ReferÖncias [1] [2] [3] [4] [5] http:/ / www. vmware. com http:/ / simos. stanford. edu/ http:/ / www. easyvmx. com http:/ / www. vmware. com/ products/ beta/ fusion/ http:/ / www. vmware. com/ vmtn/ appliances/ directory/ 122 Xen 123 Xen Para outros significados de Xen, ver Xen (desambiguaÄÇo) Xen á um software livre de virtualizaÅÉo para as arquiteturas x86, x86-64, IA-32, IA-64 e PowerPC. Xen permite a execuÅÉo de vÑrios sistemas operacionais, simultaneamente, sobre um mesmo hardware. VersÇes modificadas de Linux e NetBSD podem ser usadas como base. Diversos sistemas Unix modificados podem ser executados. Desde a versÉo 3.0, o Microsoft Windows e outros sistemas operacionais podem ser executados sobre o Xen. Xen foi originalmente desenvolvido como um projeto de pesquisa na Universidade de Cambridge, liderado por Ian Pratt, fundador da XenSource, Inc. Em 15 de agosto de 2007, a XenSource foi adquirida pela Citrix System Inc. [1] pelo valor de 500 milhÇes de dÄlares. A Citrix agora suporta o desenvolvimento do projeto open source e vende tambám uma versÉo "empresarial" do software. O primeiro lanÅamento påblico do Xen foi disponibilizado em 2003. LigaÅÑes externas í Site oficial do projeto [2]. Hospedado pela Universidade de Cambridge. í The Xen Wiki [3] í University of Cambridge, Technical Report Number 553, January 2003 [4]. Early report outlining the architecture of Xen. í Tutorial de InstalaÅÉo [5] Tutorial de InstalaÅÉo do Xen no Debian ReferÖncias [1] [2] [3] [4] [5] http:/ / www. xensource. com/ about/ Pages/ CitrixPJLLetter. aspx http:/ / www. cl. cam. ac. uk/ Research/ SRG/ netos/ xen/ http:/ / wiki. xensource. com/ xenwiki/ http:/ / www. cl. cam. ac. uk/ TechReports/ UCAM-CL-TR-553. pdf http:/ / wiki. forumdebian. com. br/ index. php/ Xen Microsoft Virtual PC 124 Microsoft Virtual PC O Microsoft Virtual PC 2007, da Microsoft, á um programa que emula um computador dentro do seu Windows. Assim sendo, em uma janela serÑ possàvel abrir outro sistema operacional, como Windows, Linux, MS-DOS, e atá criar um HD virtual, que serÑ um arquivo salvo dentro da partiÅÉo de seu Windows mesmo, podendo ser formatado com qualquer sistema de arquivos, sem interferir no sistema real. Resumindo, á possàvel usar um sistema FAT32, ReiserFS etc., dentro de um HD formatado em NTFS, por exemplo. O Virtual PC á muito åtil para empresas, testes de vàrus, aprendizado e para rodar sistemas antigos. Assim sendo o usuÑrio pode rodar Sistemas operacionais distintos e conectÑ-los atravás de um dispositivo de rede virtual que o instalador disponibiliza dentro de Painel de Controle -> ConexÇes de Rede (no caso de Sistemas Microsoft). O Virtual PC permite ainda capturar ISO's de Instaladores de Sistemas Operacionais, rodÑ-las na forma de uma unidade de CD-ROM tambám virtual, instalar o S.O. a partir da ISO e, depois de instalado, ainda personalizar o S.O. realizando mais instalaÅÇes de softwares de terceiros, o que facilita por exemplo verificar a migraÅÉo de aplicaÅÇes entre plataformas sem precisar de um segundo computador fàsico. Kernel-based Virtual Machine Kernel-based Virtual Machine Captura de tela do qemu/kvm a rodar NetBSD, OpenSolaris e Kubuntu em um hospedeiro Arch Linux. VersÉo estÑvel 88 (14 de Julho de 2009) Escrito em C Sistema Op. GNU/Linux Gãnero(s) Plataforma de virtualizaÅÉo LicenÅa GPL ou LGPL Estado do desenvolvimento Corrente PÑgina oficial linux-kvm.org [1] (em )è, acessado pela åltima vez hÑ 69 semanas Portal das Tecnologias de informaÅÇo MÉquina Virtual baseada em Nâcleo (em inglãs: Kernel-based Virtual Machine (KVM)), á uma infraestrutura de virtualizaÅÉo, integrada ao Linux. Atualmente a KVM suporta virtualizaÅÉo nativa usando Intel VT ou AMD-V. Suporte limitado a paravirtualizaÅÉo tambám estÑ disponàvel para hÄspedes linux e Microsoft Windows na forma de um driver de rede paravirtual,[2] um driver de dispositivo de entrada/saàda (disco),[3] um driver recipiente para afetar a operaÅÉo do gerenciador de memÄria virtual do hÄspede,[4] e otimizaÅÇes de processamento para hÄspedes linux. Atualmente transportes para as arquiteturas s390,[5] PowerPC,[6] and IA64 estÉo sendo desenvolvidos. A primeira versÉo da KVM foi incluàda no Linux 2.6.20 (Fevereiro de 2007).[7] Tambám foi transportada para o FreeBSD como um mÄdulo de nåcleo carregÑvel.[8] Kernel-based Virtual Machine 125 Uma gama de sistemas operativos hÄspedes funcionam na KDM, incluindo vÑrios sabores de GNU/Linux, BSD, Solaris, Microsoft Windows, Haiku, ReactOS, AROS[9] , e uma versÉo remendada da kvm que á capaz de Mac OS X.[10] Projeto e licenciamento Por si sÄ, KVM nÉo realiza nenhuma emulaÅÉo. Ao invás disso, um programa de espaÅo de usuÑrio usa a interface /dev/kvm para instalar o espaÅo de endereÅamento da mÑquina virtual hÄspede, alimenta-a com E/S simulada e mapeia o seu visor de vàdeo para o do hospedeiro. Pelo menos dois programas aproveitam este recurso: uma versÉo modificada do Qemu e o prÄprio Qemu, desde a versÉo 0.10.0. Partes da KVM sÉo licenciadas sob vÑrias licenÅas GNU:[11] í í í í í MÄdulo de nåcleo do KVM: GPL v2 MÄdulo de usuÑrio do KVM: LGPL v2 Biblioteca principal de CPU virtual do QEMU (libqemu.a) e emulador de sistema PC do QEMU: LGPL Emulador do QEMU de modo usuÑrio linux: GPL Arquivos de BIOS (bios.bin, vgabios.bin and vgabios-cirrus.bin): LGPL v2 ou posterior A KVM á mantida por Avi Kivity e á financiada primariamente pela Qumranet, uma iniciativa de tecnologia,[12] now owned by Red Hat.[13] Ferramentas de gerenciamento grÉfico í Virtual Machine Manager suporta criaÅÉo, ediÅÉo, inicializaÅÉo, terminaÅÉo de mÑquinas virtuais baseadas na KVM. í ConVirt suporta criaÅÉo, ediÅÉo, inicializaÅÉo, terminaÅÉo de mÑquinas virtuais baseadas na KVM, alám de migraÅÉo arraste-e-solte de mÑquinas virtuais em execuÅÉo ou suspensas entre hospedeiros. í Proxmox Virtual Environment Software livre de virtualizaÅÉo incluindo KVM e OpenVZ - instalador de metal-exposto, IU de gerenciamento e suporte comercial opcional. Hardware emulado Classe Dispositivo [14] Placa de vàdeo VGA Placa de som Sound Blaster 16 Placa de rede Ethernet AMD Am79C970A (e Am7990?) [15] [16] , E1000 (Intel 82540EM, 82573L, 82544GC) [17] [18] [19] , NE2000 , Realtek 8139 Kernel-based Virtual Machine ReferÖncias [1] [2] [3] [4] [5] [6] [7] [8] http:/ / www. linux-kvm. org/ Gmane - Mail To News And Back Again (http:/ / article. gmane. org/ gmane. comp. emulators. kvm. devel/ 2276) libvirt: Wiki: Virtio (http:/ / wiki. libvirt. org/ page/ Virtio) 3.2 Ballooning (https:/ / db. usenix. org/ events/ osdi02/ tech/ waldspurger/ waldspurger_html/ node6. html) Gmane - Mail To News And Back Again (http:/ / article. gmane. org/ gmane. comp. emulators. kvm. devel/ 2570) Gmane Loom (http:/ / news. gmane. org/ gmane. comp. emulators. kvm. devel/ 2595) Linux: 2.6.20 Kernel Released (http:/ / kerneltrap. org/ node/ 7670). KernelTrap. FreeBSD Quarterly Status Report: Porting Linux KVM to FreeBSD (http:/ / www. freebsd. org/ news/ status/ report-2007-07-2007-10. html#Porting-Linux-KVM-to-FreeBSD). [9] KVM wiki: Guest support status (http:/ / www. linux-kvm. org/ page/ Guest_Support_Status). [10] Virtualizing an x86 Mac OS X (http:/ / alex. csgraf. de/ self/ ?part/ projects& folder/ Qemu OSX& type/ & project/ projects& parameters/ id=Qemu OSX). [11] InformaÅÉo de licenÅas do Ubuntu 7.04 /usr/share/doc/kvm/copyright [12] Interview: Avi Kivity (http:/ / kerneltrap. org/ node/ 8088) on KernelTrap [13] Red Hat press release on Qumranet purchase (http:/ / www. redhat. com/ about/ news/ prarchive/ 2008/ qumranet. html) [14] kvm-85/qemu/hw/vga.c [15] kvm-85/qemu/hw/sb16.c [16] kvm-85/qemu/hw/pcnet.c [17] kvm-85/qemu/hw/e1000.c [18] kvm-85/qemu/hw/ne2000.c [19] kvm-85/qemu/hw/rtl8139.c LigaÅÑes externas í í í í PÑgina oficial (http://www.linux-kvm.org/page/Main_Page) Wikibook QEMU & KVM (http://qemu-buch.de/e/Content) Primeiras mediÅÇes da KVM (http://www.linuxinsight.com/finally-user-friendly-virtualization-for-linux.html) Notàcias, Blogues e Recursos sobre MÑquina de VirtualizaÅÉo baseada em Nåcleo Linux (KVM) (http://www. linux-kvm.com/) 126