Dando continuidade à série de artigos sobre balanceadores, agora nosso #cloudspecialist Thiago Marques fala sobre profiles e persistências.

O pai ta on!!

Dando continuidade à série de artigos sobre balanceadores, onde ja vimos como instalar um balanceador, como criar os nodes e monitors, e como vincular ambos em um pool, onde temos a junção de um node com uma porta de serviço (conhecido como pool-member).

Hoje daremos mais um passo e falaremos sobre profiles (que é onde conseguimos mexer em alguns parâmetros de TCP/HTTP e etc.) e persistências (que é como o bigIP vai garantir que sua conexão cai no mesmo servidor).

Profiles

Dentro do ‘Local Traffic’, clique em ‘Profiles’:

Existem vários tipos de profiles, desde HTTP, passando por web acceleration, indo até a TCP e SSL. Por conta do bigIP ser um full proxy ele é capaz de alterar os parâmetros dos protocolos que passam por ele, para assim otimizar a conexão. Os profiles são um método de estes alterar parâmetros.

Podemos então por exemplo, alterar o timeout de uma sessão HTTP, alterar o janelamento do TCP, e inserir informações no header.

Neste exemplo criaremos um profile HTTP, pois utilizaremos persistência no modo de coockie, e ter um profile HTTP é mandatório para isso.

Dentro de profiles, vá em “services”, e depois clique em HTTP:

Detalhamento do profile HTTP

De um nome para o profile (inicie com prof_http_(serviço)):

X-forwarded-for

O XFF é um recurso do HTTP, onde mantemos o IP de origem no header do HTTP. Esta opção é extremamente último quando a aplicação precisa ter rastreabilidade da conexão (aplicações de banco por exemplo). Como isso não influencia em nada no balanceador, recomendo deixá-la habilitada.

Profile Persistência

A persistência de sessão é uma característica do bigIP que garante que com base em alguns parâmetros a conexão sempre caia no mesmo servidor. Este tipo de característica é importante para casos que a aplicação trata algumas informações localmente (um carrinho de compras por exemplo).

Sem ela, se o cliente abrir uma conexão, cairia no server01, colocar 3 itens no carrinho de compras, e atualizar a página por exemplo, cairia em outro servidor e o carrinho de compras estaria vazio.

Existem vários tipos de persistência, sendo as mais usadas o cookie, que a persistência baseada em uma informação de cookie que o bigIP insere no navegador. E a source_addr, que é a persistência baseada no IP de origem da conexão.

Aqui se formos fazer o paralelo com a AWS, o mais próximo que o ELB pode fazer é o Stickiness, que é basicamente uma implementação da persistência por coockie, contudo não vejo isso como uma limitação. Em uma aplicação descentralizada, podemos ter o gerenciador de sessões em um dynamoDB, ou em um Redis. Utilizar persistências na prática (sob meu ponto de vista) acaba sendo um limitador de escalabilidade, uma vez que uma vez persistido a conexão, deleta-la significa necessariamente finalizar a sessão do usuário.

Cada uma tem sua particularidade, mas como regra geral se a aplicação for HTTP use coockie se for outra, ou use o sourceIP ou nenhuma persistência.

Persistência por cookie

Dê um nome para a persistência, iniciando com: pers_(tipo-da-persistência)_(serviço).Exemplo: pers_ck_sagara

Cookie Name

Esta opção é onde colocamos o nome do cookie que iremos inserir no browser. Esta informação é pode ser visualizada inclusive no browser pelo aplicativo: BIGIP Cookie Decoder, disponível na loja de aplicativos do chrome.

Expiration

Este é o tempo que o bigIP espera para ‘matar’ a sessão ativa (desde que ela não tenha tráfego). Por padrão o bigIP respeita as sessões da aplicação, contudo é possível alterar estes dados (vide exemplo abaixo):

Tempos de sessão default

Por padrão o apache possui um timeout de 300 segundos (5min), e o IIS possui um timeout de 20min.

É importante saber os temos default de cada servidor, pois caso você não altere o expiration no balanceador ele vai assumir

este tempo de persistência, e isso é MUITO importante.

Já tive um problema em que o usuário solicitava um relatório que era gerado em um banco de dados, contudo este relatório demorava uns 40min para ser gerado. Assim quando o usuário pedia o relatório, dava 5min a página era ‘atualizada’. 

