Virtualização

A virtualização é a criação de um ou mais ambientes virtuais em uma mesma máquina física, com o intuito de cumprir o mesmo papel de um computador físico.

Categoria de Tecnologia

Postado em 24 agosto 2022

Atualizado em 24 agosto 2022

Palavras-chave: infraestrutura,hardware,maquina,virtual,software

Visualizações: 2062



A infraestrutura de máquinas disponíveis no mercado hoje, possibilitou uma série de capacidades para a ciência da computação. Computação em nuvem é um exemplo disso.

A computação em nuvem permite que um usuário final possa acessar múltiplos computadores através da internet, sem a presença de infraestrutura extra. Assim como o fornecedor desses serviços não precisa necessariamente ter múltiplos computadores disponíveis para fornecimento.

Em outras palavras, um único computador pode abrigar múltiplos computadores dentro dele. Isso se chama virtualização.

O que é a virtualização?

A virtualização é o uso de determinados softwares para criar ambientes virtuais isolados em uma mesma máquina. Esses ambientes virtuais são praticamente idênticos a um computador convencional.

O ambiente virtual compartilha os mesmos recursos da máquina hospedeira, como CPU, memória e internet.

A virtualização pode ser parcial ou total, sendo respectivamente chamada de para-virtualização ou virtualização total. Na maioria dos casos, a virtualização total é adotada e normalmente é chamada apenas de virtualização.

O ambiente virtual é chamado de máquina virtual, que frequentemente é representado pela sigla VM (Virtual machine). Um computador pode hospedar múltiplas VMs, que serão gerenciadas pelo VMM (Virtual machine monitor).

Computador
MVV
VM 1
VM 2
VM 3

A virtualização pode ser efetuada por um hipervisor (hypervisor) como no exemplo acima ou por um contentor (container).

O que é o hipervisor na virtualização?

O hipervisor é o intermediário entre a máquina hospedeira e as máquinas virtuais.

Esse software representa uma camada na virtualização, responsável por balancear a distribuição de recursos físicos da máquina hospedeira entre as VMs, portanto sendo um VMM.

virtualização hipervisor

Ao todo, existem 2 tipos de hipervisores, o tipo 1 (bare-metal architecture) e o tipo 2 (hosted architecture).

O que é o hipervisor tipo 1 na virtualização?

No tipo 1, o hipervisor é diretamente instalado no hardware do computador, ou seja, de forma independente do sistema operacional (OS).

Nesse caso, ao mesmo tempo que utilizamos esse computador, a máquina virtual estará rodando em segundo plano, podendo ser usada como servidor.

O hipervisor tipo 1 é o mais eficiente, pelo fato de ter acesso direto aos recursos da máquina física.

Exemplos de softwares hipervisor tipo 1:

  • VMware vSphere
  • Citrix XenServer
  • Microsoft Hyper-V

O que é o hipervisor tipo 2 na virtualização?

No caso do hipervisor tipo 2, a camada de VMM é instalada acima do sistema operacional, idêntico a um aplicativo executável.

O hipervisor tipo 2 é de fácil gerenciamento e acesso, sendo bastante conveniente para testes.

Apesar de ter uma performance mais baixa do que o tipo 1, ainda é o tipo mais utilizado, pois apresenta bastante facilidade na instalação.

Exemplos de softwares hipervisor tipo 2:

  • Oracle VM VirtualBox
  • Microsoft Virtual PC
  • VMware Fusion

virtualização hipervisor tipo 1 e 2

A máquina virtual é segura?

Máquinas virtuais podem ser utilizadas como um computador convencional, seja para rodar aplicativos específicos ou disponibilizar serviços para terceiros.

Caso, uma máquina seja contaminada por algum tipo de vírus, a máquina hospedeira (máquina física) não sofre riscos de ser contaminada, assim como as outras máquinas virtuais também não sofrem nem um tipo de dano.

A máquina virtual pode ser restaurada facilmente em casos de ataque, recuperando o mesmo estado antes da contaminação.

O que é o container na virtualização?

O contentor não utiliza hipervisor, sendo gerenciado por um software de containers e sofrendo influência do sistema operacional instalado.

virtualização containers

Os containers compartilham o mesmo kernel do sistema operacional.

Exemplos de serviços de container:

  • Docker
  • LXC
  • Podman
  • Solaris containers

Qual a diferença entre container e máquina virtual?

