public class AccessLogValve extends AbstractAccessLogValve
AbstractAccessLogValve that
 outputs the access log to a file. The features of this implementation
 include:
 
 For UNIX users, another field called checkExists is also
 available. If set to true, the log file's existence will be checked before
 each logging. This way an external log rotator can move the file
 somewhere and Tomcat will start with a new file.
 
 For JMX junkies, a public method called rotate has
 been made available to allow you to tell this instance to move
 the existing log file to somewhere else and start writing a new log file.
 
AbstractAccessLogValve.AccessLogElement, AbstractAccessLogValve.ByteSentElement, AbstractAccessLogValve.CachedElement, AbstractAccessLogValve.ConnectionStatusElement, AbstractAccessLogValve.CookieElement, AbstractAccessLogValve.DateAndTimeElement, AbstractAccessLogValve.DateFormatCache, AbstractAccessLogValve.ElapsedTimeElement, AbstractAccessLogValve.FirstByteTimeElement, AbstractAccessLogValve.HeaderElement, AbstractAccessLogValve.HostElement, AbstractAccessLogValve.HttpStatusCodeElement, AbstractAccessLogValve.LocalAddrElement, AbstractAccessLogValve.LocalServerNameElement, AbstractAccessLogValve.LogicalUserNameElement, AbstractAccessLogValve.MethodElement, AbstractAccessLogValve.PortElement, AbstractAccessLogValve.ProtocolElement, AbstractAccessLogValve.QueryElement, AbstractAccessLogValve.RemoteAddrElement, AbstractAccessLogValve.RequestAttributeElement, AbstractAccessLogValve.RequestElement, AbstractAccessLogValve.RequestURIElement, AbstractAccessLogValve.ResponseHeaderElement, AbstractAccessLogValve.SessionAttributeElement, AbstractAccessLogValve.SessionIdElement, AbstractAccessLogValve.StringElement, AbstractAccessLogValve.ThreadNameElement, AbstractAccessLogValve.UserElementLifecycle.SingleUse| Modifier and Type | Field and Description | 
|---|---|
| protected File | currentLogFileThe current log file we are writing to. | 
| protected String | encodingCharacter set used by the log file. | 
| protected String | fileDateFormatDate format to place in log file name. | 
| protected SimpleDateFormat | fileDateFormatterA date formatter to format a Date using the format
 given by  fileDateFormat. | 
| protected String | prefixThe prefix that is added to log file filenames. | 
| protected boolean | renameOnRotateShould we defer inclusion of the date stamp in the file
 name until rotate time? | 
| protected boolean | rotatableShould we rotate our log file? | 
| protected String | suffixThe suffix that is added to log file filenames. | 
| protected PrintWriter | writerThe PrintWriter to which we are currently logging, if any. | 
cachedElements, condition, conditionIf, enabled, locale, localeName, logElements, pattern, requestAttributesEnabledasyncSupported, container, containerLog, next, smmserverPROTOCOL_ATTRIBUTE, REMOTE_ADDR_ATTRIBUTE, REMOTE_HOST_ATTRIBUTE, SERVER_NAME_ATTRIBUTE, SERVER_PORT_ATTRIBUTEAFTER_DESTROY_EVENT, AFTER_INIT_EVENT, AFTER_START_EVENT, AFTER_STOP_EVENT, BEFORE_DESTROY_EVENT, BEFORE_INIT_EVENT, BEFORE_START_EVENT, BEFORE_STOP_EVENT, CONFIGURE_START_EVENT, CONFIGURE_STOP_EVENT, PERIODIC_EVENT, START_EVENT, STOP_EVENT| Constructor and Description | 
|---|
| AccessLogValve() | 
| Modifier and Type | Method and Description | 
|---|---|
| void | backgroundProcess()Execute a periodic task, such as reloading, etc. | 
| String | getDirectory() | 
| String | getEncoding()Return the character set name that is used to write the log file. | 
| String | getFileDateFormat() | 
| int | getMaxDays() | 
| String | getPrefix() | 
| String | getSuffix() | 
| boolean | isBuffered()Is the logging buffered. | 
| boolean | isCheckExists()Check for file existence before logging. | 
| boolean | isRenameOnRotate()Should we defer inclusion of the date stamp in the file
 name until rotate time. | 
| boolean | isRotatable()Should we rotate the access log. | 
| void | log(CharArrayWriter message)Log the specified message to the log file, switching files if the date
 has changed since the previous log call. | 
