Notice: This Wiki is now read only and edits are no longer possible. Please see: https://gitlab.eclipse.org/eclipsefdn/helpdesk/-/wikis/Wiki-shutdown-plan for the plan.
OSEE/Design/Messaging
< OSEE
Contents
- 1 Messaging System Design Notes
- 2 Events versus Messages
- 2.1 What is the broker topology
- 2.2 What are the topics/queue names, what are their functions, and how do we use them
- 2.3 Messages
- 2.3.1 CORE
- 2.3.2 OTE
- 2.3.2.1 topic:OSEE.OTE.station.global.statusRequest
- 2.3.2.2 topic:OSEE.OTE.station.global.statusResponse
- 2.3.2.3 topic:OSEE.OTE.station.<station_name>.<station_id>.status
- 2.3.2.4 topic:OSEE.OTE.station.<station_name>.<station_id>.command
- 2.3.2.5 topic:OSEE.OTE.station.<station_name>.<station_id>.<model>.command
- 2.3.2.6 topic:OSEE.OTE.station.<station_name>.<station_id>.<model>.status
Messaging System Design Notes
10/20/09
Concepts
- Message:
- Topic:
- Component:
- Queue:
- Transport:
- Camel:
- ActiveMQ:
- Broker:
- Event:
- Message Transaction:
Requirements
- Register Listener
- Message Types
- Status messages
- Commands
- Operation in progress
- Operation complete
- Cancel Operation messages
- Control Messages - communication between app servers?
- Provide interim progress information
- Web Service Interaction
Use Cases
- Web page sends a message with JSON object. Broker converts HTTP to JMS message
sends to all subscribers.
- Application kicks an operation and is able to sync on message receives.
- Broker comes alive, clients connect to broker and broker redirects client to appropriate application server
TODO
- Document App Server Messages/Interactions
- Add Sequence Diagram for Messages
Events versus Messages
Events: inter-process communication Messages: enterprise wide communication
What is the broker topology
network of brokers, host1 + host2 + host3, we need to make sure ote can function w/o the DB layer available... so i want to make sure we can run with a network of brokers, and it has to be easily configurable so that platforms not using the persistence layer can function. Potentially in some cases we launch an embedded broker.
What are the topics/queue names, what are their functions, and how do we use them
CONSIDERATIONS:
- queue - used for app server commands - it gets removed by the first consumer to get it, so if there are multiple subscribers only one will act upon the message.
- topic - used for status - broadcast - pubsub
Messages
CORE
queue:OSEE.CORE.createBranch
- subscribers: appServers
- publishers: oseeClients
topic:OSEE.CORE.newBranch
- subscribers: oseeClients
- publishers: appServers
OTE
topic:OSEE.OTE.station.global.statusRequest
- subscribers: oteTestServers
- publishers: oteTestClients
- purpose: sent by test clients to find out information about available test servers, i.e. who exists, in what configuration, current state (connected clients, etc..)
topic:OSEE.OTE.station.global.statusResponse
- subscribers: oteTestClients
- publishers: oteTestServers
- purpose: the response message to a 'OSEE.OTE.station.global.statusRequest', contains configuration and state information of a test server
topic:OSEE.OTE.station.<station_name>.<station_id>.status
- subscribers: connected-oteTestClients
- publishers: specific-oteTestServers
- purpose: update of current state, errors, test point, current command, etc...
topic:OSEE.OTE.station.<station_name>.<station_id>.command
- subscribers: specific-oteTestServers
- publishers: connected-oteTestClients
- purpose: command the ote environment to do something
topic:OSEE.OTE.station.<station_name>.<station_id>.<model>.command
- subscribers: specific-oteTestServers
- publishers: connected-oteTestClients
- purpose: command a model to do something
topic:OSEE.OTE.station.<station_name>.<station_id>.<model>.status
- subscribers: connected-oteTestClients
- publishers: specific-oteTestServers
- purpose: update of current state, errors, test point, current command, etc...