An Introduction to STOMP
Join the DZone community and get the full member experience.
Join For FreeSTOMP (Simple (or Streaming) Text-Oriented Messaging Protocol) is a simple text-oriented protocol, similar to HTTP.
STOMP provides an interoperable wire format that allows clients to communicate with almost every available message broker. STOMP is easy to implement and gives you flexibility since it is language-agnostic, meaning clients and brokers developed in different languages can send and receive messages to and from each other.
There are lots of server implementations that support STOMP (mostly compliant with the STOMP 1.0 specification). The following is a list of STOMP 1.0 compliant message servers:
- Apache ActiveMQ – http://activemq.apache.org
- Apache Apollo – http://activemq.apache.org/apollo
- CoilMQ – http://code.google.com/p/coilmq
- Gozirra - http://www.germane-software.com/software/Java/Gozirra
- HornetQ – http://www.jboss.com/hornetq
- MorbidQ – http://www.morbidq.com
- RabbitMQ - http://www.rabbitmq.com/plugins.html#rabbitmq-stomp
- Sprinkle - http://www.thuswise.org/sprinkle/index.html
- StompServer - http://stompserver.rubyforge.org/
On the client side, there are many implementations for a vast number of technologies. Below, you will find the libraries available for the most popular languages.
Language
|
Libraries
|
C
|
libstomp - http://stomp.codehaus.org/C
|
C++
|
Apache CMS - http://activemq.apache.org/cms/
|
C# and .Net
|
Apache NMS - http://activemq.apache.org/nms/
|
Flash
|
as3-stomp - http://code.google.com/p/as3-stomp/
|
Java
|
|
Objective-C
|
objc-stomp - https://github.com/juretta/objc-stomp
|
Perl
|
Net::Stomp::Client - http://search.cpan.org/dist/Net-STOMP-Client/
Net::Stomp - http://search.cpan.org/dist/Net-Stomp/
|
PHP
|
|
Python
|
stomp.py - http://code.google.com/p/stomppy/
|
Ruby on Rails
|
stomp gem - https://rubygems.org/gems/stomp
activemessaging - http://code.google.com/p/activemessaging/
|
STOMP is an alternative to other open messaging protocols such as AMQP (Advanced Message Queueing Protocol) and implementation specific wire protocols used in JMS (Java Message Service) brokers such as OpenWire. It distinguishes itself by covering a small subset of commonly used messaging operations (commands) rather than providing a comprehensive messaging API.
Because STOMP is language-agnostic and easy to implement, it’s popular to application developers and technical architects alike. STOMP is also text-based. Since it does not use binary protocols like other message brokers, a wide range of client technologies work with STOMP, like Ruby, Python, and Perl.
STOMP is simple to implement, but supports a wide range of core enterprise messaging features, such as authentication, messaging models (point to point and publish and subscribe), message acknowledgement, transactions, message headers and properties, etc.
Protocol (object-oriented programming)
Apache ActiveMQ
Objective C
Implementation
Perl (programming language)
Python (language)
Library
application
Acknowledgement (data networks)
Published at DZone with permission of Marcelo Jabali, DZone MVB. See the original article here.
Opinions expressed by DZone contributors are their own.
Comments