[Cloud Computing] O que é “Conteinerização”/”Containerization” (utilizando Docker)?

A “Conteinerização” é uma alternativa leve – e muito mais leve – para a Virtualização Completa (utilizando uma VM – Virtual Machine) que envolve a ação de encapsular um aplicativo em um recipiente com o seu próprio ambiente operacional. Esta alternativa fornece muitos dos benefícios de carregar um aplicativo em uma máquina virtual, como executar o aplicativo em qualquer máquina física adequada, sem quaisquer preocupações com dependências.

A Conteinerização ganhou bastante destaque com a solução open-source Docker. Os contêineres Docker são projetados para funcionar em qualquer tipo de dispositivo/plataforma (em tudo), de computadores físicos à máquinas virtuais, bare-metal, OpenStack cloud clusters, instâncias públicas e muito mais.

Talvez, para quem não tenha conhecimento técnico em Virtualização ou em Computação em Nuvem, a explicação acima fique um pouco complicada ou distante de algo que possa fazer sentido, então, para simplificar um pouco – se é que isto é possível – podemos definir a “Conteinerização” como uma forma padronizada (um modelo) para a entrega de uma determinada aplicação dentro de uma estrutura virtual (Conteiner) que se assemelha a uma VM (Virtual Machine), e que consome menos recursos e possui estrutura para portabilidade mais simples entre diferentes ambientes físicos/virtuais. Podemos considerar de forma mais genérica – ou grosseira – que um Contêiner seria uma versão enxuta de uma VM Padrão (que necessita de um hypervisor para ser executada).

Abaixo, está disponível um vídeo contendo uma Introdução ao Docker, apresentado pelo fundador Solomon Hykes, publicado no Youtube pelo Twitter University. Divirta-se! 😀

Quer adicionar alguma informação a este conteúdo? Envie estas informações, sugestões e comentários através das Redes Sociais ou através de um comentário nesta publicação.

Um Abraço!

Antonio Ricardo Gonçalves

Cloud Computing: Como funciona um Datacenter da Microsoft (Vídeo)

A maioria dos profissionais de tecnologia – e de outras áreas também – estão acostumados ao Termo Cloud Computing (Computação em Nuvem). Mas será que a maioria sabe o que é um datacenter preparado para este modelo?

Venho abordando o tema de vários pontos de vista, com conceitos técnicos – os modelos SaaS / PaaS / IaaS -, soluções de mercado e como Cloud Computing pode solucionar problemas relacionados ao negócio. No entanto, muitos não tem ideia do tamanho e da capacidade de um datacenter que atende a este modelo de Computação em Nuvem.

Pesquisando conteúdo, encontrei um vídeo publicado pela Microsoft no Youtube, onde é possível dar um passeio por dentro de um datacenter da Microsoft. Então decidi compartilhar, pois, nada melhor do que visualizar o que acontece por trás de todos estes conceitos, siglas, soluções que abordo neste blog.

Espero que gostem!
Caso haja alguma dúvida, por favor, escrevam. E se por algum motivo o vídeo apresentar algum problema, por favor, alguém informe.

Um abraço!
Antonio Ricardo

[Microsoft Cloud] Comercial de TV da Microsoft sobre Cloud Computing

Como estou sem tempo disponível para novas publicações, decidi compartilhar um comercial da Microsoft que é veiculado constantemente nos canais de TV dos EUA / Canadá.
É um exemplo da aplicação da Nuvem da Microsoft (Microsoft Cloud) na prática (em uma situação real).
Divirtam-se!

Um abraço!
Antonio Ricardo

Exemplo de IaaS

Para finalizar a Trilogia de Exemplos de Cloud Computing: SaaS, PaaS e IaaS, neste artigo ilustro a seguir uma aplicação prática do modelo IaaS.

Primeiramente vamos recapitular o conceito:

