<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Victor Hugo</title>
    <description>The latest articles on DEV Community by Victor Hugo (@victorhundo).</description>
    <link>https://dev.to/victorhundo</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F202443%2F67c9daaa-ed09-4be5-8c53-ab50c98f8b05.jpeg</url>
      <title>DEV Community: Victor Hugo</title>
      <link>https://dev.to/victorhundo</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/victorhundo"/>
    <language>en</language>
    <item>
      <title>Administrando Sistemas com Docker</title>
      <dc:creator>Victor Hugo</dc:creator>
      <pubDate>Sat, 24 Aug 2019 22:04:03 +0000</pubDate>
      <link>https://dev.to/opendevufcg/administrando-sistemas-com-docker-4pgm</link>
      <guid>https://dev.to/opendevufcg/administrando-sistemas-com-docker-4pgm</guid>
      <description>&lt;p&gt;O uso de containers na &lt;a href="https://www.ibm.com/developerworks/community/blogs/tlcbr/entry/mp234?lang=en" rel="noopener noreferrer"&gt;virtualização&lt;/a&gt; e isolamento de aplicações está cada vez mais em alta nos projetos de código aberto e o Docker se destaca como a principal tecnologia do mercado, tendo sido recentemente classificada como a plataforma mais buscada no Stack Overflow (e a segunda mais amada, perdendo apenas para o Linux). A seguir, falaremos de conceitos básicos dessa tecnologia partindo de uma perspectiva da administração de sistemas.&lt;/p&gt;

&lt;h2&gt;
  
  
  Administrar Sistemas
&lt;/h2&gt;

&lt;p&gt;Algumas funções que um administrador de sistemas é encarregado de exercer são de instalar, suportar e fazer manutenção de servidores e, como o nome já sugere, sistemas em geral. Isso significa que, em uma equipe de desenvolvimento, as plataformas que são utilizadas pelos desenvolvedores devem ser fornecidas por profissionais dessa área, como sistemas de controle de versão, de revisão de código, controle de processo e diversos outros sistemas criados especialmente para o ambiente de desenvolvimento.&lt;/p&gt;

&lt;p&gt;Dependendo da necessidade da equipe de desenvolvimento, as escolhas das tecnologias podem ocasionar conflitos entre si, como sistemas que usam a mesma linguagem de programação em versões distintas ou sistemas legados que utilizam tecnologias que não recebem mais suporte. Esses problemas crescem exponencialmente quando todos eles estão rodando em uma única máquina física.&lt;/p&gt;

&lt;p&gt;Conseguir separar recursos computacionais (memória, espaço em disco e processamento), além de ter um isolamento completo de cada sistema, é o ideal para o administrador de sistemas e é por isso que o Docker, aliado aos seus containers, se torna o mais novo parceiro para essa área.&lt;/p&gt;

&lt;h2&gt;
  
  
  Hello Docker World!
&lt;/h2&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/cdn-cgi/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fmrshtjgrz3uwgrq4rkp8.jpg" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/cdn-cgi/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fmrshtjgrz3uwgrq4rkp8.jpg" alt="Banner Docker" width="800" height="75"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Agora que entendemos a importância do Docker para a instalação e manutenção de sistemas, vamos falar de alguns conceitos básicos dessa tecnologia e recomendamos que você tenha o Docker instalado na sua máquina para darmos prosseguimento com esse texto. Caso não tenha instalado, recomendamos que leia a &lt;a href="https://docs.docker.com/install/" rel="noopener noreferrer"&gt;documentação de como fazer isso&lt;/a&gt;.&lt;/p&gt;

&lt;p&gt;Para verificar que seu ambiente está configurado de forma correta, basta executar o seguinte comando abaixo. Se aparecer a mensagem “Hello from Docker!”, tudo ocorreu bem:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;sudo docker run hello-world
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;&lt;a href="https://media.dev.to/cdn-cgi/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Ftog1zj3mlhwyyc9b8cxq.gif" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/cdn-cgi/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Ftog1zj3mlhwyyc9b8cxq.gif" alt="Hello-World-Gif" width="734" height="456"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Ao executar esse comando, nós chamamos o binário do Docker, criamos um container a partir da opção &lt;code&gt;run&lt;/code&gt; e dizemos que o container que será criado é da imagem &lt;code&gt;hello-world:latest&lt;/code&gt;. Uma imagem Docker é um container pré-configurado em que será utilizado como referência para &lt;strong&gt;criar containers&lt;/strong&gt;. As imagens são baixadas do Docker Hub; no nosso caso, utilizamos a imagem &lt;a href="https://hub.docker.com/_/hello-world" rel="noopener noreferrer"&gt;hello-world&lt;/a&gt;&lt;/p&gt;

