Lightweight, scalable, high-performance Event Driven Architecture (EDA
) Enabler
- Java 7+
- RabbitMQ/SQS
- MongoDB
- Redis
brew install scala
brew install sbt
sudo apt-get install scala
echo "deb http://dl.bintray.com/sbt/debian /" | sudo tee -a /etc/apt/sources.list.d/sbt.list
sudo apt-get update
sudo apt-get install sbt
For the test phase of the build the test
vhost is required:
sudo rabbitmq-plugins enable rabbitmq_management
curl -i -u guest:guest -H "content-type:application/json" -XPUT http://localhost:15672/api/vhosts/%2Ftest
curl -i -u guest:guest -H "content-type:application/json" -XPUT http://localhost:15672/api/permissions/%2Ftest/guest -d'{"read": ".*", "write": ".*", "configure":".*"}'
git clone git@github.com:igorshapiro/serviceHub
cd serviceHub
sbt assembly
java -cp target/scala-2.11/hub-assembly-1.0.jar Boot
Create services.json
in the same directory you placed hub-assembly-1.0.jar.
Example of the manifest:
{
"services": [{
"name": "orders",
"publishes": ["order_created"],
"subscribes": ["order_paid"],
"endpoints": "http://server.com/:message_type",
"queue": "rabbitmq://rabbit.server.org/:queue_name",
"intermediary": "redis://redis.server.org/0",
"archive": "mongodb://mongo.server.org/messages_archive"
}, {
"name": "billing",
"publishes": ["order_paid"],
"subscribes": ["order_created"],
"endpoints": "http://localhost/:message_type"
}
]
}
Elements:
- name - name of the service as it will be displayed in the dashboard and queues are named (for example orders_input)
- publishes - messages being published by this service
- subscribes - messages this service subscribes to
- endpoints - a string or a hash specifying the url to deliver the message to. The message is delivered by a HTTP POST request to the endpoint (after all placeholders were replaced).
- http(s)://
- queue - Message queue server to use (currently only rabbitmq is supported)
- rabbitmq://
- sqs:// (TBD)
- intermediary - Storage to use for intermediary storing the messages - for example for tracking which messages are being processed
- redis://
- mongodb:// (TBD)
- postgres:// (TBD)
- mysql:// (TBD)
- archive - Storage to use for archiving all messages
- mongodb://
- postgres:// (TBD)
- mysql:// (TBD)
- dynamodb:// (TBD)
java -cp target/scala-2.11/hub-assembly-1.0.jar Boot
Now from the orders service you can publish your messages:
require 'rest_client'
RestClient.post 'http://your_service_hub_host:8080/api/v1/messages', {
message_type: "order_created",
content: {
id: "order_1",
user: {
id: "user_2",
email: "me@gmail.com"
}
}
}.to_json, content_type: :json
The message will be delivered to the endpoint of the billing service, as specified in the services manifest as a POST request.
In service endpoints you can specify placeholders that will be replaced by the actual message values:
{
"endpoints": "http://:env.server.com/handlers/:type"
}
Currently the following placeholders are supported:
- type - message type (example: order_created)
- env - message environment (example: dev)
Sometimes there's no generic scheme of the different urls that can be expressed via placeholders. In this case you can provide a hash:
{
"endpoints": {
"*": "http://:env.company.com/handlers/:type",
"dev": "http://localhost/handlers/:type"
}
}
Note The *
specifies the default environment
The system consists of actors of the following types:
Sends messages to outgoing queue
Listens to messages in output queue of the service and dispatches them to subscribers input queues
Delivers messages to services (via HTTP POST requests) and takes actions based on service response:
- Re-enqueue (if failed)
- Schedule (if 302 status returned)
- Discard (if succeeded)
- Move to dead letter queue (if max attempts reached)
Polls the schedule storage and enqueues any messages due
Listens to the queue and sends any messages to Processing actors