A grande diferença é como os recursos físicos são utilizados. Além disso, contentores e VMs são usados para propósitos diferentes.

Características e objetivos da máquina virtual

A máquina virtual é um computador virtual que utiliza uma porção física do computador hospedeiro, sendo considerada uma máquina totalmente separada do computador físico. Mesmo se um usuário acessar um servidor virtual, não é possível saber se de fato essa máquina é virtual ou física. Além disso, ainda é possível selecionar os recursos de hardware, como memória RAM.

Vantagens da máquina virtual

Algumas das vantagens da máquina virtual são:

  • Melhor aproveitamento dos recursos do computador físico, uma vez que um computador não utiliza grande parte desses recursos como memória e processador
  • Corte de custos com estrutura física, pelo fato de não precisar adquirir uma outra máquina para obter um ambiente requerido
  • Ambiente totalmente isolado e seguro, mesmo contaminado por malwares pode ser facilmente restaurado sem danos para a máquina hospedeira
  • Pode ser utilizado para testes de segurança cibernética, pois na prática não diferencia de um computador normal

Características e objetivos do container (contentor)

O container também é um ambiente virtual isolado, porém é um isolamento parcial e não é considerado uma máquina virtual. A virtualização por containers é usada para simular múltiplos ambientes que empacotam determinados aplicativos, simulando futuros ambientes onde aplicativos em desenvolvimento serão implantados (deployed). Porém, isso não significa que containers não podem ser utilizados no modo de produção.

O container roda em cima do sistema operacional atual do computador, por isso dependendo do sistema operacional instalado na máquina, diferentes configurações podem ser necessárias na construção de containers.

Vantagens do container

Algumas vantagens do container são:

  • Fácil gerenciamento de ambientes em um único arquivo
  • Principal meio utilizado na arquitetura de microsserviços
  • Fácil integração de containers
  • Menos espaço de armazenamento ocupado

Conclusão

A virtualização é a criação de um ou mais ambientes virtuais em uma mesma máquina física, com o intuito de cumprir o mesmo papel de um computador físico.

Existem vários modos de virtualização, com suas respectivas vantagens. A virtualização é principalmente utilizada para cortar custos de infraestrutura e ocupação espaço físico.

Projetos práticos

Desenvolvendo o campo de visão de um personagem em um plano 2D

Detectando objetos que entram dentro do campo de visão do personagem. Útil para servir de "gatilho" para eventos em um jogo.

Criando um jogo de guerra nas estrelas em javascript usando a biblioteca p5.js

Jogo simples de guerra espacial desenvolvido em javascript. Esse jogo usa cálculos de física para simular efeitos de atrito e inércia.

Tutorial de programação do jogo da serpente em javascript

Programando o clássico jogo da serpente usando o framework p5.js. Tutorial indicado para iniciantes da programação que querem aprender os conceitos básico da área criando jogos.

Criando um sistema de integração contínua (CI/CD)

Fazendo a integração contínua de Jenkins, Sonatype Nexus, Sonatype, JUnit e Gradle para automatizar processos repetitivos. Prática bastante usada em tecnologias de DevOps.

Criando artes de texto usando imagens

Convertendo imagens para ascii art usando o valor da intensidade das cores cinzentas.

Veja também

Ainda nos primórdios da internet discada, o maior medo de um usuário era o telefone tocar...

Esperávamos horas para baixar apenas alguns megabytes. Nessas horas, quando o telefone tocava nós fazíamos de tudo para não atender o telefone. Mas infelizmente nem sempre dava certo....

Os robôs estão aprendendo por conta própria?

Já não é mais novidade saber que os robôs não precisam mais da orientação de um humano para aprender. Além disso, os robôs já superam os humanos em muitas áreas...

Sistema embarcado

Mini-computador fixado a um circuito elétrico integrado com outros componentes essenciais, como memória, componente de entrada e saída

RAT Remote Access Trojan

O RAT é um malware que tipicamente infecta o computador da vítima por um cavalo de tróia. Uma vez detectado, não é muito difícil sua remoção.

IaaS (Infrastructure as a Service)

Computador virtual. Fornece infraestrutura de computação básica distribuída em vários locais, oferecendo mais flexibilidade e escalabilidade.

Linguagem de programação

A linguagem de programação é um conjunto de instruções que possuem um padrão de escritas, sendo um intermediário entre o programador humano e a máquina.