IaaS – Infrastructure as a Service (Infraestrutura como um Serviço) Neste modelo você contrata sua infraestrutura de TI como serviço, com uma vantagem muito interessante ao modelo tradicional, que é a contratação de servidores virtuais (e outros dispositivos de infraestrutura) ao invés de comprar servidores, roteadores, racks e outras “caixas” de hardware. Aqui você é tarifado por alguns fatores, como o número de servidores virtuais, quantidade de dados trafegados, dados armazenados e outros itens, dependendo de como e com quem (fornecedor IaaS) você trabalha. Neste caso, creio que o Windows Azure, Amazon EC2 e a IBM sejam bons exemplos para quem queira pesquisar mais sobre o assunto. No IaaS, obviamente também é utilizado o modelo pay-per-use, onde a cobrança é baseada no serviço e não em licenciamento de produto, ou seja, se você precisa de 10 servidores para o próximo mês, você contrata a utilização destes servidores por este período determinado e depois, simplesmente cancela a utilização.

O modelo IaaS é apoiado em soluções de virtualização (Ex. VMware, Microsoft, RedHat etc.) que são amplamente utilizadas atualmente, adicionando ingredientes extras muito importantes relacionados ao gerenciamento do ambiente. Geralmente num ambiente virtualizado “in company” a questão do gerenciamento fica limitada aos recursos mais básicos como memória, armazenamento e processamento, porém, no modelo IaaS é esperado que o gerenciamento vá além do básico, entregando maior capacidade de provisionamento do ambiente, melhor disponibilidade (por tratar-se de ambiente mais robusto e mais complexo), além do ponto fundamental que é a gestão do custo, pois, o IaaS é comercializado baseando-se na utilização dos recursos, então se não houver um sistema eficiente que gerencie todos os recursos, alguma das partes sairá prejudicada.

O Exemplo prático:

Como a Microsoft tem uma base instalada maior que os demais, torna-se um pouco mais fácil exemplificar, utilizando o Windows Azure, pois a maior parte (ou a parte total) é formada de soluções já utilizadas em infraestrutura de TI convencional.

Através da Plataforma Windows Azure, além de seus servidores Windows, Linux e outros Sistemas Operacionais x86 e 64 bits é possível criar do ponto zero ou ainda estender sua infraestrutura para o modelo Cloud Computing / IaaS transferindo parte dela para a nuvem, incluindo o Active Directory, aramzenamento / backup, aplicações web internas ou externas hospedadas em IIS, Apache etc.

Através de várias soluções integradas na plataforma Azure é possível criar conexões seguras pela Internet e tornar sua infraestrutura flexível, tirando proveito de uma infraestrutura na Nuvem. Você terá uma extensão da sua infraestrutura atual, sem se preocupar com o hardware.

Recomendo o acesso ao site do Windows Azure, pois, existe muito conteúdo em português, e cada um dos itens da solução possui uma grande biblioteca de informações, além de eventos e a comunidade Microsoft que é uma ótima fonte de obtenção de conhecimento. Creio ser mais interessante e objetivo obter as informações diretamente na fonte. Também não deixe de acessar a calculadora disponível no Site do Windows Azure, pois, esta lhe fornecerá uma excelente base para entender como os custos são aplicados.

Um grande abraço!
Antonio Ricardo

 

Exemplo de PaaS

PaaS

Recapitulando o Conceito (Já Publicado no artigo “O que é SaaS, IaaS e PaaS em Cloud Computing? – Conceitos básicos”):

PaaS – Platform as a Service (Plataforma como Serviço):
Este modelo fica entre o SaaS e IaaS, proporcionando uma plataforma mais robusta e flexível para a utilização de muitos recursos de tecnologia, onde é possível a utilização de softwares de maneira mais personalizada, sendo possível desenvolver suas próprias aplicações baseadas em alguma tecnologia (framework, linguagem etc.) e utilizar a infraestrutura necessária – disponível na Nuvem.

O exemplo (Aplicações práticas do Conceito):

Para ilustrar o que menciono no conceito, vou apresentar o WOLF, pois, trata-se de uma solução que utiliza todos os conceitos, mas, principalmente tira o melhor proveito possível da utilização de um Framework e da gestão do ciclo de vida de uma aplicação.

