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: 3348



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

Caixa eletrônico usando arquitetura limpa

Usando JavaFX e arquitetura limpa para criar um aplicativo de caixa eletrônico extremamente simples.

Integrando o PHP com Elasticsearch no desenvolvimento de um sistema de busca

Projeto de criação de um sistema de busca usando o framework Symfony e Elasticsearch. A integração com Kibana também é feito de modo remoto com um raspberrypi.

Criando um jogo de pacman usando javascript e pixi.js (parte 1)

Desenvolvimento dos conceitos mais básicos do clássico pacman, como: mapa, animação, deslocamento e detector de colisões.

Criando o esqueleto de um jogo de tiro 2D visto de cima usando P5.js

Usando lógicas matemáticas como trigonometria para criar e calcular o esqueleto de um jogo de tiro 2D em javascript

Desenvolvendo um jogo de quebra blocos em javascript

Programando um jogo clássico de arcade usando javascript e p5.js. O usuário deve quebrar os blocos utilizando uma bola ao mesmo tempo que evita que a bola saia pela parte inferior da tela

Veja também

Os três pilares de segurança da informação são o requerimento mínimo para um serviço seguro

A quantidade de programadores só tende a aumentar com o tempo. Porém, muitos programadores ainda não conhecem os três pilares de segurança da informação.

Afinal, para que servem os cookies que sempre são solicitados quando entramos em uma página?

A política de privacidade é obrigatória para qualquer site que utiliza dados pessoais do usuário. Porém, quais dados são esses especificamente?

PaaS (Plataforma como serviço)

Fornece a plataforma necessária para a implantação de softwares remotamente, economizando tempo e diminuindo custos de infraestrutura.

VPN Rede virtual privada

A VPN permite a transferência de dados de modo privado e seguro em uma rede pública sem a utilização de infraestrutura adicional.

Blockchain Parte2

PoW atua como um intermediário não-humano entre os negociadores de criptomoedas. Em média, uma transação em bitcoin dura 10 minutos.

RPA Automação robótica de processos

Automatiza tarefas repetitivas no lugar de humanos, podendo ser integradas com os softwares e serviços que são utilizados para a realização de tarefas.