&lt;h2&gt;
  
  
  Subindo um sistema com Docker
&lt;/h2&gt;

&lt;p&gt;Agora que temos o Docker instalado e tivemos uma breve ideia de como criar um container, vamos criar algo mais útil para um ambiente de desenvolvimento: um container do GitLab!&lt;/p&gt;

&lt;p&gt;Para isso, execute:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;sudo docker run \
  -p 8080:80 \
  -p 222:22 \
  --name gitlab \
  -v /srv/gitlab/config:/etc/gitlab \
  -v /srv/gitlab/logs:/var/log/gitlab \
  -v /srv/gitlab/data:/var/opt/gitlab \
  gitlab/gitlab-ce:latest
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Utilizamos o parâmetro &lt;strong&gt;name&lt;/strong&gt; para que possamos identificar com mais facilidade o container quando ele for listado através do comando &lt;code&gt;docker ps&lt;/code&gt;. A saída desse comando será algo como:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;CONTAINER ID        IMAGE                       COMMAND                 CREATED             NAMES                       NAMES                                            

80e2ce68a5bf        gitlab/gitlab-ce:latest   "/assets/wrapper"     5 weeks ago         0.0.0.0:222-&amp;gt;22/tcp, 0.0.0.0:8080-&amp;gt;80/tcp, 443/tcp   gitlab
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Além do nome do container e a partir de qual imagem ele será criado, também especificamos parâmetros de &lt;strong&gt;volume&lt;/strong&gt; (parâmetro -v) e &lt;strong&gt;porta&lt;/strong&gt; (parâmetro -p), que são fundamentais para a administração de qualquer sistema e que explicaremos com mais detalhes a seguir.&lt;/p&gt;

&lt;h3&gt;
  
  
  Volumes
&lt;/h3&gt;

&lt;p&gt;Volumes são a forma com que o Docker gerencia o sistema de arquivos, fazendo ligação da virtualização dentro do container com os diretórios da máquina real. Os containers foram projetados para ser efêmeros: caso existam dados que precisem ser salvos ou lidos/escritos é importante utilizar volumes; caso contrário, os dados serão perdidos com a destruição do container.&lt;/p&gt;

&lt;p&gt;Existem dois tipos de volumes: "com bind" e "sem bind". Volumes com bind são utilizados quando você quer especificar um caminho na sua máquina que será compartilhado com o container, enquanto nos volumes sem bind a especificação do endereço é feita pelo próprio Docker.&lt;/p&gt;

&lt;p&gt;A criação do volume pode ser feito na criação do container utilizando o parâmetro &lt;code&gt;-v&lt;/code&gt;:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;# Exemplo de criação de volume com bind
-v /home/user/container_data:/opt/app
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;





&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;# Exemplo de criação de volume sem bind
-v /opt/app (volume sem bind)
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Normalmente, volumes com bind são utilizados quando é &lt;strong&gt;preciso fazer modificações&lt;/strong&gt; nos dados frequentemente (ao alterar os dados na pasta da sua máquina real em que está sendo feito o bind, os dados dentro do container também serão alterados). &lt;strong&gt;Arquivos de configuração ou códigos de desenvolvimento são exemplos de bons usos desse tipo de volume.&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;Já os volumes sem bind geralmente são utilizados quando queremos &lt;strong&gt;apenas salvar as informações&lt;/strong&gt; e queremos apenas ler esses dados. &lt;strong&gt;Banco de dados&lt;/strong&gt; é um exemplo que pode utilizar esse tipo de volume.&lt;/p&gt;

&lt;p&gt;No nosso caso, utilizamos o parâmetro de volume três vezes, para mapear e separar arquivos de configuração, arquivos de log e os dados do GitLab:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;-v /srv/gitlab/config:/etc/gitlab \
-v /srv/gitlab/logs:/var/log/gitlab \
-v /srv/gitlab/data:/var/opt/gitlab \
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;O diretório da esquerda, por exemplo, &lt;code&gt;/src/gitlab/config&lt;/code&gt;, se refere ao diretório da máquina real, enquanto o da direita é o do container. Os arquivos alterados nesse diretório da máquina real também serão alterados dentro do container (e vice-versa).&lt;/p&gt;

&lt;p&gt;Além de facilitar a configuração e personalização dos sistemas, utilizar volumes também facilita na criação de backups ou na disponibilidade, já que ao subir um container com os dados que estão nos diretórios mapeados em outra máquina fará com que você tenha uma redundância do sistema.&lt;/p&gt;