A solução WOLF permite que qualquer empresa desenvolva sua aplicação em um ambiente de Cloud Computing, tira proveito dos benefícios do modelo Web 2.0, utilizando o desenvolvimento “code free” (sem necessidade de escrever código), entre outras funcionalidades.

Eu poderia publicar vários parágrafos aqui, mas acredito ser mais produtivo acessar o site do Wolf Framework, pois, existem muitos detalhes e informações, além de vídeos autoexplicativos que irão auxiliar muito no entendimento. Além do mais, não há nenhum tipo de alteração radical, que seja incompreensível para quem tem algum conhecimento – mesmo que seja básico – em Tecnologia da Informação. PaaS é mais uma excelente ferramenta no apoio ao desenvolvimento de aplicações, porém, baseada em ambiente de Cloud Computing.

Lembrando que, este NÃO é um artigo patrocinado e estou utilizando o WOLF apenas pela facilidade de entendimento do modelo, pois, o site tem ótimas informações. Se você deseja mais opções, a seguir apresento mais algumas: Azure (Português), Drupal (Inglês), Salesforce1 Platform (Inglês/Português), Squarespace (Inglês), LongJump (o site do LongJump também é excelente para aprofundar o entendimento – Inglês).

Um abraço!
Antonio Ricardo Goncalves

O que é Fabric-Based Infrastructure

Vamos adicionar mais um pouco de conhecimento ao nosso Gerenciamento de Cloud Computing  e entender o que é Fabric-Based infrastructure (FBI). Este é um termo relativamente novo que é utilizado para ambientes com capacidade de gestão automatizada.

Este conceito destinado à integração vertical de hardware e infraestrutura de software, chamado de Fabric-Based infrastructure (FBI) é apoiado por uma camada de automação (baseada em softwares para o gerenciamento de ambientes computacionais) e tem como objetivo apoiar a T.I. a prover soluções sob demanda para apoio aos negócios com maior agilidade, eficiência e eficácia. Desta forma, promete entregar infraestrutura para aplicações em tempo real.

Como mencionei nos artigos anteriores (Gerenciamento de Cloud Computing P.I e P.II) e também em vários outros, este modelo de computação (no modelo Cloud Computing), vem se diferenciando dos modelos tradicionais pela capacidade de atender as demandas de negócios por entregar soluções flexíveis. Isto significa disponibilizar ambientes que crescem ou encolhem horizontal ou verticalmente, baseados nas necessidades dos negócios.  Da perspectiva das áreas de negócios, esta facilidade de obter e liberar recursos computacionais implica em menores custos para seus projetos e maior rapidez na entrega de soluções.  Na visão da TI, este tipo de solução com gerenciamento mais eficiente é muito interessante por ser capaz de reduzir o consumo de recursos desnecessários (ex. hardware, software, armazenamento, energia elétrica) disponibilizando somente o necessário para determinado projeto ou solução e distribuindo melhor tais recursos.

O conceito é bem simples. Trata-se de um modelo de gestão automatizada para ambientes computacionais, porém, sem um recurso desta natureza, os modelos de Cloud Computing tornam-se ineficazes, por não atingirem seus objetivos de entrega de ambientes (como SaaS, PaaS e IaaS) com maior agilidade e eficiência operacional do que os modelos convencionais. E por último, mas, não menos importante: Custo/benefício mais atrativo para aqueles que  utilizam este modelo de computação.

Um grande abraço!
Antonio Ricardo Goncalves

Gerenciamento de Cloud Computing (Private Cloud)

Como mencionei no artigo anterior, o gerenciamento de Cloud Computing para quem adota o modelo de Private Cloud (Nuvem Privada) merece atenção especial, pois, sem a aplicação de um bom modelo de gestão aliado a um software destinado a este fim, sua nuvem privada pode tornar-se um fracasso.

