This section describes the internal message-processing model of syslog-ng, as well as
the flow-control feature that can prevent message losses. To use flow-control, the
flow-control flag must be enabled for the particular log
path.
The syslog-ng application monitors (polls) the sources defined in its configuration file, periodically checking each source for messages. When a log message is found in one of the sources, syslog-ng polls every source and reads the available messages. These messages are processed and put into the output buffer of syslog-ng (also called fifo). From the output buffer, the operating system sends the messages to the appropriate destinations.
In large-traffic environments many messages can arrive during a single poll loop,
therefore syslog-ng reads only a fixed number of messages from each source. The
log_fetch_limit() option specifies the number of messages
read during a poll loop from a single source.
![]() |
Note |
|---|---|
The |
Every destination has its own output buffer. The output buffer is needed because the
destination might not be able to accept all messages immediately. The
log_fifo_size() parameter sets the size of the output buffer.
The output buffer must be larger than the log_fetch_limit() of
the sources, to ensure that every message read during the poll loop fits into the output
buffer. If the log path sends messages to a destination from multiple sources, the
output buffer must be large enough to store the incoming messages of every source.
TCP and unix-stream sources can receive the logs from several incoming connections
(e.g., many different clients or applications). For such sources, syslog-ng reads
messages from every connection, thus the log_fetch_limit()
parameter applies individually to every connection of the source.
The flow-control of syslog-ng introduces a control window to the source that tracks
how many messages can syslog-ng accept from the source. Every message that syslog-ng
reads from the source lowers the window size by one; every message that syslog-ng
successfully sends from the output buffer increases the window size by one. If the
window is full (i.e., its size decreases to zero), syslog-ng stops reading messages from
the source. The initial size of the control window is by default
100: the log_fifo_size() must be larger
than this value in order for flow-control to have any effect. If a source accepts
messages from multiple connections, all messages use the same control window.
When flow-control is used, every source has its own control window. As a worst-case
situation, the output buffer of the destination must be set to accommodate all messages
of every control window, that is, the log_fifo_size() of the
destination must be greater than
number_of_sources*log_iw_size(). This
applies to every source that sends logs to the particular destination. Thus if two
sources having several connections and heavy traffic send logs to the same destination,
the control window of both sources must fit into the output buffer of the destination.
Otherwise, syslog-ng does not activate the flow-control, and messages may be lost.
![]() |
Note |
|---|---|
Flow-control can be used together with the disk-based buffering feature of syslog-ng PE. See Section 2.14, “Using disk-based buffering” for details. |
© 2007-2010 BalaBit IT Security
Please send your comments or documentation bugs to: documentation@balabit.com