Java 2 Enterprise Edition. JMS e. Message-driven Beans. Helder da Rocha
|
|
|
- Evelyn de Oliveira de Andrade
- 9 Há anos
- Visualizações:
Transcrição
1 Java 2 Enterprise Edition JMS e Message-driven Beans Helder da Rocha 1
2 O que é Messaging Método de comunicação entre componentes ou aplicações Arquitetura peer-to-peer com serviço centralizado para repasse de mensagens recebidas e enviadas Clientes e servidores enviam e recebem mensagens para canais administrados por serviço central de mensagens (MOM) C C C S MOM Viabiliza comunicação distribuída com acoplamento fraco Interface genérica: MOM ignora conteúdo e repassa qualquer coisa. Formato do conteúdo deve ser conhecido pelas partes Assíncrona: Comunicação pode ocorrer mesmo que o cliente e servidor não estejam disponíveis ao mesmo tempo S C 2
3 Message-oriented Middleware (MOM) Sistemas de messaging são freqüentemente chamados de Message-Oriented Middleware (MOM) Conceito não é novo: já existiam há algum tempo em implementações proprietárias (e incompatíveis) JMS API: solução independente de fabricante para acessar serviços MOM a partir de clientes Java Alguns produtos MOM compatíveis com JMS: Open source: JBossMQ, OpenJMS, JORAM IBM MQSeries, IPlanet MQ, Bea WebLogic, HP-MS, Progress SoniqMQ Mais em: java.sun.com/products/jms/ 3
4 Messaging vs. RMI/RPC vs. Messaging Mensagens são representadas como eventos Interface genérica (reutilizada em aplicações diferentes) Arquitetura centralizada (tudo passa pelo MOM) Serviços de diretórios localizam canais de comunicação (destinos) RMI/RPC (Corba, Java RMI, etc.) Mensagens são representadas como chamadas para métodos remotos Cada aplicação se comunica através de uma interface definida Pode ser descentralizado (rede de ORBs ligados por IIOP) Serviços de diretórios localizam objetos 4
5 Messaging vs. RMI/RPC Sistema de Messaging com paradigma pub/sub Sistema RMI/RPC (Java RMI ou CORBA) Remetente Destinatário Cliente Cliente mom.publica(); onmessage(msg) {...} srv.metodo(); srv.metodo(); ORB stub ORB stub msg inscreve-se msg Inter-ORB Protocol MOM Message Broker notifica skeleton ORB Objeto Remoto metodo() { //... } Protocolo comum: mensagem Protocolo comum: interface dos objetos 5
6 Quando usar um MOM em vez de RMI/RPC?... ou, quando decidir por acoplamento mais fraco? Quando a comunicação se baseia mais no formato de mensagens que em interfaces rígidas (componentes não dependem da interface de outros componentes) Quando a disponibilidade dos componentes é imprevisível, mas sua aplicação precisa rodar mesmo que componentes não estejam todos acessíveis Quando for preciso suportar comunicação assíncrona: componente pode enviar informações para outro e continuar a operar mesmo sem receber resposta imediata Cenário comum em muitas aplicações B2B! 6
7 Java Message Service Interface Java única para unir as MOMs incompatíveis API que permite que aplicações criem, enviem, recebam e leiam mensagens através de um MOM API consiste principalmente de interfaces (implementadas pelo fabricante do MOM) Parte integral da plataforma J2EE (acrescenta possibilidade de comunicação assíncrona a EJBs) 7
8 Arquitetura JMS Cliente JMS Cliente JMS Clientes: produzem e consomem mensagens Mensagem Mensagens: objetos que passam informações entre clientes JMS Mensagem JNDI lookup() Toda a comunicação com o provedor JMS é realizada através de JNDI e da API JMS Destinos tipo Fila JMS API Destinos tipo Canal Fábricas de Conexões Destinos tipo Canal Espaço de nomes JNDI Destinos tipo Fila Provedor JMS oferece: - Sistema de mensagens - Serviços administrativos - Sistemas de controle JNDI bind() Ferramentas de administração do provedor Fábricas de Conexões Objetos gerenciados acessíveis via JNDI 8
9 Domínio ptp (ponto-a-ponto) Baseado no conceito de filas, remetentes e destinatários Ou ou muitos para um: cada mensagem é enviada para uma fila específica e é consumida por um destinatário (que pode ou não estar disponível no momento) Destinatário confirma que a mensagem foi recebida e processada corretamente (acknowledgement) Filas retém mensagens até que sejam consumidas (ou expirem) QueueSender s; s.send(m1);... s.send(m5); Remetente s Envia m5 Message m5 Provedor JMS m4 FIFO m1 QueueReceiver r; Message m = r.receive(); Consome Confirma Recebimento Fila (queue) Destinatário r 9
10 Domínio pub/sub (publica/inscreve) Baseado em canais (tópicos) Muitos para muitos: mensagens são enviadas a um canal onde todos os assinantes do canal podem retirá-la Canal TopicPublisher p; p.publish(m1);... p.publish(m5); Publicador p m5 Publica Fila m2 m3 m4 TopicSubscriber s1; MessageListener k = new MessageListener() { public void onmessage(message m){...} }; s1.setmessagelistener(k); Inscreve-se em Tópico m1 Inscreve-se em Tópico m1 Fornece s1.onmessage(m1); Fornece Assinante s1 s2.setmessagelistener(k); Assinante s2 Provedor JMS s2.onmessage(m1); 10
11 Consumo síncrono e assíncrono Mensagens podem ser retiradas do destino através de uma chamada receive() Esta é a forma síncrona de retirar mensagens Cliente bloqueia enquanto mensagem não chega Mensagens também podem ser enviadas ao destinatário quando chegarem Esta é a forma assíncrona de retirar mensagens Para ser notificado, destinatário precisa ser implementado como um ouvinte e cadastrado para receber notificações Nos exemplos anteriores, o modelo P2P foi implementado com destinatário síncrono e o modelo publish-subscribe com destinatário assíncrono 11
12 Canais duráveis e não-duráveis Cada mensagem enviada a um canal pode ter múltiplos consumidores Mensagem permanece disponível até que todos os assinantes a tenham retirado Em canais não-duráveis assinante perde as mensagens enviadas nos seus períodos de inatividade Produtor Canal Assinante Mensagens recebidas tempo t.publish(a) t.publish(b) t.publish(c) A B C Ativo Inativo Ativo Se canal for não-durável A C Se canal for durável A B C t.publish(d) D Ativo D D 12
13 Desenvolvimento de aplicações JMS Para escrever aplicações que enviam ou recebem mensagens é preciso realizar uma série de etapas Obter um destino e uma fábrica de Connection conexões via JNDI Factory Usar a fábrica para obter uma conexão createconnection() Usar a conexão para obter uma ou mais sessões Connection Usar a sessão para criar uma mensagem Iniciar a sessão Depois, pode-se Enviar mensagens Receber mensagens Cadastrar ouvintes para receber mensagens automaticamente Fonte da ilustração: JMS Tutorial send() Message Producer Destination Session Message ctx.lookup(nome) createsession() create() create() receive() createmessage() ctx.lookup(nome) Message Consumer Destination 13
14 Interfaces: dois domínios É preciso escolher um domínio Para cada domínio há um destino, fábrica de conexões, conexão, sessão, produtor e consumidor Interfaces são semelhantes Destination ConnectionFactory Objetos gerenciados MessageProducer Topic Queue TopicConnectionFactory QueueConnectionFactory TopicPublisher QueueSender Connection Session MessageConsumer TopicConnection QueueConnection TopicSession QueueSession TopicSubscriber QueueReceiver Domínio pub/sub Domínio ptp 14
15 Objetos gerenciados Destinos (filas e tópicos) e fábricas de conexões não podem ser criados através da API São criados pelo provedor JMS e ligados a JNDI através de suas ferramentas administrativas. No J2EE-RI: > j2eeadmin -addjmsdestination queue/minhafila queue Para usar um objeto gerenciado O cliente precisa obtê-lo através de uma consulta (lookup) no serviço de nomes JNDI Não há padronização do nome usado em JNDI (nomes default variam entre fabricantes) Exemplo (obtenção de um destino do tipo Topic): String nomejri = "jms/topic"; //Default J2EE RI String nomejboss = "topic/testtopic"; // Default JBossMQ Context ctx = new InitialContext(); Topic canal = (Topic) ctx.lookup(nomejboss); 15
16 Há dois tipos de destinos JMS Filas (Queue) Retêm todas as mensagens que recebem até que sejam retiradas ou expirem Para cada mensagem enviada, apenas um cliente pode retirá-la Queue fila = (Queue) ctx.lookup("jms/queue"); Canais (Topic) Cada canal pode ter vários clientes assinantes Cada assinante recebe uma cópia das mensagens enviadas Para receber uma mensagem publicada em um canal, clientes precisam já ser assinantes dele antes do envio. Em canais "duráveis", assinantes não precisam estar ativos no momento do envio. Retornando, receberão mensagens nao lidas. Topic canal = (Topic) ctx.lookup("jms/topic"); 16
17 Fábricas de conexões Antes que se possa enviar uma mensagem para uma fila, publicar uma mensagem em um canal, consumir uma mensagem de uma fila ou fazer uma assinatura de um canal é preciso obter uma conexão ao provedor JMS Isto é feito através de uma fábrica de conexões. Há duas: TopicConnectionFactory - para conexões no domínio Topic QueueConnectionFactory - para conexões no domínio Queue É preciso conhecer o nome JNDI String nomejri = "TopicConnectionFactory"; //default J2EE-RI String nomejboss = "ConnectionFactory"; // default JBossMQ Precisa ser definido (geralmente Context ctx = new InitialContext(); arquivo jndi.properties no CPATH) TopicConnectionFactory factory = (TopicConnectionFactory) ctx.lookup(nomejboss); 17
18 Conexões Encapsulam uma conexão virtual com o provedor JMS Suportam múltiplas sessões (threads) Uma vez obtida uma fábrica de conexões, pode-se obter uma conexão QueueConnection queuecon = queueconnectionfactory.createqueueconnection(); TopicConnection topiccon = topicconnectionfactory.createtopicconnection(); Quando a conexão terminar, é preciso fechá-la O fechamento fecha todas as seções, produtores e consumidores associados à conexão queuecon.close(); topiccon.close(); 18
19 Sessões Contexto onde se produz e se consome mensagens Criam produtores, consumidores e mensagens Processam a execução de ouvintes Single-threaded Podem ser configuradas para definir forma de acknowledgement uso ou não de transações (tratar uma série de envios/recebimentos como unidade atômica e controlá-la via commit e rollback) Exemplos TopicSession topicsession = topiccon.createtopicsession(false, Sessão controlada por transações Sem transações QueueSession queuesession = queuecon.createqueuesession(true, 0); Confirmação automática após recebimento correto Session.AUTO_ACKNOWLEDGE); Tratamento de confirmações não especificado 19
20 Produtores de mensagens Objeto criado pela sessão e usado para enviar mensagens para um destino QueueSender: domínio ponto-a-ponto TopicPublisher: domínio pub/sub QueueSender sender = queuesession.createsender(fila); TopicPublisher publisher = topicsession.createpublisher(canal); Uma vez criado o produtor, ele pode ser usado para enviar mensagens send() no domínio ponto-a-ponto sender.send( message ); publish() no domínio pub/sub publisher.publish( message ); Durante o envio cliente pode definir qualidade do serviço como modo (persistente ou não), prioridade (sobrepõe comportamento FIFO) e tempo de vida (TTL) 20
21 Consumidores de mensagens Objeto criado pela sessão e usado para receber mensagens QueueReceiver e QueueBrowser: domínio ponto-a-ponto TopicSubscriber: domínio pub/sub QueueReceiver receiver = queuesession.createreceiver(fila); TopicSubscriber subscriber = topicsession.createsubscriber(canal); É preciso iniciar a conexão antes de começar a consumir: topiccon.start(); Depois, pode consumir mensagens de forma síncrona (método é o mesmo para domínios PTP e pub/sub Message queuemsg = receiver.receive(); Message topicmsg = subscriber.receive(1000); Para consumir mensagens de forma assíncrona é preciso criar um MessageListener 21
22 MessageListener Event handler que detecta o recebimento de mensagens Para usar, implemente MessageListener e seu método onmessage(): public class MyListener implements MessageListener { public void onmessage(message msg) { TextMessage txtmsg = (TextMessage) msg; System.out.println( "Mensagem recebida: " + txtmsg.gettext() ) } } Método onmessage() não deve deixar escapar exceções Código acima deve estar em um bloco try-catch Para que objeto seja notificado, é preciso registrá-lo em um QueueReceiver ou TopicSubscriber subscriber.setmessagelistener( new MyListener() ); topiccon.start(); // iniciar a conexão 22
23 Envio e recebimento de mensagens Cliente 1. Obtém referência para Connection Factory JNDI 4. Obtém Destino JMS 2. Cria conexão 3. Cria sessão 5. Cria produtor ou consumidor 6. Envia ou recebe mensagem Queue_1 Queue_2 Connection Factory Connection Session Producer ou Consumer JMS API Serviço de Nomes (LDAP, DNS,...) Topic_1 Fonte da ilustração: Mastering EJB 2 Cap 8 (veja referências no final) Servidor JMS 23
24 Mensagens Mensagens são compostas de três partes Propriedades (opcionais): pares nome/valor (nomes e valores arbitrários definidos pela aplicação); contém tipos primitivos Java (int, boolean, etc.) ou String. Cabeçalhos: propriedades com nomes e tipos de valores padrão definidos na especificação JMS Corpo: conteúdo que não pode ser representado através de propriedades Os tipos de mensagem correspondem a formatos de dados armazenados no corpo de mensagem Texto, objetos serializados, bytes, valores primitivos, etc. Mensagens são criadas a partir de uma Session 24
25 Cabeçalhos e propriedades Cabeçalhos: conjunto de propriedades (chave: valor) definidas na especificação JMS e usadas pelo sistema para identificar e rotear mensagens Chaves começam com "JMS". Ex: JMSMessageID, JMSDestination, JMSExpiration, JMSPriority, JMSType A maioria são criadas automaticamente durante a chamada do método de envio (dependem dos parâmetros do método) Propriedades definidas pelo programador Pode guardar informações de conteúdo textual em mensagens simples sem corpo (onde a mensagem consiste das propriedades) Usadas para qualificar a mensagem e permitir sua filtragem Úteis para preservar a compatibilidade com outros sistemas de messaging message.setstringproperty("formato", "Imagem JPEG"); 25
26 Filtros (seletores) de mensagens Consumidor pode especificar quais as mensagens que lhe interessam através de expressões SQL Expressão deve retornar valor booleano Consiste de String passado como argumento de métodos createreceiver() e createsubscriber() Expressão é tipicamente usada para comparar valores de propriedades de mensagens Consumidor só consome as mensagens em que propriedades, aplicadas à expressão resultem verdadeiro Exemplos String seletor = "Formato LIKE '%Imagem%' AND " + "JMSExpiration > 0 AND " + "Valor IS NOT NULL"; topicsession.createsubscriber (canal, seletor) 26
27 Seis tipos de mensagens Message Mensagem genérica sem corpo (contendo apenas cabeçalho e possíveis propriedades) TextMessage Objeto do tipo String (ex: conteúdo XML) MapMessage Conjunto de pares nome/valor onde nomes são Strings e valores são tipos primitivos BytesMessage Stream de bytes não interpretados StreamMessage Seqüência de tipos primitivos Java ObjectMessage Objeto Java serializado Message TextMessage MapMessage BytesMessage StreamMessage ObjectMessage 27
28 Criação de mensagens Para cada tipo de mensagem, Session fornece método create() createmessage(), createtextmessage(), createbytesmessage(), createobjectmessage(), createmapmessage(), createstreammessage() Após receber uma mensagem, via receive() ou onmessage(), é preciso fazer o cast para ter acesso aos métodos específicos de cada tipo de mensagem Message m = receiver.receive(); if (m instanceof TextMessage) { TextMessage message = (TextMessage) m; System.out.println("Recebido: " + message.gettext()); } TextMessage message = queuesession.createtextmessage(); message.settext(msg_text); // msg_text é String sender.send(message); 28
29 Exceções A maior parte das operações JMS potencialmente causam javax.jms.jmsexception Há várias sub-classes de JMSException para tratar situãções específicas Veja documentação da API ou JMS Tutorial (3.7) para mais detalhes 29
30 Exemplos de aplicações Os exemplos são do capítulo 4 do JMS Tutorial (Sun) As versões em cap07/exemplos/ foram alteradas Todas estão nos pacotes jmstut.topic ou jmstut.queue Há alvos prontos no Ant. Rode-os em duas ou três janelas e mude a ordem (rode o produtor antes e depois inverta) Aplicação ponto-a-ponto (rode em janelas diferentes) > ant runqueuesender > ant runqueuereceiver Aplicação pub/sub > ant runtopicpublisher > ant runtopicsubscriber 30
31 O que é um Message-Driven Bean (MDB)? Consumidor assíncrono Bean ativado por mensagens (eventos) MDBs consomem mensagens enviadas a filas e canais JMS Não é possível enviar uma mensagem diretamente a um messagedriven bean (envia-se mensagens a um canal que o bean escuta) Acoplamento entre clientes e MDB resume-se à conhecimento de canal comum de comunicações Um message-driven bean é um EJB mas Não possui interfaces Home ou Remote Possui apenas um método que recebe qualquer tipo de mensagem Não devolve tipos ou exceções ao cliente Não participa de contexto transacional iniciado no cliente Não possui estado (é stateless) Pode ser ouvinte de uma fila ou assinante durável ou não-durável de um canal (Topic) JMS 31
32 Desenvolvendo MDB Message-driven beans implementam duas interfaces public interface javax.jms.messagelistener public interface javax.ejb.messagedrivenbean extends javax.ejb.enterprisebean Métodos de MessageDrivenBean e da especificação ejbremove(): método da interface. Chamado pelo container quando o message-driven bean está sendo removido do pool ejbcreate(): método definido na especificação (não está na interface). É chamado quando um novo bean é criado pelo container setmessagedrivencontext(messagedrivencontext ctx): método da interface. Chamado antes do ejbcreate() quando o bean está sendo adicionado ao pool Método de MessageListener onmessage(message m): chamado cada vez que uma mensagem é enviada para o canal do bean (se o bean estiver ativado). 32
33 Exemplo: implementação de um MDB import javax.ejb.*; import javax.jms.*; public class LogBean implements MessageDrivenBean, MessageListener { protected MessageDrivenContext ctx; public void setmessagedrivencontext(messagedrivencontext ctx) { this.ctx = ctx; } public void ejbcreate() {} public void ejbremove() {} Métodos da interface MessageDrivenBean ou do contrato com a especificação } public void onmessage(message msg) { TextMessage tm = (TextMessage) msg; try { String text = tm.gettext(); } System.err.println("Received new message : " + text); } catch (JMSException e) { throw new EJBException(); } RuntimeException para container capturar! Só faça isto se houver chance de corrigir erro: falta de acknowledgement pode causar loop infinito! Método da interface MessageListener Este bean simplesmente imprime o texto contido na mensagem recebida 33
34 Ciclo de Vida Ciclo de vida muito simples Apenas dois estados Bean não existe 1. Objeto criado 2. setsessioncontext() 3. ejbcreate() ejbremove() Apenas o container chama os métodos de um Message-driven Bean onmessage() Pool de beans Fonte: [1] 34
35 Deployment Descriptor <ejb-jar> <enterprise-beans> <message-driven> <ejb-name>logejb</ejb-name> <ejb-class>examples.logbean</ejb-class> <transaction-type>container</transaction-type> <message-driven-destination> <destination-type>javax.jms.topic</destination-type> <subscription-durability>nondurable</subscription-durability> </message-driven-destination> <resource-ref> <res-ref-name>jms/topicfactory</res-ref-name> <res-type>javax.jms.topicconnectionfactory</res-type> <res-auth>container</res-auth> </resource-ref> </message-driven> </enterprise-beans> </ejb-jar> Canal (apenas a classe e tipo) Usado apenas em Topics Fábrica de filas e canais 35
36 Outros sub-tags de <message-driven> <message-selector> Usado para incluir um filtro SQL para cabeçalhos de mensagens. Apenas mensagens que combinarem com o filtro serão recebidas pelo bean. Exemplo: <message-selector><![cdata[ Formato LIKE '%Imagem%' AND JMSExpiration > 0 AND Valor IS NOT NULL ]]></message-selector> <acknowledge-mode> Permite definir o modo de acknowledgment. Pode ser Auto-acknowledge ou Dups-ok-acknowledge. O último permite o recebimento de mensagens duplicadas Client-acknowledge não é suportado 36
37 Vendor-specific: JBoss Os nomes JNDI dos recursos que serão acessados globalmente são definidos na configuração do fabricante. No JBoss: <jboss> <enterprise-beans> <message-driven> <ejb-name>logejb</ejb-name> <destination-jndi-name> topic/testtopic </destination-jndi-name> </message-driven> </enterprise-beans> <resource-managers> <resource-manager> <res-name>jms/logtopic</res-name> <res-jndi-name>topic/testtopic</res-jndi-name> </resource-manager> </resource-managers> </jboss> Nome JNDI global do destino compartilhado pelo bean e pelos clientes Referência do ENC java:comp/env Mapeamento do nome do ENC para nome JNDI global 37
38 Cliente é um cliente JMS comum Pode ser outro bean, cliente Web ou standalone public class Client { public static void main(string[] args) throws Exception { Context ctx = new InitialContext(System.getProperties()); TopicConnectionFactory factory = (TopicConnectionFactory) ctx.lookup("connectionfactory"); TopicConnection connection = factory.createtopicconnection(); TopicSession session = connection.createtopicsession( false, Session.AUTO_ACKNOWLEDGE); Cliente externo (fora do ENC) usa nomes JNDI globais } } Topic topic = (Topic) ctx.lookup("topic/testtopic"); TopicPublisher publisher = session.createpublisher(topic); TextMessage msg = session.createtextmessage(); msg.settext("this is a test message."); publisher.publish(msg); 38
39 Execução dos exemplos Diretório cap7/exemplos/mejb2/ Para montar e instalar a aplicação, use > ant jboss.deploy Uma vez instalada, rode o cliente: > ant run.jboss.client A execução não deve causar nenhuma reação no cliente, já que foi assíncrona "one-way". No servidor, aparece a mensagem enviada: [STDERR] Received new message : This is a test message. Veja também o exemplo do J2EE Tutorial (usando Queue) no subdiretório cap7/exemplos/sun2/ 39
40 Exercícios 1. Utilizando os exemplos como base, escreva um produtor JMS que envie mensagens para uma fila. As mensagens tem o seguinte formato Codigo: 100 Quantidade: 5 (cabeçalho: cod. produto) (cabeçalho: quantidade) Descrição do produto (corpo da mensagem texto) Use a fila do JBoss queue/a Varie quantidades entre 1 e Escreva um consumidor JMS para ler e consumir as mensagens enviadas sincronamente Filtre as mensagens com menos de 10 produtos 40
41 Exercício 3. Implemente um bean que receba as mensagens enviadas pelo cliente que você desenvolveu nos exercícios 1 e 2 (transforme o consumidor de mensagens em um bean) O nome JNDI da fila é queue/a O bean deve filtrar as mensagens e receber apenas aquelas cujo cabeçalho Quantidade contiver mais que 10 itens e menos que
42 Fontes [1] Kim Haase. The JMS Tutorial. Sun Microsystems, Este capítulo é baseado no JMS Tutorial. [2] Sun Microsystems. The Java Message Service Specification [3] Peter Antman. JBoss and JMS. JBoss User's Manual, Chapter 8. Contém breve tutorial sobre JMS [4] Todd SundSted. Messaging helps move Java into the Enterprise. JavaWorld, Jan Introdução aos conceitos fundamentais de sistemas de mensagens. [5] Todd SundSted. Messaging makes its move, Parts I & II. JavaWorld, Fev e Mar Série de dois artigos mostrando como usar JMS. [6] Gordon Van Huizen. JMS: An infrastructure for XML-based B2B communication JavaWorld, Introdução a JMS motivada pelo seu potencial para soluções B2B com XML [7] Michael Schoffner. Write your own MOM. JavaWorld, [8] Ed Roman et al. Mastering EJB 2, Chapter 8: Message Drive Beans Contém um breve e objetivo tutorial sobre JMS no início do capítulo 42
43 argonavis.com.br J500 - Aplicações Distribuídas com J2EE e JBoss Revisão 1.5 (junho de 2003) Minicurso de JMS,
J533 - Minicurso. Helder da Rocha ([email protected]) www.argonavis.com.br
J533 - Minicurso Helder da Rocha ([email protected]) www.argonavis.com.br 1 Sumário Introdução Messaging e Message-Oriented Middlewares (MOMs) Quando usar MOMs? Vantagens e desvantagens O que é o Java Message
Java Message Service (JMS)
J530 - Enterprise JavaBeans Java Message Service (JMS) Helder da Rocha ([email protected]) argonavis.com.br 1 Introdução O objetivo deste capítulo é apresentar uma introdução ao modelo de comunicações baseado
Java Message Service (JMS)
Java Message Service (JMS) Disciplina de Sistemas Distribuídos Prof. Cristiano André da Costa Luiz Henrique Feltes Roteiro Introdução; Arquitetura; Vantagens / Desvantagens; Componentes do JMS; Códigos
Este tutorial contém material (texto, código, imagens) produzido por Helder da Rocha em outubro de 2013 e poderá ser usado de acordo com os termos da licença Creative Commons BY-SA (Attribution- ShareAlike)
Message Driven Beans. Apresentação. Introdução Implementação de MDBs Deployment no JBoss Java Messaging Service Exemplo
Message Driven Beans Apresentação Introdução Implementação de MDBs Deployment no JBoss Java Messaging Service Exemplo 1 Introdução Message Driven Beans são EJBs que consomem mensagens enviadas para filas
UFG - Instituto de Informática
UFG - Instituto de Informática Especialização em Desenvolvimento de Aplicações Web com Interfaces Ricas EJB 3.0 Prof.: Fabrízzio A A M N Soares [email protected] Aula 12 Beans Orientados a
JMS. Java Message Service
JMS Autoria Autoria Fábio Cecin (1a versão) Versão V3.2, junho de 2013 C. Geyer Referências Referências: The JMS Tutorial após versão 1.4 do JEE em capítulo do tutorial JEE da Sun v.1.5 (JEE): até v. 1.3:
A interface de uma mensagem é extremamente flexível e permite várias formas de customização de conteúdo. Figura 1 - Tipos de Mensagens JMS
Programando com Java Artigo http://mballem.wordpress.com/ Chat JMS com ActiveMQ Java Message Service Autor Marcio Ballem: é formado em Sistemas de Informação e possui certificação Oracle Certified Professional,
Sumário. Message Oriented Middleware (MOM) Sincronização na Comunicação. Comunicação Assíncrona
Sumário Message Oriented Middleware (MOM) October 16, 2008 Comunicação Assíncrona (MOM) Conceito Java Message Service Implementação Comunicação Assíncrona Problema: Nem sempre as entidades comunicantes
Agenda - JMS. Introdução. Vagner Sacramento. Laboratory for Advanced Collaboration - LAC Departamento de Informática - PUC-Rio
Java Message Service JMS e Wireless CORBA Specification - WCORBA Vagner Sacramento [email protected] Laboratory for Advanced Collaboration - LAC Departamento de Informática - PUC-Rio Agenda - JMS
Message Oriented Middleware (MOM)
Message Oriented Middleware (MOM) November 1, 2009 Sumário Comunicação Assíncrona (MOM) Conceito Java Message Service Implementação Comunicação Assíncrona Problema: Nem sempre as entidades comunicantes
Objetos e Componentes Distribuídos: EJB e CORBA
: EJB e CORBA Sistemas Distribuídos Mauro Lopes Carvalho Silva Professor EBTT DAI Departamento de Informática Campus Monte Castelo Instituto Federal de Educação Ciência e Tecnologia do Maranhão Objetivos
Integração de Sistemas com Webservices, JMS e EJB
TREINAMENTOS Integração de Sistemas com Webservices, JMS e EJB Integração de Sistemas com Webservices, JMS e EJB 31 de agosto de 2013 Sumário i Sobre a K19 1 Seguro Treinamento 2 Termo de Uso 3 Cursos
Enterprise Java Beans
Enterprise Java Beans Prof. Pasteur Ottoni de Miranda Junior DCC PUC Minas Disponível em www.pasteurjr.blogspot.com 1-O que é um Enterprise Java Bean? O Entertprise Java Bean (EJB) é um componente server-side
Aplicações Web com Servlets e JSP
J550 Desenvolvimento de Aplicações Web com Servlets e JSP Helder da Rocha www.argonavis.com.br 1 Objetivos Este curso explora os recursos da linguagem Java para o desenvolvimento de aplicações Web Tem
Java 2 Enterprise Edition Fundamentos básicos de Transações
Java 2 Enterprise Edition Fundamentos básicos de Transações Helder da Rocha www.argonavis.com.br 1 Objetivos Apresentar conceitos essenciais sobre transações em aplicações J2EE Este curso não aborda o
Filas de Mensagens. Canal com fila de mensagens
Filas de Mensagens Message Oriented Middleware - MOM Canal com fila de mensagens Emissor Rede Receptor Emissor Emissor fila Modelo do RPC ou de ligação de transporte fila Receptor Receptor Emissor fila
Objetos e Componentes Distribuídos: EJB
: EJB Sistemas Distribuídos Mauro Lopes Carvalho Silva Professor EBTT DAI Departamento de Informática Campus Monte Castelo Instituto Federal de Educação Ciência e Tecnologia do Maranhão Objetivos Nesta
Java RMI. RMI Remote Method Invocation. Chamadas Remotas de Procedimentos (RPC) RPC - Implementação
Java Remote Method Invocation Java Remote Method Invocation () é um protocolo Java para comunicação entre processos Permite objetos Java invocar transparentemente métodos de outros objetos (que podem estar
15/4/15. Processamento Paralelo Middleware Orientado a Objetos. Sistema operacional é a única infraestrutura para interação. Middleware é adicionado
Aplicações distribuídas: interação entre partes Processamento Paralelo Middleware Orientado a Objetos Prof. João Paulo A. Almeida ([email protected]) Rede A Rede B Rede C 2015/01 - INF02799 Sistema
Sistemas Distribuídos
Sistemas Distribuídos LICENCIATURA EM COMPUTAÇÃO Prof. Adriano Avelar Site: www.adrianoavelar.com Email: [email protected] 1. Que são sistemas abertos? É um sistema que oferece serviços de acordo com
Enterprise Java Bean. Enterprise JavaBeans
Enterprise Java Bean Introdução Elementos do Modelo Enterprise JavaBeans A especificação do Enterprise JavaBeansTM (EJB) define uma arquitetura para o desenvolvimento de componentes de software distribuídos
ESTUDO DAS TECNOLOGIAS UTILIZANDO TROCA DE MENSAGEM E ARMAZENAMENTO EM FILA JMS COM CONSUMIDOR MDB MESSAGE-DRIVEN-BEAN
UNIVERSIDADE TECNOLÓGICA FEDERAL DO PARANÁ DEPARTAMENTO ACADÊMICO DE INFORMÁTICA CURSO DE ESPECIALIZAÇÃO EM TECNOLOGIA JAVA EDSON VIEIRA ESTUDO DAS TECNOLOGIAS UTILIZANDO TROCA DE MENSAGEM E ARMAZENAMENTO
J2EE. J2EE - Surgimento
J2EE Java 2 Enterprise Edition Objetivo: Definir uma plataforma padrão para aplicações distribuídas Simplificar o desenvolvimento de um modelo de aplicações baseadas em componentes J2EE - Surgimento Início:
Vamos fazer um pequeno experimento
1 Vamos fazer um pequeno experimento Dividam-se em dois grupos: Mestre Escravo Projeto de Sistemas Distribuídos Comunicação entre Processos Prof. Msc. Marcelo Iury de Sousa Oliveira [email protected]
IBM WebSphere MQ. Introdução
Introdução Arquitectura Application Messaging Interface WebSphere Aplication Server WebSphere Business Integration Server Vantagens e desvantagens Introdução Plataforma de integração e infraestrutura de
Web Technologies. Tópicos da apresentação
Web Technologies Tecnologias de Middleware 2004/2005 Hugo Simões [email protected] 1 A Web Tópicos da apresentação Tecnologias Web para suporte a clientes remotos (Applets,CGI,Servlets) Servidores Aplicacionais
Modelo de Componentes CORBA
Modelo de Componentes CORBA Cláudia Brito L. N. da Silva [email protected] Roteiro 1. Visão geral 2.! Definindo componentes! Implementando componentes! Empacotando componentes! Instalando componentes!
Tipos, Literais, Operadores
Tipos, Literais, Operadores Identificadores São palavras utilizadas para nomear variáveis, métodos e classes Na linguagem Java, o identificador sempre começa por letra, sublinhado(_) ou cifrão ($) Não
Tipos, Literais, Operadores
Tipos, Literais, Operadores Identificadores São palavras utilizadas para nomear variáveis, métodos e classes Na linguagem Java, o identificador sempre começa por letra, sublinhado(_) ou cifrão ($) Não
Prof. Fellipe Araújo Aleixo [email protected]
Prof. Fellipe Araújo Aleixo [email protected] A arquitetura Enterprise JavaBeans é uma arquitetura de componentes para o desenvolvimento e a implantação de aplicativos de negócio distribuídos
Aplicações distribuídas em Java Parte II: Componentes EJB
Aplicações distribuídas em Java Parte II: Componentes EJB 51 Objetivos Explorar tecnologias usadas para implementar componentes de negócio para servidores de aplicação em Java Introdução a Enterprise JavaBeans
Programando sistemas distribuídos com objetos distribuídos na rede TCP/IP. Prof. Me. Sérgio Carlos Portari Júnior
Programando sistemas distribuídos com objetos distribuídos na rede TCP/IP Prof. Me. Sérgio Carlos Portari Júnior Conteúdo Programático Contextualizando: Aula anterior Camada Middleware Programar para SD
Message Oriented Middleware (MOM)
Message Oriented Middleware (MOM) March 24, 2010 Comunicação Assíncrona Problema: Nem sempre as entidades comunicantes estão disponíveis simultaneamente. Por exemplo, um servidor de submissão pode estar
Java RMI. Sistemas Distribuídos. Mauro Lopes Carvalho Silva. Professor EBTT DAI Departamento de Informática Campus Monte Castelo
Sistemas Distribuídos Mauro Lopes Carvalho Silva Professor EBTT DAI Departamento de Informática Campus Monte Castelo Instituto Federal de Educação Ciência e Tecnologia do Maranhão Objetivos Nesta aula
Linguagem de Programação II Implementação
Linguagem de Programação II Implementação Prof. Alessandro Borges 2 Tópicos Implementação em Java Variáveis Palavras reservadas Pacotes Identificador this Acessando membros de outros objetos API Java Nossa
4 - Padrões da Camada de Integração. Introdução
Padrões de Projeto J2EE J931 Padrões da Camada de Integração Helder da Rocha ([email protected]) argonavis.com.br Introdução A camada de integração encapsula a lógica relacionada com a integração do sistema
EJB. Session Beans. J2EE (C. Geyer) Introdução a SessionBean 1
EJB Session Beans J2EE (C. Geyer) Introdução a SessionBean 1 Autores! Autores " Cláudio Geyer " Eduardo Studzinski Estima de Castro (EJB 3.0) " Gisele Pinheiro Souza (EJB 3.0) J2EE (C. Geyer) Introdução
Aula 03. Evandro Deliberal
Aula 03 Evandro Deliberal [email protected] https://www.linkedin.com/in/evandrodeliberal Concorrência Método Sincronização Problemas: Perda de consistência Acesso a dados inconsistentes Perda de atualizações
Usando o Eclipse - Fundamentos. Professor Vicente Paulo de Camargo
Usando o Eclipse - Fundamentos Professor Vicente Paulo de Camargo O Eclipse é um ambiente de desenvolvimento integrado (IDE) É a ferramenta mais utilizada pelas empresas, visto que pode ser configurada
Polimorfismo. O que é polimorfismo?
O que é polimorfismo? Polimorfismo Significa que variáveis podem referenciar mais do que um tipo. Não é um conceito novo e várias linguagens de programação aplicam. Funções são polimórficas quando seus
Injeção de Dependências e Spring
Injeção de Dependências e Spring Daniel Cukier Prof. Fabio Kon IME-USP Conteúdo Exemplo Melhor maneira de aprender Injeção de Dependência (DI) Spring Service Locator Daniel Cukier - IME/USP 2/29 Exemplo
Programação Orientada a Objectos - P. Prata, P. Fazendeiro
9 Classes Abstractas e Interfaces Classe Abstracta Classe em que pelo menos um dos métodos de instância não é implementado. Exemplo: public abstract class Forma{ public abstract double area(); public abstract
Stateful Session Beans
J530 - Enterprise JavaBeans Stateful Session Beans Helder da Rocha ([email protected]) argonavis.com.br 1 Stateful Session Beans Quando um cliente chama um método de um bean, ele está iniciando um diálogo
p Pacotes, a grosso modo, são apenas pastas ou diretórios do sistema operacional onde ficam armazenados os arquivos fonte de Java.
Pacotes e Jar 1 Pacotes p Usamos pacotes em java para organizar as classes semelhantes. p Pacotes, a grosso modo, são apenas pastas ou diretórios do sistema operacional onde ficam armazenados os arquivos
Princípios de Sistemas Distribuídos. Tecnologias utilizadas em sistemas distribuídos Aula 5
Princípios de Sistemas Distribuídos Tecnologias utilizadas em sistemas distribuídos Aula 5 Conceitos de comunicação entre processos Interprocess Communication (IPC) Sistemas distribuídos são construídos
Tutorial J2EE. Aprendendo EJB de uma maneira fácil! Paulo Silveira
Tutorial J2EE Aprendendo EJB de uma maneira fácil! Paulo Silveira Aprendendo J2EE RemoteException ApplicationServer SessionBean JNDI ejb-jar.xml EJBLocalHome CMP RequiresNew CMR EJBContext Aprendendo J2EE
Exercícios de fixação: Listas
Exercícios de fixação: Listas Exercício 1 : Inlcuindo o driver ao seu projeto 1. No Eclipse, vamos criar um novo projeto chamado CursoJavaJDBC. 2. Copie o driver do MySQL para o seu projeto. a. localize
Aplicações Distribuídas Cliente/ Servidor Corporativas
Aplicações Distribuídas Cliente/ Servidor Corporativas Introdução Desenvolver e distribuir Servlets e aplicativos EJB. Desenvolver e distribuir aplicativos Enterprise JavaBeans (EJB). Introdução Simples
PadrãoIX. Módulo II JAVA. Marcio de Carvalho Victorino. Servlets A,L,F,M
JAVA Marcio de Carvalho Victorino 1 Servlets 2 1 Plataforma WEB Baseada em HTTP (RFC 2068): Protocolo simples de transferência de arquivos Sem estado (não mantém sessão aberta) Funcionamento (simplificado):
INTRODUÇÃO. RPC x RMI
1 INTRODUÇÃO RPC x RMI 2 INTRODUÇÃO RPC Remote procedure call Este termo é utilizado para aplicativos clientes que fazem normalmente chamadas a procedimentos remotos que estão em outro processo e hosts.
Num sistema de objectos distribuídos, dois conceitos são fundamentais.
Folha 9-1 Java RMI - Remote Method Invocation No modelo de programação orientada a objectos, vimos que um programa consiste numa colecção de objectos que comunicam entre si através da invocação dos seus
Programação orientada a objetos
J100 com Programação orientada a objetos TM SE Helder da Rocha ([email protected]) argonavis.com.br 1 Objetivos Este curso tem como objetivo iniciá-lo em Java... mas não apenas isto Visa também a ajudá-lo
Ferramenta MVCASE - Estágio Atual: Especificação, Projeto e Construção de Componentes
Ferramenta MVCASE - Estágio Atual: Especificação, Projeto e Construção de Componentes Antônio Francisco do Prado Daniel Lucrédio e-mail: [email protected] Resumo Este artigo apresenta a ferramenta CASE
TDC2012. EJB simples e descomplicado, na prática. Slide 1
TDC2012 EJB simples e descomplicado, na prática Slide 1 Palestrantes Kleber Xavier Arquiteto Senior / Globalcode [email protected] Vinicius Senger Arquiteto Senior / Globalcode [email protected]
Comunicação. Carlos A. G. Ferraz 25/6/2003. Sistemas Distribuídos 1. Tópicos. Camadas. Transmissão de dados. Marshalling/Unmarshalling.
Tópicos Comunicação Carlos Ferraz [email protected] Elementos básicos de comunicação Transmissão de dados Endereçamento Sincronismo Enfileiramento (Bufferização) Confiabilidade Portas e sockets UDP RPC:
J530 - Enterprise JavaBeans. Introdução a EJB e Stateless. Session Beans. argonavis.com.br. Helder da Rocha ([email protected])
J530 - Enterprise JavaBeans Introdução a EJB e Stateless Session Beans Helder da Rocha ([email protected]) argonavis.com.br 1 Componentes de um EJB Para que o container possa gerar o código necessário é preciso
Redes de Computadores e Aplicações
Instituto Federal de Educação, Ciência e Tecnologia do Rio Grande do Norte Campus Currais Novos Redes de Computadores e Aplicações Aula 13 - Camada de Aplicação Visão Geral Prof. Diego Pereira
UTILIZAÇÃO DA TECNOLOGIA ENTERPRISE JAVABEANS NO DESENVOLVIMENTO DE APLICAÇÕES DISTRÍBUIDAS
UTILIZAÇÃO DA TECNOLOGIA ENTERPRISE JAVABEANS NO DESENVOLVIMENTO DE APLICAÇÕES DISTRÍBUIDAS ¹Lucas Martins de Andrade, ¹Jaime William Dias ¹Universidade Paranaense (Unipar) Paranavaí PR Brasil [email protected]
