Pro Java Clustering and Scalability by Jorge Acetozi
Author:Jorge Acetozi
Language: eng
Format: epub
Publisher: Apress, Berkeley, CA
10.3 Message Flow Using a Simple Broker
Figure 10-1 shows the message flow with a simple broker. The figure may be confusing at first glance, but this is exactly the flow that you just learned about.
Figure 10-1.Message flow: simple broker
When you send a frame through WebSocket over STOMP, the message will first reach clientInboundChannel. There, it will be routed to a specific MessageHandler depending on the destination name. If the name starts with /app, then it will route it to the SimpAnnotationMethod message handler (which will eventually call your @MessageMapping annotated method inside the @Controller class). If the name starts with /topic, then it will route it directly to the SimpleBroker4 message handler.
Let’s look at an example of the frame SEND /app/a. First, clientInboundChannel will receive and forward it to the SimpAnnotationMethod message handler. Then, from the @MessageMapping annotated method, the message will be forwarded to brokerChannel. This will send it to the SimpleBroker message handler. This message handler keeps a ConcurrentHashMap with every WebSocket session ID for every connected client and also all the subscriptions in the SubscriptionRegistry (in memory). Then, the message handler uses the WebSocket client ID to forward the message to the corresponding clientOutboundChannel, which will finally send the message to the client.
Note that using the simple broker approach , the subscriptions are kept in memory.
Download
This site does not store any files on its server. We only index and link to content provided by other sites. Please contact the content providers to delete copyright contents if any and email us, we'll remove relevant links or contents immediately.
Deep Learning with Python by François Chollet(12568)
Hello! Python by Anthony Briggs(9912)
OCA Java SE 8 Programmer I Certification Guide by Mala Gupta(9795)
The Mikado Method by Ola Ellnestam Daniel Brolund(9777)
Dependency Injection in .NET by Mark Seemann(9336)
Algorithms of the Intelligent Web by Haralambos Marmanis;Dmitry Babenko(8293)
Test-Driven iOS Development with Swift 4 by Dominik Hauser(7760)
Grails in Action by Glen Smith Peter Ledbrook(7693)
The Well-Grounded Java Developer by Benjamin J. Evans Martijn Verburg(7557)
Becoming a Dynamics 365 Finance and Supply Chain Solution Architect by Brent Dawson(7040)
Microservices with Go by Alexander Shuiskov(6805)
Practical Design Patterns for Java Developers by Miroslav Wengner(6717)
Test Automation Engineering Handbook by Manikandan Sambamurthy(6656)
Secrets of the JavaScript Ninja by John Resig Bear Bibeault(6409)
Angular Projects - Third Edition by Aristeidis Bampakos(6065)
The Art of Crafting User Stories by The Art of Crafting User Stories(5596)
NetSuite for Consultants - Second Edition by Peter Ries(5531)
Demystifying Cryptography with OpenSSL 3.0 by Alexei Khlebnikov(5335)
Kotlin in Action by Dmitry Jemerov(5062)
