public class

SocketAppender

extends AppenderSkeleton
java.lang.Object
   ↳ org.apache.log4j.AppenderSkeleton
     ↳ org.apache.log4j.net.SocketAppender

Class Overview

Sends LoggingEvent objects to a remote a log server, usually a SocketNode.

The SocketAppender has the following properties:

  • If sent to a SocketNode, 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. They ship a serialized LoggingEvent object to the server side.

  • 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.

    On the other hand, if the network link is up, but the server is down, the client will not be blocked when making log requests but the log events will be lost due to server unavailability.

  • Even if a SocketAppender is no longer attached to any category, it will not be garbage collected in the presence of a connector thread. A connector thread exists only if the connection to the server is down. To avoid this garbage collection problem, you should close() the the SocketAppender explicitly. See also next item.

    Long lived applications which create/destroy many SocketAppender instances should be aware of this garbage collection problem. Most other applications can safely ignore it.

  • If the JVM hosting the SocketAppender exits before the SocketAppender is closed either explicitly or subsequent to garbage collection, then there might be untransmitted data in the pipe which might be lost. This is a common problem on Windows based systems.

    To avoid lost data, it is usually sufficient to close() the SocketAppender either explicitly or by calling the shutdown() method before exiting the application.

Summary

Constants
int DEFAULT_PORT The default port number of remote logging server (4560).
String ZONE The MulticastDNS zone advertised by a SocketAppender
[Expand]
Inherited Fields
From class org.apache.log4j.AppenderSkeleton
Public Constructors
SocketAppender()
SocketAppender(InetAddress address, int port)
Connects to remote server at address and port.
SocketAppender(String host, int port)
Connects to remote server at host and port.
Public Methods
void activateOptions()
Connect to the specified RemoteHost and Port.
void append(LoggingEvent event)
Subclasses of AppenderSkeleton should implement this method to perform actual logging.
void cleanUp()
Drop the connection to the remote host and release the underlying connector thread if it has been created
synchronized void close()
Close this appender.
String getApplication()
Returns value of the Application option.
boolean getLocationInfo()
Returns value of the LocationInfo option.
int getPort()
Returns value of the Port option.
int getReconnectionDelay()
Returns value of the ReconnectionDelay option.
String getRemoteHost()
Returns value of the RemoteHost option.
boolean isAdvertiseViaMulticastDNS()
boolean requiresLayout()
The SocketAppender does not use a layout.
void setAdvertiseViaMulticastDNS(boolean advertiseViaMulticastDNS)
void setApplication(String lapp)
The App option takes a string value which should be the name of the application getting logged.
void setLocationInfo(boolean locationInfo)
The LocationInfo option takes a boolean value.
void setPort(int port)
The Port option takes a positive integer representing the port where the server is waiting for connections.
void setReconnectionDelay(int delay)
The ReconnectionDelay option takes a positive integer representing the number of milliseconds to wait between each failed connection attempt to the server.
void setRemoteHost(String host)
The RemoteHost option takes a string value which should be the host name of the server where a SocketNode is running.
[Expand]
Inherited Methods
From class org.apache.log4j.AppenderSkeleton
From class java.lang.Object
From interface org.apache.log4j.Appender
From interface org.apache.log4j.spi.OptionHandler

Constants

public static final int DEFAULT_PORT

The default port number of remote logging server (4560).

Constant Value: 4560 (0x000011d0)

public static final String ZONE

The MulticastDNS zone advertised by a SocketAppender

Constant Value: "_log4j_obj_tcpconnect_appender.local."

Public Constructors

public SocketAppender ()

public SocketAppender (InetAddress address, int port)

Connects to remote server at address and port.

public SocketAppender (String host, int port)

Connects to remote server at host and port.

Public Methods

public void activateOptions ()

Connect to the specified RemoteHost and Port.

public void append (LoggingEvent event)

Subclasses of AppenderSkeleton should implement this method to perform actual logging. See also AppenderSkeleton.doAppend method.

public void cleanUp ()

Drop the connection to the remote host and release the underlying connector thread if it has been created

public synchronized void close ()

Close this appender.

This will mark the appender as closed and call then cleanUp() method.

public String getApplication ()

Returns value of the Application option.

public boolean getLocationInfo ()

Returns value of the LocationInfo option.

public int getPort ()

Returns value of the Port option.

public int getReconnectionDelay ()

Returns value of the ReconnectionDelay option.

public String getRemoteHost ()

Returns value of the RemoteHost option.

public boolean isAdvertiseViaMulticastDNS ()

public boolean requiresLayout ()

The SocketAppender does not use a layout. Hence, this method returns false.

public void setAdvertiseViaMulticastDNS (boolean advertiseViaMulticastDNS)

public void setApplication (String lapp)

The App option takes a string value which should be the name of the application getting logged. If property was already set (via system property), don't set here.

public void setLocationInfo (boolean locationInfo)

The LocationInfo option takes a boolean value. If true, the information sent to the remote host will include location information. By default no location information is sent to the server.

public void setPort (int port)

The Port option takes a positive integer representing the port where the server is waiting for connections.

public void setReconnectionDelay (int delay)

The ReconnectionDelay option takes a positive integer representing the number of milliseconds to wait between each failed connection attempt to the server. The default value of this option is 30000 which corresponds to 30 seconds.

Setting this option to zero turns off reconnection capability.

public void setRemoteHost (String host)

The RemoteHost option takes a string value which should be the host name of the server where a SocketNode is running.