&lt;h3&gt;
  
  
  Portas
&lt;/h3&gt;

&lt;p&gt;Uma das coisas mais poderosas do Docker é a sua gerência de rede. É possível &lt;a href="https://github.com/jessfraz/onion" rel="noopener noreferrer"&gt;rotear todo o tráfego de rede do container através do Tor&lt;/a&gt;, por exemplo, mas vamos nos conter em apenas abordar o redirecionamento de portas que é feito utilizando o &lt;strong&gt;parâmetro -p&lt;/strong&gt;.&lt;/p&gt;

&lt;p&gt;Serviços em redes são acessados através de portas, como páginas http (80), servidores de email (25) e login remoto (22) e precisam especificar, além do endereço IP, a porta de comunicação. O GitLab utiliza tanto uma interface web na porta 80, quanto pode-se acessá-lo remotamente com ssh na porta 22, porém é muito provável que outras aplicações já utilizem essas mesmas portas para outras aplicações na máquina real. Por isso, foram feitos os seguintes mapeamentos:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;-p 8080:80 \
-p 222:22 \

&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Ou seja, ao acessar a porta 8080 na máquina real, o Docker irá redirecionar para a porta 80 dentro do container, na qual está rodando o serviço web do GitLab. Da mesma forma é feito o mapeamento da porta 222 para a 22.&lt;/p&gt;

&lt;p&gt;Acessando &lt;a href="http://localhost:8080" rel="noopener noreferrer"&gt;http://localhost:8080&lt;/a&gt;, você terá acesso ao seu GitLab.&lt;/p&gt;

&lt;p&gt;Usando esse parâmetro do Docker com &lt;a href="https://httpd.apache.org/docs/2.4/howto/reverse_proxy.html" rel="noopener noreferrer"&gt;proxy Apache&lt;/a&gt;, por exemplo, é possível servir diversos serviços com redirecionamento para aplicações completamente isoladas através de containers.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/cdn-cgi/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F7fwq6suah3cefs9pfb32.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/cdn-cgi/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F7fwq6suah3cefs9pfb32.png" alt="apache+docker" width="800" height="362"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;h2&gt;
  
  
  Considerações Finais
&lt;/h2&gt;

&lt;p&gt;Resolver problemas de conflitos, fazer cópia do sistema para realizar testes, diminuir tempo de upgrade/manutenção e até melhorar a organização dos arquivos de configurações são vantagens que o uso do Docker pode trazer para o administrador de sistemas.&lt;/p&gt;

&lt;p&gt;Com uma breve explicação foi possível subir uma poderosa aplicação como o GitLab. Encorajamos que você se aprofunde nesse mundo de containers e, para isso, recomendamos:&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;
&lt;a href="https://docs.docker.com/" rel="noopener noreferrer"&gt;Documentação Docker&lt;/a&gt;;&lt;/li&gt;
&lt;li&gt;
&lt;a href="https://docs.gitlab.com/omnibus/docker/" rel="noopener noreferrer"&gt;Documentação da Imagem Docker do GitLab&lt;/a&gt;;&lt;/li&gt;
&lt;li&gt;
&lt;a href="https://github.com/jessfraz/dockerfiles" rel="noopener noreferrer"&gt;Jessie Frazelle (referência no mundo Docker)&lt;/a&gt;;&lt;/li&gt;
&lt;li&gt;
&lt;a href="https://www.youtube.com/watch?v=0cDj7citEjE" rel="noopener noreferrer"&gt;Canal do YouTube LINUXtips&lt;/a&gt;;&lt;/li&gt;
&lt;li&gt;
&lt;a href="https://github.com/victorhundo/docker-guide" rel="noopener noreferrer"&gt;Oficina de Docker no GitHub&lt;/a&gt;.&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;Muito obrigado pela leitura! Fique atento: em breve, teremos novos artigos de contribuidores do OpenDevUFCG aqui no &lt;strong&gt;dev.to&lt;/strong&gt;. Acompanhe o OpenDevUFCG no &lt;a href="https://twitter.com/OpenDevUFCG" rel="noopener noreferrer"&gt;Twitter&lt;/a&gt;, no &lt;a href="https://instagram.com/OpenDevUFCG" rel="noopener noreferrer"&gt;Instagram&lt;/a&gt; e, claro, no &lt;a href="https://github.com/OpenDevUFCG" rel="noopener noreferrer"&gt;GitHub&lt;/a&gt;.&lt;/p&gt;

</description>
      <category>docker</category>
      <category>sysadmin</category>
      <category>gitlab</category>
      <category>ptbr</category>
    </item>
  </channel>
</rss>
