Academic Tutorials



English | French | Portugese | Dutch | Italian
Google

em linha

Home Códigos de fonte E-Livros Downloads Contatar-nos Sobre nós

HTML Tutorials
HTML Tutorial
XHTML Tutorial
CSS Tutorial
TCP/IP Tutorial
XML Tutorials
XML Tutorial
XSL Tutorial
XSLT Tutorial
DTD Tutorial
Schema Tutorial
XForms Tutorial
XSL-FO Tutorial
XML DOM Tutorial
XLink Tutorial
XQuery Tutorial
XPath Tutorial
XPointer Tutorial
RDF Tutorial
SOAP Tutorial
WSDL Tutorial
RSS Tutorial
WAP Tutorial
Web Services Tutorial
Browser Scripting
JavaScript Tutorial
VBScript Tutorial
AJAX Tutorial
DHTML Tutorial
HTML DOM Tutorial
WMLScript Tutorial
E4X Tutorial
Server Scripting
ASP Tutorial
PHP Tutorial
PERL Tutorial
SQL Tutorial
ADO Tutorial
.NET (dotnet)
Microsoft.Net
XML Web Services
ASP.Net
.Net Mobile
C# : C Sharp
ADO.NET
VB.NET
Multimedia
SVG Tutorial
Flash Tutorial
Media Tutorial
SMIL Tutorial
Web Building
Web Browsers
Web Hosting
W3C Tutorial
Web Building
Web Quality
Web Semantic
Web Careers
Java Tutorials
Java Tutorial
JSP Tutorial
Servlets Tutorial
Struts Tutorial
EJB Tutorial
JMS Tutorial
JMX Tutorial
Programming Langauges
C Tutorial
C++ Tutorial
Visual Basic Tutorial
Data Structures Using C
Soft Skills
Communication Skills
Time Management
Project Management
Team Work
Leadership Skills
Corporate Communication
Negotiation Skills


JMS Peer-to-Peer and the PublishSubscribe

Previous Next




Peer-to-Peer (P2P)

The problem with a generic term like Peer-to-Peer (P2P) network computing is that it inevitably means different things to different people, and so you will find the term applied to a variety of systems. For example, you will find the term applied to:

  • Centralized systems where every peer connects to a server which coordinates and manages communication.



  • Decentralized systems, where peers run independently without the need for centralized services.



  • Brokered systems where peers connect to a server in order to discover other peers, but then manage the communication themselves.



  • Project JXTA defines a set of protocols that can be used to construct peer-to-peer systems using any of the centralized, brokered and decentralized approaches. J2EE is intended for server-side computing, which suggests it is most suited for a centralized peer-to-peer system. A good way to get a better appreciation of the differences is to study a simple example application. This first article will introduce a very simple JMS chat application for the exchange of messages between users. The choice of a chat application is deliberate because Project JXTA already supplies a demonstration application called myJXTA (which is also known by its former name of InstantP2P) that includes a sophisticated chat capability.




Peer-to-peer example code using JMS

The JMS chat application was deployed and tested using the Java 2 SDK, Enterprise Edition Version 1.3 so this is the environment that will be assumed. To run the JMSChat example you must have installed the latest version of the Java 2 SDK, Enterprise Edition Version 1.3. You should first install the required version of the Java 2 SDK, Standard Edition, if not already installed. The links to the appropriate locations are given below:

This section contains instructions on how to create and run a simple JMS chat program. It is an adaptation of the publish/subscribe (pub/sub) example provided by the JMS tutorial. Before you can run the example, you need to make sure your environment is set appropriately. Table 1 shows how to set the environment variables needed to run J2EE applications on Windows and UNIX platforms.

Java 2 SDK, Enterprise Edition Version 1.3. And the Java 2 SDK, Standard Edition




Writing the Chat Client Program

The JMSChat client is a multi-threaded Java program that uses a pub/sub topic for broadcasting messages to all subscribers to the topic. It uses separate threads for publishing messages to the topic and for receiving messages from the topic. These threads are implemented by the JMSChatThread class.

The publishing thread does the following:

  • Performs a JNDI lookup of the TopicConnectionFactory and topic


  • Creates a connection and session



  • Creates a TopicPublisher



  • Creates a TextMessage



  • Publishes messages to the topic



  • Closes the connection, which automatically closes the session and TopicPublisher



  • The receiving thread does the following:

  • Performs a JNDI lookup of the TopicConnectionFactory and topic



  • Creates a connection and session



  • Creates a TopicSubscriber



  • Starts the connection, causing message delivery to begin



  • Listens for the messages published to the topic



  • Closes the connection, which automatically closes the session and TopicSubscriber






