Dead Streams Eviction
Savant automatically evicts dead streams. You know about such evictions by receiving corresponding events (via designated callbacks) in your Pyfuncs: normally, you do not need to manually deal with evictions. Instead, configuration parameters specified per source tune how frequently Savant checks the idle streams and how long the stream can be inactive before being considered dead.
The behavior is configured with the following parameters specified in the YAML configuration file per source:
source_timeout
(default:10
seconds);source_eviction_interval
(default:1
second).
The first one specifies a period in seconds, defining how long a stream can avoid sending frames to the pipeline before it is considered inactive;
The second specifies how often Savant checks for inactive streams and evicts them.
Depending on the nature of the data sources, you should tune the values to reflect real-life conditions and avoid sending EOS events to the functions when a stream is not expected to be dead.
Let us consider the situation when the pipeline is designed to process the data from RTSP cameras. In this case, you would like to decrease the source_timeout
parameter to 2-3
seconds to reflect the always-availability nature of RTSP streams.
Another case is when you handle file fragments from S3. This case assumes that the fragment may be late. To address the situation, you may want to increase the source_timeout
parameter to 120
seconds and source_eviction_interval
to 10
seconds.
Take a look at the default.yml
for details:
# pipeline definition
pipeline:
source:
element: zeromq_source_bin
properties:
socket: ${oc.env:ZMQ_SRC_ENDPOINT}
socket_type: ${oc.env:ZMQ_SRC_TYPE, ROUTER}
bind: ${oc.decode:${oc.env:ZMQ_SRC_BIND, True}}
# Filter inbound frames by source ID.
source_id: ${oc.decode:${oc.env:SOURCE_ID, null}}
# Filter inbound frames by source ID prefix.
source_id_prefix: ${oc.decode:${oc.env:SOURCE_ID_PREFIX, null}}
# Timeout before deleting stale source (in seconds).
source_timeout: ${oc.decode:${oc.env:SOURCE_TIMEOUT, 10}}
# Interval between source eviction checks (in seconds).
source_eviction_interval: ${oc.decode:${oc.env:SOURCE_EVICTION_INTERVAL, 1}}
# Size of the source blacklist.
blacklist_size: ${oc.decode:${oc.env:SOURCE_BLACKLIST_SIZE, 1024}}
# TTL of the source blacklist in seconds.
blacklist_ttl: ${oc.decode:${oc.env:SOURCE_BLACKLIST_TTL, 10}}
# Length of the ingress queue in frames (0 - no limit, default 200).
ingress_queue_length: ${oc.decode:${oc.env:INGRESS_QUEUE_LENGTH, null}}
# Size of the ingress queue in bytes (0 - no limit, default 10485760).
ingress_queue_byte_size: ${oc.decode:${oc.env:INGRESS_QUEUE_BYTE_SIZE, null}}
# Length of the queue before decoder in frames (0 - no limit, default 5).
decoder_queue_length: ${oc.decode:${oc.env:DECODER_QUEUE_LENGTH, null}}
# Size of the queue before decoder in bytes (0 - no limit, default 10485760).
decoder_queue_byte_size: ${oc.decode:${oc.env:DECODER_QUEUE_BYTE_SIZE, null}}
# Send EOS on frame resolution change for JPEG and PNG codecs (default true).
eos_on_frame_resolution_change: ${oc.decode:${oc.env:EOS_ON_FRAME_RESOLUTION_CHANGE, null}}
You can override only required parameters in your module YAML configuration file. Also, take a look at corresponding environment variables helping to configure the parameters without specifying them in the module config.