É necessário um conjunto de hardware e software para a criação de uma Nuvem Privada, e para que este conjunto funcione harmoniosamente, você precisará de uma solução – software – destinada ao gerenciamento de sua nuvem.  Um bom exemplo para entender como isto funciona é comparar com uma orquestra, onde existem músicos excepcionais e que dominam totalmente seus respectivos instrumentos musicais, porém, para que haja harmonia entre todos estes e seja produzida boa música e um resultado em grupo, o maestro é fundamental na condução do conjunto.

Existem vários fornecedores no mercado que entregam ótimas soluções para esta finalidade. Muitos fornecem soluções completas, onde você terá desde o modelo conceitual, hardware e software e a plataforma para fazer a gestão da sua Nuvem Privada.

Um ponto fundamental a ser destacado para quem passa a utilizar uma Nuvem Privada é basear a maior parte dos recursos oferecidos no conceito de auto-serviço (self-service), onde, o cliente pode criar seus próprios recursos, como máquinas virtuais (servidores / desktops), armazenamento etc. Este cliente pode ser um departamento de T.I. ou outro qualquer, dependendo da necessidade, e isto é definido de acordo com um modelo de gestão baseado nas necessidades dos negócios da empresa.

As duas fontes a seguir podem lhe fornecer muita informação sobre este assunto: (Obs. Os exemplos não são patrocinados, como sempre faço. Caso queira sugerir algum outro exemplo, fique a vontade. Sugestões são sempre bem-vindas!) http://www.microsoft.com/en-us/server-cloud/solutions/virtualization-private-cloud.aspx#fbid=IW3d6VZuKPD
http://www.vmware.com/br/products/vsphere/

Um grande abraço!
Antonio Ricardo

Gerenciamento de Cloud Computing

Como em qualquer outra atividade, a gestão de recursos da TI é essencial, porém, com o avanço da TI e a adoção de modelos baseados em computação em nuvem, este tema torna-se muito mais crítico e importante na obtenção dos resultados desejados.

Devido a este modelo (Cloud Computing) entregar muito mais confiabilidade, disponibilidade, agilidade e flexibilidade – é o que todos desejam, certo?! –; a atenção ao gerenciamento deste padrão de ambiente necessita muito estudo e gerenciamento no dia-a-dia de sua operação. Isto vale tanto para quem contrata ou comercializa algo como SaaS, IaaS, PaaS ou para quem utiliza Private / Hybrid Cloud.

Para ficar bem fácil de compreender, pensemos primeiramente num caso em que uma empresa utiliza correio eletrônico no modelo SaaS (Software as a Service). Todos nós concordamos que ficar sem email por minutos (ou segundos), pode custar caro, principalmente para áreas como centrais de atendimento, comercial e assim por diante. Portanto, quando pensamos no gerenciamento, devemos tomar cuidados especiais, como por exemplo, o tipo de contrato que está sendo contemplado com o fornecedor de serviços, pois, se você necessita de 99,999% de disponibilidade e assina um SLA de 95,9% dificilmente atingirá seu objetivo de disponibilidade, pois, a maior parte das empresas – ou todas elas – baseiam seus preços de SaaS nesta questão – a disponibilidade. Quando você analisar o Custo x Benefício de alguma solução deste tipo, o SLA substituiu exatamente o termo Benefício. (Custo X Benefício = Custo x SLA).  Quer ter melhor beneficio ou ter um SLA mais agressivo? Terá que desembolsar mais (Isto já aplicado nos modelos tradicionais, como Outsourcing).

Podemos considerar importantes, neste exemplo, outros fatores, como as funcionalidades que o produto disponibiliza, pois, sua empresa pode necessitar também de soluções de colaboração, mensagem instantânea ou ainda funcionalidades de CRM que podem ser agregadas a este produto de correio eletrônico, e que, se forem adquiridas separadamente podem custar mais ou ainda não se integrarem. Além disso, não podemos esquecer NUNCA de pensarmos num parceiro de verdade e não simplesmente em um fornecedor, pois, a entrega do serviço dependerá totalmente dele e nos momentos de crise ele deverá ser seu Parceiro e não apenas o Fornecedor de SaaS (este é um fator bem crítico no dia-a-dia de quem utiliza Cloud Computing).

