# in config/config.exs
config :message_queue,
app_name: my_app,
adapter: :rabbitmq,
rpc_modules: [SampleModule]app_name- name of your applicationadapter- kind of adapter. Possible values::rabbitmq,:sandboxrpc_modules- modules are available for remote call
An adapter is a set of instructions for how to communicate with a specific service.
MessageQueue provides adapters for use RabbitMQ and for testing. To use these adapters, declare them in the environment configuration.
You can create new adapters for any environment by implementing the MessageQueue.Adapters.Producer, MessageQueue.Adapters.Consumer, MessageQueue.Adapters.RPCServer, MessageQueue.Adapters.RPCCclient or MessageQueue.Adapters.Connection behaviour.
config :message_queue,
adapter: MessageQueue.CustomLocalAdapterIn that case you must define module(s) for specific logic.
Follow the naming convention!
For example:
MessageQueue.CustomLocalAdapter.Producer
MessageQueue.CustomLocalAdapter.Consumer
MessageQueue.CustomLocalAdapter.RPCServer
MessageQueue.CustomLocalAdapter.RPCClient
MessageQueue.CustomLocalAdapter.Connection
use MessageQueue.Consumer
def start_link(_opts) do
GenServer.start_link(__MODULE__, %{queue: "queue", prefetch_count: 1}, name: __MODULE__)
end
def handle_message(payload, meta, state) do
...
endIf available in Hex, the package can be installed
by adding message_queue to your list of dependencies in mix.exs:
def deps do
[
{:message_queue, github: "ChannexIO/message_queue"}
]
end