Docker
  • Introdução a Containeres e Docker
    • Introdução
    • O que é um container e suas vantanges
    • VM versus Container
    • Como funcionam os containers
    • Linux
    • Container sem Docker
      • cgroup
      • cpu.max
    • LxC
    • LxD
    • Containers versus Imagens
    • Arquitetura do Docker
    • Arquitetura do Docker mais a fundo
    • Projetos Open Source
  • Instalação do Docker
    • Linux
    • Windows
      • Docker Desktop
      • Rancher Desktop
      • WSL
    • Mac
    • Visual Studio Code
  • Primeiros Passos com Docker
    • Criação e listagem básica de um container
    • Interagindo com o container
    • Executando containers continuamente
      • nginx
      • docker container run
      • docker container run nginx
      • docker container run -d nginx
      • docker container exec
    • Como usar publish de porta
      • docker container stop
      • docker container start
      • docker container rm
      • docker container rm -f $(docker container ls -qa)
    • Containers e variáveis de ambiente
      • docker container run -e
  • Desafio
    • Desafio 01 - Banco de Dados Postgresql
    • Desafio 02 - Banco de Dados MySQL
    • Desafio 03 - Banco de Dados MongoDB
  • Executando a sua primeira aplicação em containers
    • Introdução
    • Preparando o container para a aplicação
    • Executando a aplicação
      • docker container cp
  • Primeiros Passos com Docker Images
    • Introdução
    • OverlayFS na Prática
    • Copy-on-Write
    • Formas de criar uma imagem Docker
    • Como funciona o Docker Commit
    • Docker Commit na Prática
      • docker commit
    • Entendendo melhor a sua imagem
      • docker image history
      • docker image inspect
    • Entrando mais a fundo na imagem
    • Como usar a imagem Docker no modo raiz
  • Avançando em imagens Docker com Dockerfile
    • O que é Dockerfile
    • Primeira Imagem com Dockerfile
      • docker image build
    • Como funciona a construção com Dockerfile
    • Possibilidades com Dockerfile
    • FROM
    • RUN
    • WORKDIR
    • COPY
    • ADD
    • LABEL
    • ENV
    • VOLUME
    • ARG
    • EXPOSE
    • USER
    • ENTRYPOINT
    • CMD
    • ENTRYPOINT versus CMD
    • Principais comandos com imagem
    • Imagem da aplicação com Dockerfile
    • Comparando Docker Commit com Dockerfile
  • Docker Registry
    • Introdução
    • Docker Hub
    • Sua imagem com o nome certo
    • Renomear imagens com Docker Tag
      • docker image tag
    • Enviando a sua primeira imagem para o Docker Hub
      • docker image push
      • docker image pull
  • Algumas boas práticas para construção de imagem
    • Um processo por container
    • Usar imagens confiáveis
    • Otimizar sempre a sua imagem
    • Uso inteligente das camadas
    • Dockerignore
  • Multistage Build
    • Introdução
    • Multistage build na prática
    • Target para fazer o build
      • docker image build --target
    • Imagem externa no Multistage build
    • Usar um estágio de build como base
  • Docker Volume
    • Introdução
      • docker volume
    • Bind Mount
    • Particularidades do Bind Mount
    • Bind Mount no Windows
    • Exemplo com Bind Mount
    • Docker Volume
      • docker volume create
      • docker volume inspect
      • docker volume ls
      • docker volume prune
      • docker volume rm
    • Onde ficam os arquivos do Docker volume?
    • Usando o volume no Dockerfile
    • Como fazer backup de um Docker Volume
    • Exemplo com Docker Volume
    • Storage tmpfs
    • Como criar algo funcional com o que aprendemos
  • Network
    • Introdução
    • Componentes do Docker Network
    • Rede Bridge na prática
      • docker network
      • docker network create
      • docker network inspect
      • docker network ls
      • docker network prune
      • docker network rm
    • Criando a sua rede bridge
      • docker network connect
      • docker network disconnect
    • Como funciona a rede bridge por dentro
    • Rede Host na prática
    • Rede none da prática
    • Como adicionar domínios no seu container
  • Aplicação 100% no Docker
    • Introdução
    • Criação da Imagem e Envio para o Docker Hub
    • Criação do Docker Network
    • Container do PostgreSQL
    • Container da Aplicação Web
    • Atualização da aplicação
  • Docker Compose
    • Introdução
      • docker compose
    • A evolução do docker compose
    • Criação básica de um Docker Compose
      • docker compose attach
      • docker compose build
      • docker compose config
      • docker compose cp
      • docker compose create
      • docker compose down
      • docker compose events
      • docker compose exec
      • docker compose images
      • docker compose kill
      • docker compose logs
      • docker compose ls
      • docker compose pause
      • docker compose port
      • docker compose ps
      • docker compose pull
      • docker compose push
      • docker compose restart
      • docker compose rm
      • docker compose run
      • docker compose scale
      • docker compose start
      • docker compose stats
      • docker compose stop
      • docker compose top
      • docker compose unpause
      • docker compose up
      • docker compose version
      • docker compose wait
      • docker compose watch
    • Variáveis de Ambiente
    • Volume Bind Mount
    • Docker Volume
    • Docker Network - Bridge
    • Docker Network - Host Driver e Add Host
    • Ordenando a execução dos containers
    • Compose com build de imagem
    • Como Parametrizar o Compose com Variáveis de Ambiente
    • Múltiplos Composes
    • Extends
    • Merge
    • Include
    • Profiles
    • Comandos importantes do Docker Compose
  • Troubleshooting
    • Introdução
    • Docker Info
    • Docker Events
    • Docker Logs
    • Docker Inspect
    • Docker Top
    • Docker Stats
    • Docker Exec
  • Resiliência e Gerenciamento de Recursos
    • Introdução
    • Docker Restart
      • Introdução
      • on-failure
      • unless-stopped
      • always
      • Docker Compose
    • Healthcheck
      • Introdução
      • Linha de Comando
      • Docker Compose
      • Direto na Imagem
    • Gerenciamento de Recurso
      • CPU
        • Como Gerenciar CPU
        • Prática
      • Memória
        • Como Gerenciar Memória
        • Prática
      • Docker Compose
  • Fazendo um ambiente mais seguro
    • Introdução
    • Docker Scout
      • Introdução
      • Verificação Simples de Imagem
      • Como adicionar um repositório
      • Primeira melhoria na imagem
  • BUSCA RÁPIDA
    • Referências
    • Comandos
      • docker commit
      • docker compose
      • docker container
      • docker image
      • docker network
      • docker volume
    • Dockerfile
