log4cplus
2.1.0
|
Sends spi::InternalLoggingEvent objects to a remote a log server. More...
#include <socketappender.h>
Public Member Functions | |
SocketAppender (const log4cplus::tstring &host, unsigned short port, const log4cplus::tstring &serverName=tstring(), bool ipv6=false) | |
SocketAppender (const log4cplus::helpers::Properties &properties) | |
~SocketAppender () | |
virtual void | close () |
Release any resources allocated within the appender such as file handles, network connections, etc. More... | |
Public Member Functions inherited from log4cplus::Appender | |
Appender () | |
Appender (const log4cplus::helpers::Properties &properties) | |
virtual | ~Appender () |
void | destructorImpl () |
This function is for derived appenders to call from their destructors. More... | |
bool | isClosed () const |
Check if this appender is in closed state. More... | |
void | syncDoAppend (const log4cplus::spi::InternalLoggingEvent &event) |
This method performs threshold checks and invokes filters before delegating actual logging to the subclasses specific {} method. More... | |
void | asyncDoAppend (const log4cplus::spi::InternalLoggingEvent &event) |
This method performs book keeping related to asynchronous logging and executes syncDoAppend() to do the actual logging. More... | |
void | doAppend (const log4cplus::spi::InternalLoggingEvent &event) |
This function checks async flag. More... | |
virtual log4cplus::tstring | getName () |
Get the name of this appender. More... | |
virtual void | setName (const log4cplus::tstring &name) |
Set the name of this appender. More... | |
virtual void | setErrorHandler (std::unique_ptr< ErrorHandler > eh) |
Set the ErrorHandler for this Appender. More... | |
virtual ErrorHandler * | getErrorHandler () |
Return the currently set ErrorHandler for this Appender. More... | |
virtual void | setLayout (std::unique_ptr< Layout > layout) |
Set the layout for this appender. More... | |
virtual Layout * | getLayout () |
Returns the layout of this appender. More... | |
void | setFilter (log4cplus::spi::FilterPtr f) |
Set the filter chain on this Appender. More... | |
log4cplus::spi::FilterPtr | getFilter () const |
Get the filter chain on this Appender. More... | |
void | addFilter (log4cplus::spi::FilterPtr f) |
Add filter at the end of the filters chain. More... | |
void | addFilter (std::function< spi::FilterResult(const log4cplus::spi::InternalLoggingEvent &)>) |
Add filter at the end of the filters chain. More... | |
LogLevel | getThreshold () const |
Returns this appenders threshold LogLevel. More... | |
void | setThreshold (LogLevel th) |
Set the threshold LogLevel. More... | |
bool | isAsSevereAsThreshold (LogLevel ll) const |
Check whether the message LogLevel is below the appender's threshold. More... | |
void | waitToFinishAsyncLogging () |
This method waits for all events that are being asynchronously logged to finish. More... | |
Public Member Functions inherited from log4cplus::helpers::SharedObject | |
void | addReference () const LOG4CPLUS_NOEXCEPT |
void | removeReference () const |
Protected Attributes | |
log4cplus::helpers::Socket | socket |
log4cplus::tstring | host |
unsigned int | port |
log4cplus::tstring | serverName |
bool | ipv6 = false |
volatile bool | connected |
helpers::SharedObjectPtr< helpers::ConnectorThread > | connector |
Protected Attributes inherited from log4cplus::Appender | |
std::unique_ptr< Layout > | layout |
The layout variable does not need to be set if the appender implementation has its own layout. More... | |
log4cplus::tstring | name |
Appenders are named. More... | |
LogLevel | threshold |
There is no LogLevel threshold filtering by default. More... | |
log4cplus::spi::FilterPtr | filter |
The first filter in the filter chain. More... | |
std::unique_ptr< ErrorHandler > | errorHandler |
It is assumed and enforced that errorHandler is never null. More... | |
std::unique_ptr< helpers::LockFile > | lockFile |
Optional system wide synchronization lock. More... | |
bool | useLockFile |
Use lock file for inter-process synchronization of access to log file. More... | |
bool | async |
Asynchronous append. More... | |
std::atomic< std::size_t > | in_flight |
std::mutex | in_flight_mutex |
std::condition_variable | in_flight_condition |
bool | closed |
Is this appender closed? More... | |
Additional Inherited Members | |
Public Attributes inherited from log4cplus::helpers::SharedObject | |
thread::Mutex | access_mutex |
Sends spi::InternalLoggingEvent objects to a remote a log server.
The SocketAppender has the following properties:
Remote logging is non-intrusive as far as the log event is concerned. In other words, the event will be logged with the same time stamp, NDC, location info as if it were logged locally by the client.
SocketAppenders do not use a layout.
Remote logging uses the TCP protocol. Consequently, if the server is reachable, then log events will eventually arrive at the server.
If the remote server is down, the logging requests are simply dropped. However, if and when the server comes back up, then event transmission is resumed transparently. This transparent reconneciton is performed by a connector thread which periodically attempts to connect to the server.
Logging events are automatically buffered by the native TCP implementation. This means that if the link to server is slow but still faster than the rate of (log) event production by the client, the client will not be affected by the slow network connection. However, if the network connection is slower then the rate of event production, then the client can only progress at the network rate. In particular, if the network link to the the server is down, the client will be blocked.
host
Remote host name to connect and send events to.
port
Port on remote host to send events to.
ServerName
Host name of event's origin prepended to each event.
IPv6
Boolean value specifying whether to use IPv6 (true) or IPv4 (false). Default value is false.
Definition at line 105 of file socketappender.h.
log4cplus::SocketAppender::SocketAppender | ( | const log4cplus::tstring & | host, |
unsigned short | port, | ||
const log4cplus::tstring & | serverName = tstring() , |
||
bool | ipv6 = false |
||
) |
log4cplus::SocketAppender::SocketAppender | ( | const log4cplus::helpers::Properties & | properties | ) |
log4cplus::SocketAppender::~SocketAppender | ( | ) |
|
protectedvirtual |
Subclasses of Appender
should implement this method to perform actual logging.
Implements log4cplus::Appender.
|
virtual |
Release any resources allocated within the appender such as file handles, network connections, etc.
It is a programming error to append to a closed appender.
Implements log4cplus::Appender.
|
protectedvirtual |
Implements log4cplus::helpers::IConnectorThreadClient.
|
protectedvirtual |
Implements log4cplus::helpers::IConnectorThreadClient.
|
protectedvirtual |
Implements log4cplus::helpers::IConnectorThreadClient.
|
protectedvirtual |
Sets connected flag to true in ConnectorThread's client.
Implements log4cplus::helpers::IConnectorThreadClient.
|
protected |
|
protected |
|
protected |
Definition at line 142 of file socketappender.h.
|
protected |
Definition at line 143 of file socketappender.h.
|
protected |
Definition at line 131 of file socketappender.h.
|
protected |
Definition at line 134 of file socketappender.h.
|
protected |
Definition at line 132 of file socketappender.h.
|
protected |
Definition at line 133 of file socketappender.h.
|
protected |
Definition at line 130 of file socketappender.h.