Neste workshop, abordamos conceitos de automação de infraestrutura, também conhecida como "Infraestrutura como Código" e realizamos demonstrações práticas da automatização de criação de máquinas virtuais, utilizando as ferramentas Vagrant e Puppet. Também falamos sobre conteiners e demonstramos o provisionamento de um ambiente utilizando o Docker. Contamos ainda com a participação do convidado Philipe Costa, que bateu um papo sobre o Ansible, poderosa ferramenta open source de automatização e provisionamento ágil. Tivemos também a presença do Psicólogo Vitor Santos, que nos trouxe a palestra "Conhecendo O Meu Eu Foda - Competências para se destacar e chegar em um nível extra".
Neste repositório, estão os arquivos utilizados durante a apresentação e demonstração prática dos provisionamentos com Vagrant+Puppet e com Docker.
- A pasta "1-exemplo_pratico" possui duas subpastas. Uma contendo o exemplo prático de provisionamento com Vagrant e Puppet e uma outra subpasta contendo o exemplo prático de provisionamento com Docker.
- Na raiz do repositório você irá encontrar o arquivo da apresentação utilizada no workshop.
- Neste projeto, foi provisionado um ambiente contendo dois servidores. Um servidor contendo o Apache hospedando um site simples de cadastro de pessoas (uma espécie de agenda online) e um outro servidor contendo o banco de dados MySQL, onde são persistidos os dados cadastrados por meio do site. No servidor do MySQL foi criado um banco de dados chamado "agenda" com uma tabela apenas, chamada "pessoa".
- O provider utilizado para a criação das máquinas foi o VirtualBox.
- O Vagrantfile está no diretório "workshop-automacao-infra/1-exemplo_pratico/vagrant/".
- O site com CRUD simples usado nos testes está na pasta "1-exemplo_pratico/manifests/site/" e foi baseado no projeto da Glaucia Lemos: https://github.com/glaucia86/projeto.crud.php
- Na pasta "1-exemplo_pratico/manifests/" se encontram os arquivos de provisionamento do Puppet, sendo que o arquivo "app.pp" é o arquivo de provisionamento da máquina do site e o arquivo "db.pp" é o arquivo de provisionamento da máquina de banco de dados.
- Lembrando que a pasta "manifests" é sincronizada com a pasta "/vagrant/manifests" existente dentro das máquinas virtuais criadas pelo Vagrant. Por isso, o Puppet instalado em cada uma das máquinas virtuais consegue, ao ser chamado, executar as instruções dos arquivos "app.pp" e "db.pp".
- Tanto o Vagrantfile quantos os arquivos do Puppet estão devidamente documentados com comentários nos códigos.
- Primeiro baixe e instale o VirtualBox de acordo com o seu sistema operacional: https://www.virtualbox.org/wiki/Downloads
- Faça o mesmo para o Vagrant, baixe-o e instale-o de acordo com o seu SO: https://www.vagrantup.com/downloads.html
- Clone este repositório com o comando: git clone https://github.com/carryontech/workshop-automacao-infra.git
- Navegue até o diretório "workshop-automacao-infra/1-exemplo_pratico/vagrant/"
- Execute o comando vagrant up.
- o comando vagrant up irá executar as intruções contidas no Vagrantfile para criar as máquinas virtuais. Conforme vocês vão ver dentro do Vagrantfile, na configuração de cada uma das máquinas existe uma linha chamando o Puppet. É o Puppet quem vai provisionar os recursos necessários em cada servidor, como o Apache, o PHP e o MySQL Server.
- Após a execução completa do vagrant up, você deve acessar o endereço http://192.168.50.10/site/ para validar o funcionamento.
- A máquina do site estará com o IP 192.168.50.10 e a máquina de banco de dados estará com o IP 192.168.50.11.
- Neste projeto, foi provisionado um ambiente contendo o mesmo site utilizado no exemplo de Vagrant+Puppet, porém, no exemplo com o Docker, o ambiente foi distribuído em 3 containers:
- Um container do servidor web NGINX.
- Um segundo container rodando o PHP com o driver PDO (PHP Data Object).
- E um terceiro container rodando o MySQL Server.
- As imagens Docker utilizadas no projeto foram baixadas do Docker Hub, sendo que a imagem do PHP não vem com o driver PDO instalado. Sendo assim, utilizou-se o docker build para criar, a partir da imagem oficial do PHP, uma nova imagem contendo o PHP e o PDO.
- Dentro da pasta 1-exemplo_pratico/docker/ você irá encontrar o seguinte conteúdo:
- Arquivo site.conf - Este é um arquivo de configuração do NGINX, que informa para esse serviço qual é o nome da aplicação, onde ele deve procurar o index do site, onde devem ser salvos os arquivos de log, dentre outras configurações.
- Arquivo Dockerfile - Esté o arquivo utilzado para fazer o build da nossa imagem do PHP. Neste arquivo constam as instruções para que o comando "docker build" possa baixar a imagem do PHP, instalar o driver PDO e criar uma nova imagem que aqui chamamos de "php-pdo-carryon".
- Arquivo docker-compose.yml - Neste arquivo estão todas as instruções para a composição do ambiente. Nele, cada container é tratado como um serviço. Sendo assim, em cada um desses serviços estão especificados: A imagem utilizada para rodar o container, o nome do container, a porta a ser exposta, variáveis de ambiente, volumes compartilhados, dentre outras configurações.
- Arquivo pessoa.sql - Conforme já dito, neste exemplo foi configurado um ambiente contendo um site que funciona como uma agenda online e um banco de dados MySQL. Assim como no exemplo de Vagrant+Puppet, foi criado um banco de dados chamado "agenda" com uma tabela chamada "pessoa". O arquivo "pessoa.sql" então será enviado para o container do MySQL e executado automaticamente para criar a tabela pessoa no banco de dados "agenda".
- Diretório "data" - Esta pasta foi criada para funcionar como um volume compartilhado entre o container do MySQL e o host de forma que os arquivos do banco de dados também estejam disponíveis localmente. Essa pasta foi especificada dentro do arquivo docker-compose.yml.
- Diretório "site" - Assim como a pasta "data", a pasta "site" também se trata de um volume compartilhado entre o host e container, neste caso, o container do NGNIX e o container do PHP, de forma que ambos os serviços tenham acesso aos arquivos do site.
- Se você não estiver com o Docker instalado, realize a instalação.
- Segue abaixo o link da documentação oficial do Docker referente a instalação, que é bem simples. É só seguir as orientações de acordo com o seu sistema operacional. Você vai encontrar as opções ao lado esquerdo da página ;)
- Documentação do Docker: https://docs.docker.com/install/
- Clone este repositório caso ainda não o tenha feito: git clone https://github.com/carryontech/workshop-automacao-infra.git
- Navegue até a pasta "workshop-automacao-infra/1-exemplo_pratico/docker/"
- Execute o seguinte comando (esse ponto após php-pdo-carryon faz parte do comando): docker build -t php-pdo-carryon .
- O comando acima irá criar, a partir da imagem oficial do PHP, uma imagem chamada php-pdo-carryon contendo o PHP e o driver PDO, para isso, o docker build irá ler as instruções contidas no arquivo Dockerfile. O ponto ao final do comando serve para especificar que o Dockerfile está no diretório corrente.
- Finalizada a execução do docker build, execute o comando: docker-compose up
- Este comando irá ler o arquivo docker-compose.yml e compor todo o ambiente exatamente como especificado neste arquivo.
- Para testar o funcionamento, basta acessar o endereço: http://localhost:8080