Totoro is a RabbitMQ util that focuses on samplify queue operation.
Please install Delayed Job active record and Delayed Job recurring before use Totoro. Totoro basically use delayed job to cache and resend falied messages.
Add this line to your application's Gemfile:
gem 'totoro'
And then execute:
$ bundle
rails g totoro:init
This command will generate two files
totoro.yml
(Rabbitmq configuration file)initilizers/totoro.rb
(Rails initializer)db/migrate/[tiemstamp]_create_totoro_failed_messages.rb
(DB migration to create messages caching table)
rails g delayed_job:active_record
https://github.com/collectiveidea/delayed_job
rake db:migrate
default: &default
default:
connect:
host: rabbitmq
port: 5672
user: app
pass: app
queue:
normal_queue_for_both_enqueue_and_subscribe:
name: default_exchange.queue.name
persistent: true
durable: true
clean_start: false
exchange_queue_for_subscribe:
name: fanout.exchange.queue
durable: true
exchange: fanout.exchange.name
exchange:
exchange_for_fanout_enqueue:
name: fanout.exchange.name
persistent: false
custom:
connect:
host: rabbitmq
port: 5672
user: app
pass: app
queue:
custom_queue:
name: custom.queue.name
durable: true
development:
<<: *default
test:
<<: *default
production:
<<: *default
Please run rake totoro:resend_msg
before you start your app.
Totoro::Queue.enqueue('queue_id', payload)
Totoro::Queue.broadcast('exchange_id', payload)
To create a dequeue daemon, first you need to create a worker
rails g totoro:worker <worker_name> <queue_name>
after that, add business logic in the process method
module Worker
class WorkerClass < Totoro::BaseWorker
setup queue_name: <queue_name>
def process(payload, metadata, delivery_info)
# worker process
end
end
end
finally, run the background deamon
bundle exec totoro worker_class
When you have more than one rabbitmq server to connect, you need to add custom configuration.
To use the custom rabbitmq server you need to add ServerName
between Totoro
and Queue
For example:
Totoro::<ServerName>::Queue.enqueue('queue', payload)
To create a dequeue daemon, first you need to create a worker
rails g totoro:wroker <worker_name> <queue_name> <prefix>
after that, add business logic in the process method
module Worker
class WorkerClass < Totoro::BaseWorker
setup queue_name: <queue_name>, prefix: <prefix>
def process(payload, metadata, delivery_info)
# worker process
end
end
end
finally, run the background deamon
bundle exec totoro worker_class
Bug reports and pull requests are welcome on GitHub at https://github.com/blockchaintech-au/totoro. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the Contributor Covenant code of conduct.
The gem is available as open source under the terms of the MIT License.
Everyone interacting in the Totoro project’s codebases, issue trackers, chat rooms and mailing lists is expected to follow the code of conduct.