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 HAProxy é um aplicativo de software de rede que oferece alta disponibilidade, balanceamento de carga e proxy para aplicativos de rede TCP e HTTP. É adequado para sites de alto tráfego e alimenta muitos sites populares na web. Este artigo mostra como instalar e configurar o HAProxy no Debian 9.1.
Embora o HAProxy tenha vários recursos importantes, este artigo se concentra em como configurar o HAProxy para "proxy" seu aplicativo Web.
O Debian 9 já vem com o HAProxy 1.7 (versão estável mais recente no momento da escrita), e podemos simplesmente instalá-lo usando apt-get
:
# apt-get update
# apt-get install haproxy
Se os comandos anteriores foram bem-sucedidos, você instalou o HAProxy e pode prosseguir para a próxima etapa.
O arquivo de configuração HAProxy é dividido em duas seções - "global" e "proxies". Um trata da configuração de todo o processo, enquanto o último consiste nas seções de configuração padrão, front-end e back-end.
Usando seu editor de texto favorito, abra /etc/haproxy/haproxy.cfg
e observe as seções predefinidas: "global" e "padrões". A primeira coisa que você pode fazer é aumentar maxconn
para um tamanho razoável, pois isso afeta as conexões permitidas pelo HAProxy. Muitas conexões podem causar falhas no serviço da Web devido a muitos pedidos. Você precisará ajustar o tamanho para ver o que funciona para você. Na seção global, escolhemos um maxconn
valor de 3072
.
global
daemon
maxconn 3072
Na seção padrão, adicione a seguinte linha no modo http
:
option forwardfor
Isso adicionará X-Forwarded-For
cabeçalhos a cada solicitação, o que permite que seus servidores back-end aprendam o endereço IP original do usuário.
Além disso, adicione esta linha para ativar o modo de fechamento de conexão HTTP no lado do servidor, mantendo a capacidade de oferecer suporte ao keep-alive HTTP no lado do cliente. Isso reduz a latência no lado do cliente e ajuda a conservar os recursos do servidor:
option http-server-close
Se você deseja usar o keep-alive nos lados do cliente e do servidor, pode usar option http-keep-alive
. Essa opção é particularmente útil quando o custo de estabelecer uma nova conexão com o servidor é significativo comparado ao custo de recuperação do recurso solicitado.
Finalmente, o arquivo de configuração resultante será mais ou menos assim:
defaults
mode http
option forwardfor
option http-server-close
timeout connect 5000ms
timeout client 50000ms
timeout server 50000ms
Para configurar seu proxy, você precisará adicionar duas seções ao arquivo de configuração para definir as duas partes do proxy: o front-end e o back-end.
O frontend manipulará suas conexões HTTP. Adicione o seguinte ao final do seu haproxy.cfg
arquivo:
frontend http-frontend
bind public_ip:80
reqadd X-Forwarded-Proto:\ http
default_backend wwwbackend
Substitua public_ip
pelo endereço IP público ou nome de domínio do seu servidor.
Configure seu back-end adicionando as seguintes linhas ao final do seu arquivo de configuração:
backend wwwbackend
server 1-www server1_ip:80 check
server 2-www server2_ip:80 check
server 3-www server3_ip:80 check
A configuração de back-end usada aqui cria três conexões nomeadas X-www
. ( X
é 1, 2 ou 3.) Cada um deles corresponde a um serverX_ip:80
endereço. (Substitua serverX_ip
pelos endereços IP das instâncias do Vultr.) Isso permitirá que você carregue o equilíbrio entre cada servidor no conjunto de servidores especificado (supondo que cada endereço IP corresponda a um servidor diferente). A check
opção faz com que o balanceador de carga execute verificações de integridade no servidor.
Salve o arquivo de configuração e reinicie o HAProxy:
service haproxy restart
Se tudo estiver funcionando, você poderá se conectar http://public_ip/
(substituindo-o pelo seu IP público ou nome de domínio, conforme configurado na etapa de front-end) e visualizar seu site.
Se sua instância do HAProxy se recusar a iniciar após as modificações, é provável que haja um erro em algum lugar do arquivo de configuração. Para receber mensagens claras sobre o problema no arquivo de configuração, tente iniciar o HAProxy manualmente usando este comando:
# haproxy -f /etc/haproxy/haproxy.cfg
Por exemplo, se você vir uma saída como esta:
[ALERT] 234/195612 (2561) : parsing [/etc/haproxy/haproxy.cfg:48] : server 1-www has neither service port nor check port nor tcp_check rule 'connect' with port information. Check has been disabled.
[ALERT] 234/195612 (2561) : Error(s) found in configuration file : /etc/haproxy/haproxy.cfg
[ALERT] 234/195612 (2561) : Fatal errors found in configuration.
Você esqueceu de especificar o número da porta do servidor 1-www
.
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? O Couch CMS é um sistema de gerenciamento de conteúdo (CMS) simples e flexível, gratuito e de código aberto que permite que os web designers
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
Este artigo ensinará como configurar uma prisão chroot no Debian. Presumo que você esteja usando o Debian 7.x. Se você estiver executando o Debian 6 ou 8, isso pode funcionar, mas
Introdução Uma maneira fácil de configurar um servidor VPN no Debian é com o PiVPN. PiVPN é um instalador e wrapper para o OpenVPN. Ele cria comandos simples para você t
Usando um sistema diferente? Introdução O Kanboard é um programa de software de gerenciamento de projetos gratuito e de código aberto, projetado para facilitar e visualizar
Usando um sistema diferente? Neos é uma plataforma de aplicativos de conteúdo com um CMS e uma estrutura de aplicativos em seu núcleo. Este guia mostra como instalar
Introdução O Cacti é uma ferramenta de monitoramento e gráfico de código aberto totalmente baseada em dados RRD. Através do Cacti, você pode monitorar quase qualquer tipo de dispositivo
Java é uma linguagem de programação independente de plataforma / máquina virtual. Neste tutorial, instalaremos a implementação OpenJDK do Java 8 em um Debian
O Git é um sistema de controle de versão (VCS) que permite o rastreamento de alterações no código. Neste tutorial, mostraremos a instalação de um servidor HTTP (S) Git, um
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
Introdução O MySQL possui um ótimo recurso conhecido como views. As visualizações são consultas armazenadas. Pense neles como um alias para uma consulta longa. Neste guia,
Usando um sistema diferente? O Matomo (anteriormente Piwik) é uma plataforma de análise de código aberto, uma alternativa aberta ao Google Analytics. Fonte Matomo está hospedado o
Munin é uma ferramenta de monitoramento para pesquisar processos e recursos em sua máquina e apresenta as informações em gráficos através de uma interface da web. Use o seguinte
Usando um sistema diferente? O NodeBB é um fórum baseado no Node.js. Ele utiliza soquetes da web para interações instantâneas e notificações em tempo real. Código fonte do NodeBB i
O Samba é uma solução de código aberto que permite aos usuários configurar compartilhamentos de arquivos e impressão rápidos e seguros. Neste artigo, abordarei como configurar a sagacidade do Samba
Introdução Neste tutorial, abordaremos o processo de adicionar um intervalo / sub-rede IP inteiro a um servidor Linux executando o CentOS, Debian ou Ubuntu. O processo
Usando um sistema diferente? O Plesk é um painel de controle proprietário de host da web que permite que os usuários administrem seus sites pessoais e / ou clientes, bancos de dados
Usando um sistema diferente? O Koel é um aplicativo simples de transmissão de áudio pessoal baseado na Web, escrito em Vue no lado do cliente e Laravel no lado do servidor. Koe
Usando um sistema diferente? O Ghost é uma plataforma de blog de código aberto que vem ganhando popularidade entre desenvolvedores e usuários comuns desde a sua 201
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.