Publish/Subscribe (pub/sub)

A pub/sub application has the following characteristics:

  1. A pub/sub producer is publisher
  2. A message may have multiple subscribers
  3. A pub/sub destination is a topic
  4. A pub/sub consumer is a subscriber
An email newsletter application may use a publish/subscribe model. Everyone who is interested in the newsletter becomes a subscriber, and when a new message is published (say the head of HR sends out new info), that message is sent to all subscribers.

Writing the Pub/Sub Client Programs. The publishing program (SimpleTopicPublisher.java) performs the following steps:

  1. Performs the JNDI API lookup of the TopicConnectionFactory and topics.

  2. Creates the connections and a sessions.

  3. Creates the TopicPublisher.
  4. Creates the TextMessage.
  5. Publishes one or more messages to the topics.

  6. Closes the connection, which automatically closes the session and the TopicPublisher.

The receiving program (SimpleTopicSubscriber.java) performs the following steps:
  1. Performs the JNDI API lookup of the TopicConnectionFactory and topics.

  2. Creates the connection and a sessions.
  3. Creates the TopicSubscriber.
  4. Creates an instance of the TextListener class and registers it as the message listener for a TopicSubscriber.

  5. Starts the connection, causing the message delivery to begin.

  6. Listens for the messages published to the topic, stopping when the user enters the letters(characters) q or Q (Quit).

  7. Closes the connection, which automatically closes the session and TopicSubscriber.

The message listener (TextListener.java) follows these steps:
  1. When the message arrives, the onMessage method is called automatically.

  2. The onMessage method converts the incoming message to a TextMessage and displays its appropriate contents.





Previous Next

Keywords: JMS Peer-to-Peer and the PublishSubscribe,jms web services,jms sample code,open source jms,jms web service,websphere mq jms,file sharing peer,jms api,jms architecture,jms examples,jms session,jms jdbc,peer music,jndi jms,jms database,bea jms,ibm jms,using jms,jms connection,jms queue,peer software,remote jms,p2p peer,peer program,peer network,java to,c# to.


HTML Quizes
HTML Quiz
XHTML Quiz
CSS Quiz
TCP/IP Quiz
XML Quizes
XML Quiz
XSL Quiz
XSLT Quiz
DTD Quiz
Schema Quiz
XForms Quiz
XSL-FO Quiz
XML DOM Quiz
XLink Quiz
XQuery Quiz
XPath Quiz
XPointer Quiz
RDF Quiz
SOAP Quiz
WSDL Quiz
RSS Quiz
WAP Quiz
Web Services Quiz
Browser Scripting Quizes
JavaScript Quiz
VBScript Quiz
AJAX Quiz
DHTML Quiz
HTML DOM Quiz
WMLScript Quiz
E4X Quiz
Server Scripting Quizes
ASP Quiz
PHP Quiz
PERL Quiz
SQL Quiz
ADO Quiz
.NET (dotnet) Quizes
Microsoft.Net Quiz
XML Web Services Quiz
ASP.Net Quiz
.Net Mobile Quiz
C# : C Sharp Quiz
ADO.NET Quiz
VB.NET Quiz
Multimedia Quizes
SVG Quiz
Flash Quiz
Media Quiz
SMIL Quiz
Web Building  Quizes
Web Browsers Quiz
Web Hosting Quiz
W3C Quiz
Web Building Quiz
Web Quality Quiz
Web Semantic Quiz
Web Careers Quiz
Java Quizes
Java Quiz
JSP Quiz
Servlets Quiz
Struts Quiz
EJB Quiz
JMS Quiz
JMX Quiz
Programming Langauges Quizes
C Quiz
C++ Quiz
Visual Basic Quiz
Data Structures Using C Quiz
Soft Skills Quizes
Communication Skills Quiz
Time Management Quiz
Project Management Quiz
Team Work Quiz
Leadership Skills Quiz
Corporate Communication Quiz
Negotiation Skills Quiz

Privacy Policy
Copyright © 2003-2008 Vyom Technosoft Pvt. Ltd., All Rights Reserved.