A Vert.x client allowing applications to interact with a RabbitMQ broker (AMQP 0.9.1)
This service is experimental and the APIs are likely to change before settling down.
Add the following dependency to your maven project
<dependency>
<groupId>io.vertx</groupId>
<artifactId>vertx-rabbitmq-client</artifactId>
<version>3.5.0</version>
</dependency>
Add the following dependency to your gradle project
dependencies {
compile 'io.vertx:vertx-rabbitmq-client:3.5.0'
}
You can create a client instance as follows using a full amqp uri:
def config = [:]
// full amqp uri
config.uri = "amqp://xvjvsrrc:[email protected]/xvjvsrrc"
def client = RabbitMQClient.create(vertx, config)
Or you can also specify individual parameters manually:
def config = [:]
// Each parameter is optional
// The default parameter with be used if the parameter is not set
config.user = "user1"
config.password = "password1"
config.host = "localhost"
config.port = 5672
config.virtualHost = "vhost1"
config.connectionTimeout = 6000
config.requestedHeartbeat = 60
config.handshakeTimeout = 6000
config.requestedChannelMax = 5
config.networkRecoveryInterval = 500
config.automaticRecoveryEnabled = true
def client = RabbitMQClient.create(vertx, config)
You can pass additional config parameters to RabbitMQ’s exchangeDeclare method
def config = [:]
config["x-dead-letter-exchange"] = "my.deadletter.exchange"
config["alternate-exchange"] = "my.alternate.exchange"
// ...
client.exchangeDeclare("my.exchange", "fanout", true, false, config, { onResult ->
if (onResult.succeeded()) {
println("Exchange successfully declared with config")
} else {
onResult.cause().printStackTrace()
}
})
The following are some examples of the operations supported by the RabbitMQService API.
Consult the javadoc/documentation for detailed information on all API methods.
Publish a message to a queue
def message = [
body:"Hello RabbitMQ, from Vert.x !"
]
client.basicPublish("", "my.queue", message, { pubResult ->
if (pubResult.succeeded()) {
println("Message published !")
} else {
pubResult.cause().printStackTrace()
}
})
Publish a message to a queue and confirm the broker acknowledged it.
def message = [
body:"Hello RabbitMQ, from Vert.x !"
]
// Put the channel in confirm mode. This can be done once at init.
client.confirmSelect({ confirmResult ->
if (confirmResult.succeeded()) {
client.basicPublish("", "my.queue", message, { pubResult ->
if (pubResult.succeeded()) {
// Check the message got confirmed by the broker.
client.waitForConfirms({ waitResult ->
if (waitResult.succeeded()) {
println("Message published !")} else {
waitResult.cause().printStackTrace()}
})
} else {
pubResult.cause().printStackTrace()
}
})
} else {
confirmResult.cause().printStackTrace()
}
})
Consume messages from a queue
// Create the event bus handler which messages will be sent to
// Create the event bus handler which messages will be sent to
vertx.eventBus().consumer("my.address", { msg ->
def json = msg.body()
println("Got message: ${json.body}")
})
// Setup the link between rabbitmq consumer and event bus address
client.basicConsume("my.queue", "my.address", { consumeResult ->
if (consumeResult.succeeded()) {
println("RabbitMQ consumer created !")
} else {
consumeResult.cause().printStackTrace()
}
})
Will get a message from a queue
client.basicGet("my.queue", true, { getResult ->
if (getResult.succeeded()) {
def msg = getResult.result()
println("Got message: ${msg.body}")
} else {
getResult.cause().printStackTrace()
}
})
// Create the event bus handler which messages will be sent to
vertx.eventBus().consumer("my.address", { msg ->
def json = msg.body()
println("Got message: ${json.body}")
// ack
client.basicAck(json.deliveryTag, false, { asyncResult ->
})
})
// Setup the link between rabbitmq consumer and event bus address
client.basicConsume("my.queue", "my.address", false, { consumeResult ->
if (consumeResult.succeeded()) {
println("RabbitMQ consumer created !")
} else {
consumeResult.cause().printStackTrace()
}
})
You will need to have RabbitMQ installed and running with default ports on localhost for this to work. <a href="mailto:[email protected]">Nick Scavelli</a>