Também podemos adotar Cloud Computing internamente, que conhecemos como Private Cloud, e neste caso, necessitamos de modelos mais robustos de gestão, o que inclui, além do que citei nos parágrafos anteriores, soluções integradas de gerenciamento de seu ambiente de computação em nuvem.  (Vou dedicar meu próximo artigo a este tópico para não estender demais este aqui. Já está longo demais… :-D)

Finalizando a ideia, podemos perceber que, apenas num único e simples exemplo – do correio eletrônico -, vários tipos ou domínios de gerenciamento são necessários para obtenção de bons resultados. A seguir, cito alguns: Gestão de contratos, gestão de riscos, gestão financeira, gestão de ativos, gestão de fornecedores, gestão de crise entre outros.

Mas tenha calma, não se desespere, pois, tudo que foi citado é perfeitamente viável de ser colocado em prática, principalmente adotando metodologias e conhecimento para apoiar a gestão de seu dia-a-dia.

Todos já ouvimos falar de ITIL, TOGAF, COBIT, PM e outras siglas e letrinhas que fornecem excelentes conhecimento,  métodos e maneiras de superar tais desafios… Não ouvimos?! Tem muita coisa boa para se colocar em prática e apoiar o avanço da adoção da tecnologia que você necessita. Também existem vários frameworks direcionados a gestão de Cloud Computing pipocando… Então, siga em frente!

Um grande abraço!
Antonio Ricardo Gonçalves

O que é Cloud Computing?

Cloud Computing

OS CONCEITOS:

Porque o termo Nuvem  (em inglês: Cloud) é utilizado?
A ideia é bem simples: A(s) nuvem(ns) não possui(em) forma definida, ou seja, podem assumir qualquer formato ou tamanho, dependendo de fatores como vento, pressão atmosférica, temperatura etc, podem juntar-se ou dispersar, formando novas nuvens; também podem deslocar-se entre locais totalmente distintos.

Agora vamos aplicar a ideia acima a computação.

E o que significa Computação em Nuvem (em inglês: Cloud Computing)?
Basicamente a Computação em Nuvem refere-se a utilização de recursos computacionais como memória, capacidade de armazenamento de dados/informações, capacidade de processamento/cálculo baseados em servidores compartilhados e interligados através da Internet, baseados no princípio da Computação em Grade (em inglês: Grid Computing).

Grid Computing é um modelo de computação onde é possível executar processos através de computadores distribuídos localmente ou geograficamente distribuídos. A Computação em Grade (Grid Computing) é uma evolução da Computação Distribuída. Um exemplo muito interessante de Grid Computing é o “World Community Grid”. Acesse o site http://www.worldcommunitygrid.org para conhecer. Caso queria saber mais sobre os assuntos Grid Computing e Computação Distribuída, a Wikipedia é sempre uma boa fonte para pesquisa.

Outra questão fundamental para entendermos a Computação em Nuvem é a Virtualização, que também possui um conceito simples. A ideia da virtualização é isolar as aplicações/sistemas do hardware, através de uma camada de software conhecida como Hypervisor. O objetivo deste modelo é prover a liberdade de execução de um sistema, sem depender do tipo de hardware utilizado.

Finalmente chegamos onde eu queria: Sintetizar todas as ideias acima em uma explicação para o que conhecemos como Cloud Computing e utilizamos em nosso dia-a-dia.

Cloud Computing (esta é minha visão): Um conjunto de hardware agrupado (em inglês: clustered) com capacidade automática (ou autônoma) de prover serviços através de provisionamento e análise em tempo real da capacidade deste conjunto de hardware. Este modelo tem como objetivo o consumo transparente de recursos de computação que podem estar em qualquer lugar de forma simples e amigável a quem consome o serviço. Este serviço, de acordo com sua capacidade de autogerenciamento, pode “crescer” ou “encolher” de acordo com a necessidade de que está consumindo.

Resumidamente, a ideia de Cloud Computing é atender as necessidades de um consumidor de TI, sem burocracia, com agilidade e de maneira totalmente transparente e gerenciável, baseado nos conceitos acima descritos.

 

