NAME
Beekeeper::Service::Sinkhole::Worker - Handle unserviced call topics
VERSION
Version 0.07
DESCRIPTION
In the case of all workers of a given service being down, all requests sent to the service will timeout as no one is serving them. This may cause a serious disruption in the application, as any other service depending of the broken one will halt too for the duration of the timeout.
In order to mitigate this situation all Sinkhole workers will be notified by the Supervisor when unserviced topics are detected, making these to respond immediately to all requests with an error response. Then callers will quickly receive an error response instead of timing out.
As soon as a worker of the downed service becomes online again the Sinkhole workers will stop rejecting requests.
A single Sinkhole worker can handle around 4000 req/s.
Sinkhole workers are not created automatically. In order to add Sinkhole workers to a pool these must be declared into config file pool.config.json
:
[
{
"pool_id" : "myapp",
"bus_id" : "backend",
"workers" : {
"Beekeeper::Service::Sinkhole::Worker" : { "worker_count": 2 },
...
},
},
]
METHODS
This worker class does not expose public methods.
AUTHOR
José Micó, jose.mico@gmail.com
COPYRIGHT AND LICENSE
Copyright 2015-2021 José Micó.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language itself.
This software is distributed in the hope that it will be useful, but it is provided “as is” and without any express or implied warranties. For details, see the full text of the license in the file LICENSE.