Isso acontecia justamente porque o tempo de timeout do apache tinha chegado ao limite. Resolvi o problema aumentando o tempo de timeout no bigIP.

Espero que tenham gostado!! No próximo artigo criaremos o virtual-server, e falaremos um pouco sobre estatísticas e tshoot.


 That’s all folks! Be Happy!!!

foto-thiago-marques
Thiago Marques Technical Account Manager
thiago.marques@darede.com.br

Technical Account Manager da Darede, formato em Rede de Computadores, e pós graduado em Segurança da Informação. Possui ampla experiência em Datacenters e Service Providers, além de ser um entusiasta em DevOps e mercado financeiro.

OUTRAS PUBLICAÇÕES

FRRouting com Docker

Em mais um artigo sobre container, nosso #cloudspecialist Thiago Marques agora traz um overview sobre FRRouting com Docker. Confere aí!

Microsserviços

Conforme o uso de cloud computing começa a se popularizar, obtemos arquiteturas cada vez mais complexas, gerando a necessidade de atualizações frequentes e ágeis, por isso o conceito de microsserviços se tornam uma boa opção para se construir um ambiente em cloud. E essa abordagem tem se consolidado como o preferido entre as empresas de tecnologia, uma vez que de acordo com pesquisa da Kong, 84% das organizações entendem que arquiteturas em microsserviços representam um novo paradigma ao desenvolver aplicações e as utilizam em seus ambientes em cloud. Mas, o que são microsserviços? Imagine um quebra-cabeças. E cada peça é construída por pequenas equipes e de forma independente. Mas que juntas elas formam um conjunto unificado. Os microsserviços funcionam praticamente dessa forma. Eles são uma abordagem de arquitetura em que são realizados pequenos serviços de forma autônoma, mas que se comunicam entre si através de APIs ou outras tecnologias. A arquitetura baseada em microsserviços, podem trazer escalabilidade para o ambiente, entregas contínuas, resiliência, além oferecer a capacidade de desenvolver aplicações com maior velocidade, e tirar proveito dos constantes avanços tecnológicos. Confira nossos especialistas falando sobre o conceito de microsserviços Microsserviços X Monolito A arquitetura monolítica é uma forma mais tradicional de desenvolver aplicações, pois ela trabalha em apenas um monolítico executável, ou seja, ao contrário da arquitetura em microsserviços, a equipe de TI trabalha em um processo único em que diversos módulos do sistema são executados em uma mesma máquina, assim compartilhando recursos de processamento, memória, bancos de dados e arquivos. Essa característica não anula a capacidade de se obter um ambiente totalmente escalável, porém neste caso toda a arquitetura será escalada. Mas as dependências de processos comprometem a disponibilidade de arquiteturas monolíticas, bem como um maior impacto no sistema em casos de falhas. Com uma arquitetura em microsserviços é construída em blocos independentes podendo ser executados de forma autônoma. Fazendo com que possam ser corrigidos em casos de falhas de forma isolada e escalados do mesmo jeito em picos de demanda, assim trazendo flexibilidade de redução de custos para o ambiente. A partir da comunicação via APIs ou desacoplamento, a arquitetura de microsserviços também pode ser reaproveitada em múltiplas aplicações. Como pode ser visto na imagem a seguir: Assim como apresentada na imagem acima enquanto a arquitetura monolítica trabalha com todos os serviços em um único processo, os microsserviços podem ser divididos em diversos serviços e pequenas equipes de forma que facilite o desenvolvimento de uma aplicação em cloud. Também é importante ressaltar que após anos de uso de arquiteturas com microsserviços, foram desenvolvidas uma série de boas práticas sobre como devemos implementá-las, por isso é imprescindível buscar um parceiro como a Darede que pode lhe guiar nesse universo. Acompanhe outros artigos sobre o mundo da TI no blog da Darede!

Cloud Computing: Tendências

Nos últimos anos, a cloud foi uma das áreas que mais cresceram, e a expectativa futura é ainda mais animadora. Confira o artigo sobre suas tendências.

Nós usamos cookies para garantir e oferecer a melhor experiência de navegação em nosso site! Mais informações