Configure sua própria rede privada com o OpenVPN
O Vultr oferece uma incrível conectividade de rede privada para servidores executando no mesmo local. Mas às vezes você quer dois servidores em países diferentes
O Docker Swarm transforma seus servidores individuais em um cluster de computadores, facilitando o dimensionamento, a alta disponibilidade e o balanceamento de carga. O balanceador de carga Swarm implementa uma estratégia de balanceamento de carga round-robin e isso pode interferir no funcionamento correto de aplicativos stateful (legados) que requerem alguma forma de sessões fixas para permitir uma configuração de alta disponibilidade com várias instâncias. O Docker Enterprise Edition oferece suporte à sessão de camada 7, mas neste guia, focaremos na versão gratuita (CE) do Docker. Para implementar sessões complicadas, usaremos o Traefik.
Neste tutorial, usaremos duas instâncias do Vultr com endereços IP privados 192.168.0.100 e 192.168.0.101, ambos são nós de gerenciador do Docker Swarm (o que não é ideal para produção, mas é suficiente para este tutorial).
Este tutorial usa a jwilder/whoami
imagem do docker como aplicativo de demonstração. Esse contêiner simples responderá a uma chamada REST com o nome do contêiner de resposta, facilitando o teste se as sessões persistentes estão funcionando. Esta imagem é usada apenas para fins de demonstração e precisa ser substituída pela imagem do seu próprio aplicativo. O whoami-service
está configurado da seguinte maneira:
sudo docker network create whoaminet -d overlay
sudo docker service create --name whoami-service --mode global --network whoaminet --publish "80:8000" jwilder/whoami
sudo firewall-cmd --zone=public --add-port=80/tcp --permanent
sudo firewall-cmd --reload
Se subseqüentemente tivermos curl
o whoami
ponto de extremidade REST em http://192.168.0.100/
, podemos ver o balanceamento de carga round-robin do Docker Swarm em funcionamento.
curl http://192.168.0.100
I'm a6a8c9294fc3
curl http://192.168.0.100
I'm ae9d1763b4ad
curl http://192.168.0.100
I'm a6a8c9294fc3
curl http://192.168.0.100
I'm ae9d1763b4ad
curl http://192.168.0.100
I'm a6a8c9294fc3
Ele não serve para testar isso em navegadores modernos como o Chrome ou Firefox, porque eles são projetados para manter as conexões ativas (abertas) e o balanceador de carga do Docker Swarm só muda para o outro contêiner a cada nova conexão. Se você quiser testar isso com um navegador, precisará aguardar pelo menos 30 segundos para que a conexão feche antes de atualizar novamente.
O Traefik suporta nativamente o Docker Swarm, ele pode detectar e registrar ou cancelar o registro de contêineres em tempo real e se comunica com o seu aplicativo pela rede de sobreposição interna. O Traefik precisa de algumas informações sobre seu aplicativo antes que ele possa começar a manipular pedidos. Esta informação é fornecida à Traefik adicionando etiquetas ao seu serviço Swarm.
sudo docker service update --label-add "traefik.docker.network=whoaminet" --label-add "traefik.port=8000" --label-add "traefik.frontend.rule=PathPrefix:/" --label-add "traefik.backend.loadbalancer.stickiness=true" whoami-service
A lista abaixo descreve o significado de cada rótulo:
traefik.docker.network
: A rede de sobreposição do Docker pela qual o Traefik se comunicará com seu serviço traefik.port
: A porta na qual seu serviço está atendendo (esta é a porta exposta internamente, não a porta publicada)traefik.frontend.rule
: PathPrefix:/
liga a raiz de contexto /
a este serviço.traefik.backend.loadbalancer.stickiness
: Ativa sessões permanentes para este serviçoAgora que whoami-service
ele foi configurado com os rótulos necessários, podemos adicionar o serviço Traefik ao enxame:
sudo docker service create --name traefik -p8080:80 -p9090:8080 --mount type=bind,source=/var/run/docker.sock,destination=/var/run/docker.sock --mode=global --constraint 'node.role == manager' --network whoaminet traefik --docker --docker.swarmmode --docker.watch --web --loglevel=DEBUG
Este comando faz várias coisas ao mesmo tempo. A lista abaixo explicará com mais detalhes:
--name traefik
: O nome do nosso novo serviço Docker é traefik
-p8080:80
: Publicamos a porta da Traefik 80
em porta 8080
(a porta 80
já está em uso pelo nosso whoami-service
)-p9090:8080
: Publicamos a interface web do Traefik na porta 9090
--mount ...
: Montamos o soquete do Docker no contêiner para que o Traefik possa acessar o tempo de execução do Docker do host --global
: Queremos contêineres Traefik em cada nó do gerente por motivos de alta disponibilidade --constraint 'node.role == manager'
: Queremos que o Traefik seja executado apenas nos nós do gerente, porque os nós dos trabalhadores não podem fornecer ao Traefik as informações necessárias. Por exemplo, docker service ls
em um nó de trabalho não funciona, portanto, o Traefik nem seria capaz de descobrir quais serviços estão em execução--network whoaminet
: Conecta o Traefik à mesma rede que a nossa whoami-service
, caso contrário eles não podem se conectar. Dissemos anteriormente ao Traefik para se conectar ao nosso serviço nessa rede com a traefik.docker.network
etiquetatraefik
: Diga ao docker para usar a imagem mais recente do dock do Traefik para este serviço--docker --docker.swarmmode --docker.watch --web --loglevel=DEBUG
: Argumentos da linha de comando transmitidos diretamente ao Traefik para permitir a execução no modo de enxame do Docker ( --loglevel=DEBUG
é opcional aqui, mas interessante durante a instalação e neste tutorial)Tudo o que resta a fazer é abrir as portas necessárias no firewall do CentOS:
sudo firewall-cmd --zone=public --add-port=8080/tcp --permanent
sudo firewall-cmd --zone=public --add-port=9090/tcp --permanent
sudo firewall-cmd --reload
Assim que o Traefik é iniciado, você pode ver nos logs que o Traefik descobre os dois whoami
contêineres. Também está emitindo o nome do cookie que será usado para lidar com a sessão persistente:
time="2018-11-25T13:17:30Z" level=debug msg="Configuration received from provider docker: {\"backends\":{\"backend-whoami-service\":{\"servers\":{\"server-whoami-service-1-a179b2e38a607b1127e5537c2e614b05\":{\"url\":\"http://10.0.0.5:8000\",\"weight\":1},\"server-whoami-service-2-df8a622478a5a709fcb23c50e689b5b6\":{\"url\":\"http://10.0.0.4:8000\",\"weight\":1}},\"loadBalancer\":{\"method\":\"wrr\",\"stickiness\":{}}}},\"frontends\":{\"frontend-PathPrefix-0\":{\"entryPoints\":[\"http\"],\"backend\":\"backend-whoami-service\",\"routes\":{\"route-frontend-PathPrefix-0\":{\"rule\":\"PathPrefix:/\"}},\"passHostHeader\":true,\"priority\":0,\"basicAuth\":null}}}"
time="2018-11-25T13:17:30Z" level=debug msg="Wiring frontend frontend-PathPrefix-0 to entryPoint http"
time="2018-11-25T13:17:30Z" level=debug msg="Creating backend backend-whoami-service"
time="2018-11-25T13:17:30Z" level=debug msg="Adding TLSClientHeaders middleware for frontend frontend-PathPrefix-0"
time="2018-11-25T13:17:30Z" level=debug msg="Creating load-balancer wrr"
time="2018-11-25T13:17:30Z" level=debug msg="Sticky session with cookie _a49bc"
time="2018-11-25T13:17:30Z" level=debug msg="Creating server server-whoami-service-1-a179b2e38a607b1127e5537c2e614b05 at http://10.0.0.5:8000 with weight 1"
time="2018-11-25T13:17:30Z" level=debug msg="Creating server server-whoami-service-2-df8a622478a5a709fcb23c50e689b5b6 at http://10.0.0.4:8000 with weight 1"
time="2018-11-25T13:17:30Z" level=debug msg="Creating route route-frontend-PathPrefix-0 PathPrefix:/"
time="2018-11-25T13:17:30Z" level=info msg="Server configuration reloaded on :80"
time="2018-11-25T13:17:30Z" level=info msg="Server configuration reloaded on :8080"
Se nos curvarmos http://192.168.0.100:8080
, podemos ver que um novo cookie _a49bc
foi definido:
curl -v http://192.168.0.100:8080
* About to connect() to 192.168.0.100 port 8080 (#0)
* Trying 192.168.0.100...
* Connected to 192.168.0.100 (192.168.0.100) port 8080 (#0)
> GET / HTTP/1.1
> User-Agent: curl/7.29.0
> Host: 192.168.0.100:8080
> Accept: */*
>
< HTTP/1.1 200 OK
< Content-Length: 17
< Content-Type: text/plain; charset=utf-8
< Date: Sun, 25 Nov 2018 13:18:40 GMT
< Set-Cookie: _a49bc=http://10.0.0.5:8000; Path=/
<
I'm a6a8c9294fc3
* Connection #0 to host 192.168.0.100 left intact
Se, nas chamadas subsequentes, enviarmos esse cookie para o Traefik, sempre seremos encaminhados para o mesmo contêiner:
curl http://192.168.0.100:8080 --cookie "_a49bc=http://10.0.0.5:8000"
I'm a6a8c9294fc3
curl http://192.168.0.100:8080 --cookie "_a49bc=http://10.0.0.5:8000"
I'm a6a8c9294fc3
curl http://192.168.0.100:8080 --cookie "_a49bc=http://10.0.0.5:8000"
I'm a6a8c9294fc3
curl http://192.168.0.100:8080 --cookie "_a49bc=http://10.0.0.5:8000"
I'm a6a8c9294fc3
O cookie contém apenas o endereço IP interno (sobreposição) do contêiner ao qual o Traefik deve enviar para solicitar. Se você alterar o valor do cookie para http://10.0.0.4:8000
, a solicitação será efetivamente encaminhada para o outro contêiner. Se o cookie nunca for reenviado para o Traefik, a sessão permanente não funcionará e as solicitações serão equilibradas entre os contêineres do aplicativo e os contêineres do Traefik.
Isso é tudo o que é necessário para configurar as sessões adesivas da camada 7 no Docker CE no CentOS 7.
O Vultr oferece uma incrível conectividade de rede privada para servidores executando no mesmo local. Mas às vezes você quer dois servidores em países diferentes
Usando um sistema diferente? Introdução O CyberPanel é um dos primeiros painéis de controle do mercado, tanto de código aberto quanto de OpenLiteSpeed. What thi
Usando um sistema diferente? O ESpeak pode gerar arquivos de áudio de conversão de texto em fala (TTS). Isso pode ser útil por vários motivos, como criar seu próprio Turim
Usando um sistema diferente? O LibreNMS é um sistema de monitoramento de rede de código aberto completo. Ele usa o SNMP para obter os dados de diferentes dispositivos. Uma variedade
Usar um usuário sudo para acessar um servidor e executar comandos no nível raiz é uma prática muito comum entre o Linux e o Unix Systems Administrator. O uso de um sud
Usando um sistema diferente? O RabbitMQ é um intermediário de mensagens de código aberto amplamente usado, escrito na linguagem de programação Erlang. Como um middleware orientado a mensagens
Usando um sistema diferente? O RTMP é ótimo para veicular conteúdo ao vivo. Quando o RTMP é emparelhado com o FFmpeg, os fluxos podem ser convertidos em várias qualidades. Vultr i
Usando um sistema diferente? Gradle é um conjunto de ferramentas de automação de compilação de código aberto e gratuito baseado nos conceitos do Apache Ant e Apache Maven. Gradle fornece
Usando um sistema diferente? Neste guia, veremos como configurar um servidor FTP (ProFTPd) para transferir arquivos entre o seu PC e o seu servidor.
Usando um sistema diferente? O Netdata é uma estrela em ascensão no campo do monitoramento de métricas do sistema em tempo real. Comparado com outras ferramentas do mesmo tipo, o Netdata:
Usando um sistema diferente? O Apache Cassandra é um sistema de gerenciamento de banco de dados NoSQL gratuito e de código aberto, projetado para fornecer escalabilidade, alta
Neste tutorial, aprenda como configurar um servidor multiplayer Just Cause 2. Pré-requisitos Verifique se o sistema está totalmente atualizado antes de começarmos
Usando um sistema diferente? Neste tutorial, explicarei como configurar um servidor Starbound no CentOS 7. Pré-requisitos Você precisa ser o proprietário deste jogo
O ZNC é um segurança IRC gratuito e de código aberto que permanece permanentemente conectado a uma rede para que os clientes possam receber mensagens enviadas enquanto estiverem offline. Thi
O Django é uma estrutura Python popular para escrever aplicativos da web. Com o Django, você pode criar aplicativos mais rapidamente, sem reinventar a roda. Se você quiser você
Outubro é um sistema de gerenciamento de conteúdo de código aberto baseado no Laravel PHP Framework. Com uma interface elegante e uma arquitetura modular concisa
Após alterar a porta SSH, configurar a batida na porta e fazer outros ajustes para a segurança SSH, talvez haja mais uma maneira de protegê-lo
Introdução O MyCLI é um cliente de linha de comando para MySQL e MariaDB que permite concluir automaticamente e ajuda na sintaxe de seus comandos SQL. MyCL
Usando um sistema diferente? O Directus 6.4 CMS é um sistema de gerenciamento de conteúdo sem cabeça (CMS) poderoso e flexível, gratuito e de código aberto que fornece
Usando um sistema diferente? O Reader Self 3.5 é um leitor de RSS auto-hospedado, simples e flexível, gratuito e de código aberto, e uma alternativa ao Google Reader. Leitor Sel
Os ataques de ransomware estão aumentando, mas a IA pode ajudar a lidar com os vírus de computador mais recentes? AI é a resposta? Leia aqui para saber se é AI boone ou bane
ReactOS, um sistema operacional de código aberto e gratuito está aqui com a versão mais recente. Será que ela pode atender às necessidades dos usuários modernos do Windows e derrubar a Microsoft? Vamos descobrir mais sobre esse estilo antigo, mas uma experiência de sistema operacional mais recente.
O Whatsapp finalmente lançou o aplicativo Desktop para usuários de Mac e Windows. Agora você pode acessar o Whatsapp do Windows ou Mac facilmente. Disponível para Windows 8+ e Mac OS 10.9+
Leia isto para saber como a Inteligência Artificial está se tornando popular entre as empresas de pequena escala e como está aumentando as probabilidades de fazê-las crescer e dar vantagem a seus concorrentes.
Recentemente, a Apple lançou o macOS Catalina 10.15.4, uma atualização suplementar para corrigir problemas, mas parece que a atualização está causando mais problemas, levando ao bloqueio de máquinas mac. Leia este artigo para saber mais
13 Ferramentas de Extração de Dados Comerciais de Big Data
Nosso computador armazena todos os dados de uma maneira organizada conhecida como sistema de arquivos Journaling. É um método eficiente que permite ao computador pesquisar e exibir arquivos assim que você clicar em search.https: //wethegeek.com/? P = 94116 & preview = true
À medida que a ciência evolui em um ritmo rápido, assumindo muitos de nossos esforços, os riscos de nos sujeitarmos a uma singularidade inexplicável também aumentam. Leia, o que a singularidade pode significar para nós.
Uma visão sobre 26 técnicas analíticas de Big Data: Parte 1
A IA na área da saúde deu grandes saltos nas últimas décadas. Portanto, o futuro da IA na área da saúde ainda está crescendo dia a dia.