A PRÁTICA:

Na prática, utilizamos Cloud Computing o tempo todo. Quando utilizamos serviços como o Google, Gmail, Outlook, Azure, Facebook estamos consumindo Cloud Computing, pois, independente de onde está a infraestrutura e os softwares envolvidos na solução – e estes estão espalhados pelo mundo todo – o que precisamos está sempre ao nosso alcance.

Atualmente existem inúmeros tipos de ofertas de Computação em Nuvem no mercado de TI. Desde as grandes como Microsoft, IBM, HP, Google, Amazon até pequenas empresas fornecem soluções neste modelo. Cabe a cada um, profissional ou empresa, entender o que necessita em quem pode lhe fornecer a melhor solução.

Quando falamos de Cloud Computing, geralmente entramos nos conceitos de TI como um Serviço (TI as a Service), como SaaS, IaaS, Paas, DaaS e vários outros. Caso queira saber sobre estes modelos, acesse este artigo https://antonioricardo.org/2013/03/28/o-que-e-saas-iaas-e-paas-em-cloud-computing-conceitos-basicos  ou navegue pelo blog para mais informações.

Um grande abraço!
Antonio Ricardo

O que é DTaaS – Desktop as a Service (Desktop como um serviço)

DaaS

Com o objetivo de complementar a publicação anterior, a seguir, explico o que é DTaaS e como podemos utilizar este conceito em nosso dia-a-dia.Como o nome sugere, DTaaS (Desktop as a service) é mais um modelo de utilização de recursos de Tecnologia da Informação, onde é possível substituir o modelo tradicional de aquisição de produtos, pela contratação de serviços, ou seja, ao invés de você adquirir um desktop (hardware) e softwares (sistema operacional, softwares de proteção, softwares de produtividade etc.), você contrata um provedor de serviços que irá fornecer tal infraestrutura, através de um modelo pré-determinado (normalmente baseado em Cloud Computing / Virtualização) cobrando uma assinatura mensal.

O conceito de DTaaS está diretamente associado a recursos de Virtualização de Desktops e Cloud Computing (Também chamado de Virtual Desktop as a Service). No segundo caso, podemos expandir o modelo de Cloud Computing em modelos tradicionais, em Private Cloud (Nuvem Privada) e também na mescla de ambos, chamados de modelos híbridos.

De forma simplista – e para facilitar o entendimento – podemos fazer um paralelo entre DTaaS e SaaS (Software as a Service) onde no modelo DTaaS, além do software (descrito no SaaS), adquirimos também o hardware como um serviço, pagando pela utilização ao invés de comprar o alugar. Isto significa que o provedor deste serviço fica responsável por toda a infraestrutura, entregando todos os recursos de hardware e software dentro de um “pacote de serviços”.

E como funciona a estrutura de virtual desktop as a service na prática?
Esta solução é formada por Servidores (onde são criadas estruturas para fornecimento destes desktops virtuais, através da utilização de produtos fornecidos por empresas como Citrix, Dell, VMware entre outras), elementos de rede como roteadores e switches e por clientes ou Thin Clients (Estes responsáveis por acessar os recursos armazenados nos servidores e disponibilizá-los para os usuários da solução).
Um ponto muito positivo e importante neste modelo é seu gerenciamento facilitado pela arquitetura das soluções que proporciona maior segurança e agilidade na administração.
Como ponto negativo ou crítico cito a necessidade de atenção com sua característica de alta disponibilidade, pois, se algo falhar por falta de redundância de recursos ou falha na especificação da capacidade de carga, pode haver indisponibilidade para muitos usuários ao simultaneamente.

Como sempre menciono em meus artigos, adotar uma solução de TI em um ambiente corporativo é uma questão delicada, e deve estar sempre direcionada ao apoio direto ao negócio.  O DTaaS é apenas mais um modelo dentre muitos e seu sucesso depende primeiramente da necessidade de sua utilização, combinando-se a isto um ótimo projeto de viabilização, implantação e adoção do modelo.

Um abraço,
Antonio Ricardo