Handerson Frota – Analista Programador;Sócio Fundador da Triadworks;Atualmente Analista Programador da IVIA;Envolvido na programação desde os 13 anos iniciando com C, web desde 1997 e com Java desde 2001;Entusiasta Java e Ajax;Colunista da DevMedia, com artigos e vídeo aulas;Coordenador e Fundador da Célula Java na Faculdade Lourenço Filho;Já atuou em vários projetos de médio e grande porte exercendo as funções de: Programador, Analista, Arquiteto e Líder Técnico;
O que é COMET ?Comet ou ReverseAjax ?Você não conhece o DWR ?Quer saber mais sobre o DWR ?E agora como utilizar ?Mas, como vou configurar isso ?Preste atenção em alguns exemplos.Considerações finais.
1. Polling;2. Piggyback;3. Comet;
Polling – (Ativo)
Quando o navegador(cliente) faz pedidos ao servidor em intervalos regulares e freqüentes.
Gerando assim um tráfico extra e pesado na rede.
Servidor você tem alguma atualização pra
mim ?
SIM
NÃO
Piggyback – (Passivo)
O servidor tendo alguma atualização para o cliente aguarda até que o cliente faça uma nova solicitação, então ele “aproveita” para enviar juntamente com a respostas do cliente a sua atualização.
Não gera tráfego extra, em contra partida é muito demorado.
Servidor preciso do extrato da minha
conta.
Receba seu extrato e um débito no seu
cartão.
Opá, tenho uma nova
atualização pra você !
Opá, tenho uma nova
atualização pra você !
Comet – (Ativo)
O servidor fica responsável em atualizar a qualquer momento o cliente.
Uma única conexão é aberta e mantida pelo servidor.
Ele se utiliza basicamente de duas estratégias:
1.Streaming;
2.Long polling;
1. Streaming
O navegador abre uma única conexão persistentepara o servidor.
Quando o servidor envia algum evento a conexão não é fechada.
2. Long polling
O navegador faz um pedido para o servidor, que é mantido em aberto até que o servidor tenha novos dados a ser enviado.
Após enviar um evento, o servidor encerra a conexão e imediatamente o navegador abre uma nova.
Seja qual for a técnica, o servidor é capaz deenviar novas informações com baixa latência;
Streaming é considerado de melhor desempenho comparado ao Long Polling;
Vítima receba essa atualização.
Opa, a sua mulher acabou de efetuar uma compra com o
seu cartão !
Opa, a sua mulher acabou de efetuar uma compra com o
seu cartão !
O DWR é o Framework Ajax para JAVA mais robusto, simples e confiável que existe no mercado atualmente.
Ele possui integração com os principais frameworks do mercado: JSF, EJB2, EJB3, Struts 1x, Struts 2.x,Webwork, Hibernate, Hibernate 2, Hibernate 3, Springdentre outros.
Site Oficial: http://directwebremoting.org/dwr
Artigos, Vídeo Aulas: http://www.handersonfrota.com.br/artigos-tutoriais/dwr/
Por padrão o DWR começa com o Reverse Ajax(Comet) desligado, permitindo apenas a transferência via Piggyback.
O Reverse Ajax do DWR possui dois modos: Ativo e Passivo.
O Modo Ativo possui ainda mais 3 modos.
1.Full Streaming(Comet - Streaming)2.Early Closing (Comet - Long Polling)3.Polling
1. Basta acrescentar o trecho de código no seu web.xml. Com isso você ativa o Reverse Ajax.
2. Depois de ativado no web.xml, agora no segundo passo você vai definir qual a página que vai se utilizar do Reverse Ajax.
Basta acrescentar na sua página a seguinte linha de código:
Você poderá adicionar no onload da página ou no início de um arquivo JS, ou apenas como Script na página.
Este é o modo padrão quando o Reverse Ajax é ativado para as versões 2.0.3 e anteriores.
A partir da versão 2.0.4 o padrão é a Early Closing.
Ele tem como características respostas mais rápidas, porque ele fecha a conexão apenas uma vez a cada 60 segundos, ou verifica se o browser ainda está ativo.
Para ativar o modo Full Streaming na versão DWR 2.0.4 em diante, basta seguir as configurações:
No web.xml ative o uso de Reverse Ajax.
Ainda no web.xml adicione o seguinte trecho.
Depois basta acrescentar na sua página a seguinte linha de código:
No modo Early Closing ele irá manter a conexão aberta assim como na Full Streaming, no entanto ele ocupa apenas a conexão durante 60 segundos, se não houver uma saída para o navegador.
Esse modo nas versões DWR 2.0.4 e superiores, não se faz necessária nenhuma configuração adicional.
Para as versões 2.0.3 para baixo é preciso adicionar o seguinte trecho.
Neste caso o DWR irá manter a conexão aberta por mais de 500 milissegundos após a primeira saída, depois ele fecha e já solicita o a sua reabertura. Ele faz isso antes de forçar um flush.
Caso este modo esteja sendo utilizado em aplicações com um elevada taxa de transferência de dados(servidor-cliente) se faz necessário em alguns casos aumentar a o tempo de conexão aberta com o servidor.
Bastando alterar o valor no maxWaitAfterWrite = 1000 ou Mais, dependendo da sua necessidade.
Se por algum motivo você deseje utilizar essa técnica, também é bem simples configurar.
Além da configuração padrão: web.xml(activeReverseAjaxEnabled=true) é preciso adicionar dois init-params, veja a seguir:
Você deve definir o PollingServerLoadMonitor.
No modo Polling o default é de 5 segundos, mas é recomendado que você altere esse valor, pelo menos para 60 segundos. Isso para as versões DWR 2.0.3 em diante.
Como vimos o DWR tem um excelente suporte a Reverse Ajax(Comet) em geral. Bem simples de se utilizar, fácil de configurar e robusto.
O DWR 3.0 promete muito mais, com novas features, suporte a Rest, melhor integração com Spring, suporte ao Google Gears e Dojo Offline,Aptana Jaxer, OpenAjax, PubSub, Bayeux etc.
Top Related