Powered by GitBook
On this page
  • Docker Stateless vs Stateful
  • Conceitos
  • Aplicações Stateless em Docker
  • Aplicações Stateful em Docker
  • Exemplos
  • Desafios de Aplicações Stateful em Docker
  • Conclusão
  1. Docker Volume

Introdução

Docker Stateless vs Stateful

Conceitos

Stateless (Sem Estado)

Um aplicativo ou serviço stateless (sem estado) não armazena informações sobre a sessão do usuário ou o estado do aplicativo entre as requisições. Cada requisição é independente, e não depende das requisições anteriores ou futuras. Isso facilita a escalabilidade, pois qualquer instância do serviço pode processar qualquer requisição.

Stateful (Com Estado)

Um aplicativo ou serviço stateful (com estado) mantém informações sobre a sessão ou o estado do usuário entre as requisições. Isso significa que há dependência entre as requisições, e o estado é preservado de uma para outra. Essas aplicações geralmente dependem de uma forma de persistência, como um banco de dados ou um sistema de arquivos, para armazenar o estado.

Aplicações Stateless em Docker

Aplicações stateless são ideais para ambientes de contêineres, como o Docker, por várias razões:

Escalabilidade

Como não há dependência de estado, é fácil escalar o número de instâncias do serviço. Novas instâncias podem ser adicionadas ou removidas dinamicamente sem preocupações com sincronização de estado.

Tolerância a Falhas

Se um contêiner falhar, outro contêiner pode assumir o processamento das requisições sem perda de informações.

Deploys Simples

Atualizar uma aplicação stateless é mais fácil, pois não há necessidade de gerenciar a migração de estados entre versões.

Aplicações Stateful em Docker

Aplicações stateful podem ser mais complexas para gerenciar em Docker, pois envolvem a persistência de dados e o gerenciamento do estado. No entanto, ainda é possível executar essas aplicações em contêineres, utilizando algumas práticas:

Volumes

Usar volumes Docker para persistir dados no sistema de arquivos do host, permitindo que os dados sobrevivam à recriação dos contêineres.

Banco de Dados Externo

Externalizar a persistência do estado para bancos de dados, como MySQL, PostgreSQL, ou outros sistemas de armazenamento distribuído que gerenciam o estado de forma robusta e independente dos contêineres.

Clusterização

Utilizar ferramentas de orquestração, como Kubernetes, para gerenciar e garantir a consistência e disponibilidade do estado em ambientes distribuídos.

Exemplos

Exemplo de Aplicação Stateless

Um servidor web que serve arquivos estáticos ou processa requisições HTTP simples, onde cada requisição é independente, e não há necessidade de manter uma sessão de usuário entre requisições.

docker run -d -p 80:80 nginx

Exemplo de Aplicação Stateful

Um banco de dados que precisa manter o estado das transações e dados entre as requisições.

docker run -d -v db_data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=senha mysql

Desafios de Aplicações Stateful em Docker

Gerenciamento de Estado

Manter a consistência do estado pode ser desafiador, especialmente em ambientes distribuídos e com múltiplas réplicas de contêineres.

Recuperação de Falhas

A recuperação de contêineres falhos sem perda de dados é crítica para aplicações stateful.

Conclusão

Embora Docker seja mais naturalmente adaptado para aplicações stateless devido à sua natureza efêmera e escalável, com as práticas adequadas, é possível executar aplicações stateful de forma eficiente. A escolha entre stateless e stateful dependerá das necessidades específicas da aplicação e do quanto o estado é fundamental para o funcionamento da mesma.

Tipos de Volume:

  • Bind

  • Volume

  • tmpfs

  • drivers

PreviousDocker VolumeNextdocker volume

Last updated 9 months ago