JMS Interview Questions
1) What is Messaging?
Messaging is a method of communication between software components or applications
2) What is JMS?
Java Message Service is a Java API that allows applications to create, send, receive, and read messages.
3) Is JMS a specification or a product?
JMS is a specification.
4) What are the features of JMS?
The following are the important features of JMS:
a. Asynchronous Processing.
b. Store and forwarding.
c. Guaranteed delivery.
d. Provides location transparency.
e. Service based Architecture.
5) What are two messaging models or messaging domains?
a. Point-to-Point Messaging domain.
b. Publish/Subscribe Messaging domain
6) Explain Point-to-Point Messaging model.
A point-to-point (PTP) product or application is built around the concept of message queues, senders, and receivers. Each message is addressed to a specific queue, and receiving clients extract messages from the queue(s) established to hold their messages. Queues retain all messages sent to them until the messages are consumed or until the messages expire.
Point-to-Point Messaging has the following characteristics:
a. Each Message has only one consumer.
b. The receiver can fetch the message whether or not it was running when the client sent the message.
c. The receiver acknowledges the successful processing of a message.
7) Explain Pub/Sub Messaging model.
In a publish/subscribe (pub/sub) product or application, clients address messages to a topic. Publishers and subscribers are generally anonymous and may dynamically publish or subscribe to the content hierarchy. The system takes care of distributing the messages arriving from a topic's multiple publishers to its multiple subscribers. Topics retain messages only as long as it takes to distribute them to current subscribers.
Pub/sub messaging has the following characteristics:
a. Each message may have multiple consumers.
b. Publishers and subscribers have a timing dependency. A client that subscribes to a topic can consume only messages published after the client has created a subscription, and the subscriber must continue to be active in order for it to consume messages.
8) What are the two types of Message Consumption?
a. Synchronous Consumption :A subscriber or a receiver explicitly fetches the message from the destination by calling the receive method. The receive method can block until a message arrives or can time out if a message does not arrive within a specified time limit.
b. Asynchronous Consumption : A client can register a message listener with a consumer. A message listener is similar to an event listener. Whenever a message arrives at the destination, the JMS provider delivers the message by calling the listener's onMessage method, which acts on the contents of the message.
9) What is a connection factory?
A connection factory is the object a client uses to create a connection with a provider. A connection factory encapsulates a set of connection configuration parameters that has been defined by an administrator.Each connection factory is an instance of either the QueueConnectionFactory or the TopicConnectionFactory interface.
10) What is a destination?
A destination is the object a client uses to specify the target of messages it produces and the source of messages it consumes. In the PTP messaging domain, destinations are called queues and in the pub/sub messaging domain, destinations are called topics.
11) What is a message listener?
A message listener is an object that acts as an asynchronous event handler for messages. This object implements the MessageListener interface, which contains one method, onMessage. In the onMessage method, you define the actions to be taken when a message arrives.
12) What is a message selector?
Message selector filters the messages received by the consumer based on a criteria. Message selectors assign the work of filtering messages to the JMS provider rather than to the application. A message selector is a String that contains an expression. The syntax of the expression is based on a subset of the SQL92 conditional expression syntax. The message consumer then receives only messages whose headers and properties match the selector.
13) Can a message selector select messages on the basis of the content of the message body?
No. The message selection is only based on message header and message properties.
14) What are the parts of a JMS message?
A JMS message has three parts:
a. header
b. Properties (optional)
c. body (optional)
15) What is a message header?
A JMS message header contains a number of predefined fields that contain values that both clients and providers use to identify and to route messages.Each header field has associated setter and getter methods, which are documented in the description of the Message interface.
16) What are message properties?
Message properties are additional user defined properties other than those that are defined in the header.
17) What is the root exception of JMS?
JMSException is the root class for exceptions thrown by JMS API methods.
18) Name few subclasses of JMSException.
a. MessageFormatException
b. MessageEOFException
c. InvalidClientIDException
d. InvalidDestinationException
e. InvalidSelectorException
19) What is a Message?
A message is a package of business data that is sent from one application to another over the network. The message should be self-describing in that it should contain all the necessary context to allow the recipients to carry out their work independently.
20) How many types are there and What are they?
There are 5 types of Messages. They are:
a. TextMessage : A java.lang.String object (for example, the contents of an Extensible Markup Language file).
b. MapMessage : A set of name/value pairs, with names as String objects and values as primitive types in the Java programming language. The entries can be accessed sequentially by enumerator or randomly by name. The order of the entries is undefined.
c. BytesMessage : A stream of uninterpreted bytes. This message type is for literally encoding a body to match an existing message format.
d. StreamMessage: A stream of primitive values in the Java programming language, filled and read sequentially.
e. ObjectMessage: A Serializable object in the Java programming language.
21) What is a Topic?
22) What is a Queue?
23) What is a Message Driven Bean?
24) Do MDB's have component interfaces?
25) Do MDB's have JNDI?
26) Why do MDB's dont have component interfaces or JNDI?
27) Can be MDB be attached to different listeners in the same EAR?
27) What are the two parts of a message and explain them?
A message basically has two parts : a header and payload. The header is comprised of special fields that are used to identify the message, declare attributes of the message, and provide information for routing. Payload is the type of application data the message contains.
28) What are the two types of delivery modes?
29)What is the method that would be called on arrival of a message and what is its argument?