2600Hz AMQP Event Pools
Provides a way for the 2600Hz node to bind for common AMQP events and distribute locally versus every app or process bindings for them.
For instance, call events are used by many apps, each of which may be running on the same VM together. Rather than having a CHANNEL_CREATE
delivered N times to the node, have it be delivered once from the broker and use internal Erlang messaging (via gproc) to distribute the payload.
This limits using up AMQP channels, which have a hard-coded limit of 2047, by allowing apps to not instantiate dynamic gen_listener
processes (say per-call or per-agent) which would approach the limit.
Event bindings
At the time of writing, the supported bindings are:
- call events
- configuration events (doc change events)
- presence (updates and dialog events)
Erlang Architecture
Runtime
kazoo_events_sup
|
--> kz_event_listeners_sup
|
--> [kz_event_listener_sup
|
--> [kz_event_listener,...]
]
Simple supervisor tree where the kz_event_listeners_sup
starts as a SOFO supervisor with kz_event_listener_sup
as its childspec. Once a 2600Hz app (or process) uses a kz_events:bind*
function, the kz_events_listeners_sup
will start a kz_event_listener_sup
supervisor to then start the gen_listener
pool.
Apps can programmatically start the pool of listeners at startup as well.
Worker count
You can configure how many gen_listener
workers are started in two ways: per-event-type or single default count. Check the kazoo_events
system_config
document:
%% default count
{"_id":"kazoo_events"
,"default":{
"event_listeners":5
}
}
%% per-event-type count
{"_id":"kazoo_events"
,"default":{
"call_events":{
"event_listeners":5
}
,"presences":{
"event_listeners":5
}
}
}