| protected void | open()Open the new log file for the date specified by  dateStamp. | 
| void | rotate()Rotate the log file if necessary. | 
| boolean | rotate(String newFileName)Rename the existing log file to something else. | 
| void | setBuffered(boolean buffered)Set the value if the logging should be buffered | 
| void | setCheckExists(boolean checkExists)Set whether to check for log file existence before logging. | 
| void | setDirectory(String directory)Set the directory in which we create log files. | 
| void | setEncoding(String encoding)Set the character set that is used to write the log file. | 
| void | setFileDateFormat(String fileDateFormat)Set the date format date based log rotation. | 
| void | setMaxDays(int maxDays) | 
| void | setPrefix(String prefix)Set the log file prefix. | 
| void | setRenameOnRotate(boolean renameOnRotate)Set the value if we should defer inclusion of the date
 stamp in the file name until rotate time | 
| void | setRotatable(boolean rotatable)Configure whether the access log should be rotated. | 
| void | setSuffix(String suffix)Set the log file suffix. | 
| protected void | startInternal()Start this component and implement the requirements
 of  LifecycleBase.startInternal(). | 
| protected void | stopInternal()Stop this component and implement the requirements
 of  LifecycleBase.stopInternal(). | 
createAccessLogElement, createAccessLogElement, createLogElements, escapeAndAppend, findLocale, getCondition, getConditionIf, getConditionUnless, getEnabled, getIpv6Canonical, getLocale, getMaxLogMessageBufferSize, getPattern, getRequestAttributesEnabled, invoke, log, setCondition, setConditionIf, setConditionUnless, setEnabled, setIpv6Canonical, setLocale, setMaxLogMessageBufferSize, setPattern, setRequestAttributesEnabledgetContainer, getDomainInternal, getNext, getObjectNameKeyProperties, initInternal, isAsyncSupported, setAsyncSupported, setContainer, setNext, toStringdestroyInternal, getDomain, getObjectName, postDeregister, postRegister, preDeregister, preRegister, register, setDomain, unregister, unregisteraddLifecycleListener, destroy, findLifecycleListeners, fireLifecycleEvent, getState, getStateName, getThrowOnFailure, init, removeLifecycleListener, setState, setState, setThrowOnFailure, start, stopprotected volatile String prefix
protected boolean rotatable
protected boolean renameOnRotate
protected volatile String suffix
protected PrintWriter writer
protected SimpleDateFormat fileDateFormatter
fileDateFormat.protected File currentLogFile
protected String fileDateFormat
protected volatile String encoding
null, the
 system default character set will be used. An empty string will be
 treated as null when this property is assigned.public int getMaxDays()
public void setMaxDays(int maxDays)
public String getDirectory()
public void setDirectory(String directory)
directory - The new log file directorypublic boolean isCheckExists()
true if file existence is checked firstpublic void setCheckExists(boolean checkExists)
checkExists - true meaning to check for file existence.public String getPrefix()
public void setPrefix(String prefix)
prefix - The new log file prefixpublic boolean isRotatable()
true if the access log should be rotatedpublic void setRotatable(boolean rotatable)
rotatable - true if the log should be rotatedpublic boolean isRenameOnRotate()
true if the logs file names are time stamped
  only when they are rotatedpublic void setRenameOnRotate(boolean renameOnRotate)
renameOnRotate - true if defer inclusion of date stamppublic boolean isBuffered()
true if the logging uses a bufferpublic void setBuffered(boolean buffered)
buffered - true if buffered.public String getSuffix()
public void setSuffix(String suffix)
suffix - The new log file suffixpublic String getFileDateFormat()
public void setFileDateFormat(String fileDateFormat)
fileDateFormat - The format for the file timestamppublic String getEncoding()
null if the system default
  character set is used.public void setEncoding(String encoding)
encoding - The name of the character set.public void backgroundProcess()
backgroundProcess in interface ValvebackgroundProcess in class ValveBasepublic void rotate()
public boolean rotate(String newFileName)
newFileName - The file name to move the log file entry topublic void log(CharArrayWriter message)
log in class AbstractAccessLogValvemessage - Message to be loggedprotected void open()
dateStamp.protected void startInternal()
                      throws LifecycleException
LifecycleBase.startInternal().startInternal in class AbstractAccessLogValveLifecycleException - if this component detects a fatal error
  that prevents this component from being usedprotected void stopInternal()
                     throws LifecycleException
LifecycleBase.stopInternal().stopInternal in class AbstractAccessLogValveLifecycleException - if this component detects a fatal error
  that prevents this component from being usedCopyright © 2000-2021 Apache Software Foundation. All Rights Reserved.