You can monitor your server’s activity in several different ways. This chapter discusses how to monitor your server by recording and viewing log files. For information on using the built-performance monitoring services, quality of service features, or SNMP, see Chapter 12, Monitoring Servers.
This chapter contains the following sections:
Server log files record your server’s activity. You can use these logs to monitor your server and to troubleshoot problems. The error log file, located in the https-server_name/logs/errors directory in the server root directory, lists all the errors encountered by the server. The access log, located in https-server_name/logs/access in the server root directory, records requests to the server and responses from the server. You can configure the information recorded in the Sun Java System Web Server access log file. Use the log analyzer to generate server statistics. Back up server error and access log files by archiving them.
Due to limitations in the operating system, the Sun Java System Web Server does not work with log files larger than 2GB on Linux. When the maximum file size is reached, logging stpos.
This section discusses how log files are created. The section includes the following topics:
On both the UNIX and Windows platforms, logs from the administration server are collected in the administration server https-admserve/logs/ directory. Logs from server instances are collected in the https-server_name/logs/ directory.
You can set the default log level for the entire server. Redirect the stdout and the stderr to the server’s event log and direct the log output to the operating system’s system log. Additionally, you can direct the stdout and the stderr content to the server’s event log. Log messages by default are sent to stderr in addition to the specified server log file.
Another feature available is to log the virtual server ID with the log message. This is a useful feature when multiple virtual servers are used to log messages to the same log file. You can choose to write the log messages to system log. When you do so, logging is not performed on the error log file. Instead the syslog logging service on UNIX, or the system logging service on Windows platform is used to produce and manage logs.
You can also use the server.xml attributes to control the contents of this file. For details on the server.xml file, see the Sun Java System Web Server 6.1 SP12 Administrator’s Configuration File Reference.
For stable operational environments where centralized logging is required syslog is appropriate. For environments where log output is frequently required for diagnostics and debugging, individual server instance or virtual server logs may be more manageable.
All logged data for the server instance and administration server in one file may prove difficult to read and debug. It is recommended that you use the syslog master log file only for deployed applications that are running smoothly.
Logged message are intermixed with all other logs from the Solaris daemon applications.
By using the syslog log file, in conjunction with the syslogd, and the system log daemon, you can configure the syslog.conf file to:
Log messages to the appropriate system log
Write messages to the system console
Forward logged messages to a list of users, or forward logged messages to another the syslogd on another host over the network
Since logging to the syslog means, logs from Sun Java System Web Server, and other daemon applications are collected in the same file, logged messages are enhanced with the following information to identify Sun Java System Web Server-specific messages from the particular server or virtual server instance:
Unique message ID
Timestamp
Instancename
Program name (webservd or webserv-wdog)
Process ID (PID of the webserv process)
Thread ID (optional)
Server ID
The LOG element can be configured for both the administration server and the server instance in the server.xml file.
For more information on the syslog logging mechanism used in the UNIX operating environment, use the following man commands at a terminal prompt:
man syslog man syslogd man syslog.conf
For more information on the event log mechanism used in the Windows operating environment, refer to the Windows help system index for the keywords Event Logging.
The following table defines the log levels and messages in the Sun Java System Web Server, in increasing order of severity.
Table 10–1 Log Levels| Log level | Description | 
|---|---|
| finest finer fine | Messages indicate extent of verbosity of debug messages. finest gives the maximum verbosity. | 
| info | Messages are informative in nature, usually related to server configuration or server status. These messages do not indicate errors that need immediate action. | 
| warning | Messages indicate a warning. The message would probably be accompanied by an exception. | 
| failure | Messages indicate a failure of considerable importance that can prevent normal application execution. | 
| config | Messages indicate a misconfiguration. | 
| security | Messages indicate a security issue. | 
| catastrophe | Messages indicate a fatal error. | 
The Sun Java System Web Server can have virtual server instances. Each virtual server within a Sun Java System Web Server instance has its own identity and may have its own log file. The use of separate log files for each virtual server can help track server activity for particular transactions and resources.
You can also direct logged messages from multiple virtual servers to one server log file. When so doing, you may wish to enable the logvsid in the LOG element of the server.xml file. This helps users to distinguish log messages originating from different virtual servers.
<SERVER> ... <LOG file="/export//https-iws-files2.red.iplanet.com/logs/errors" loglevel="finest" logtoconsole="true" usesyslog="false" createconsole="false" logstderr="true" logstdout="true" logvsid="true"> </SERVER>
In this example, the <LOG logvsid="true"> is responsible for including the virtual server ID in every log message. This allows you to differentiate between messages from different virtual servers. The absence of attribute errorlog in the VS element, causes all the virtual servers to log messages to a single file.
For developers, it is important for the application logs and server logs to be made readily available during unit testing for Web application components and J2SE applications. On the Windows platform, developers prefer to see log messages displayed in a command window on the desktop. On the UNIX platform, many developers are comfortable with simply having the log messages stream to stderr in the terminal window in which the server instance is started, or, use the tail -f command to see the log messages written in log files.
The server.xml file contains attributes that can be set for the stdout and the stderr to direct logged messages to a log file or to the terminal window, and so forth. For more information on the use of stdout and stderr, see the Sun Java System Web Server 6.1 SP12 Administrator’s Configuration File Reference.
You can set up your access and error log files to be automatically archived. At a certain time, or after a specified interval, your logs are rotated. The Sun Java System Web Server saves the old log files and stamps the saved file with a name that includes the date and time they were saved.
For example, you can set up your access log files to rotate every hour, and Sun Java System Web Server saves and names the file “access.200307152400,” where name of the log file, year, month, day, and 24-hour time is concatenated together into a single character string. The exact format of the log archive file varies depending upon which type of log rotation you set up.
The Sun Java System Web Server offers the two types of log rotation for archiving files: Internal-daemon log rotation and Cron-based log rotation.
This type of log rotation happens within the HTTP daemon, and can only be configured at system startup. Internal daemon log rotation process allows the server to rotate logs internally without requiring the server to restart. Logs rotated using this method are saved in the following format:
access.<YYYY><MM><DD><HHMM> error. <YYYY><MM><DD><HHMM>
Specify the time used as a basis to rotate log files and start a new log file. For example, if the rotation start time is 12:00 a.m., and the rotation interval is 1440 minutes (one day), a new log file is created immediately when you save and apply changes irrespective of the present time. The log file will rotate every day at 12:00 a.m., and the access log will be stamped at 12:00 a.m. and saved as access.200307152400. Similarly, if you set the interval at 240 minutes (4 hours), the 4 hour intervals begin at 12:00 a.m., and the access log files contain information collected from 12:00 a.m. to 4:00 a.m., from 4:00 a.m. to 8:00 a.m.
If log rotation is enabled, log file rotation starts at server startup. The first log file to be rotated gathers information from the current time until the next rotation time. Using the previous example, if you set your start time at 12:00 a.m. and your rotation interval at 240 minutes, and the current time is 6:00 a.m., the first log file to be rotated will contain the information collected from 6:00 a.m. to 8:00 a.m, and the next log file will contain information from 8:00 a.m. to 12:00 p.m. (noon).
This type of log rotation is based on the time stored in the scheduler.conf file in the server_root/https-admserv/config/ directory. This method allows you to archive log files immediately or have the server archive log files at a specific time on specific days. The server’s scheduler configuration options are stored in the schedulerd.conf file in the server_root/https-admserv/config/ directory. Logs rotated using the scheduler-based method are saved in the following format:
<original_filename>.<YYYY><MM><DD><HHMM>
For example, access might become access.200307151630 when it is rotated at 4:30 p.m.
Log rotation is initialized at server startup. If rotation is turned on, the Sun Java System Web Server creates a time-stamped access log file and rotation starts at server startup.
Once the rotation begins, the Sun Java System Web Server creates a new time stamped log file when there is a request or error that needs to be logged to the access or error log file and it occurs after the prior-scheduled “next rotate time”.
Archive the server logs before running the log analyzer.
To archive log files and to specify whether to use the Internal daemon method or the scheduler-based method, use the Archive Log Files Page in the Server Manager.
During installation, the accesslog file is created for the server. You can customize access logging for any resource by specifying whether or not to log accesses, the format to use for logging, and whether or not the server should spend time looking up the domain names of clients when they access a resource.
To add %vsid% to the log file format string:
 To add the %vsid% to the log file
format string
To add the %vsid% to the log file
format stringAccess the Server Manager and choose the Logs tab.
Click the Access Log Preferences link.
Enter a new log file location and filename in the Log File: text box.
Click the Only Log: radio button.
Click the Virtual Server Id check box. Alternately click the Custom Format: radio button and add the string ”%vsid%.
When adding the custom format string ”%vsid%, you must use a new access log file.
When changing the format of an existing log file, you should first delete/rename the existing log file OR use a different file name.
Server access logs can be in Common Logfile Format, flexible log format, or your own customizable format. The Common Logfile Format is a commonly supported format that provides a fixed amount of information about the server. The flexible log format allows you to choose (from Sun Java System Web Server) what to log. A customizable format uses parameter blocks that you specify to control what gets logged. For a list of customizable format parameters, see the Sun Java System Web Server 6.1 SP12 NSAPI Programmer’s Guide.
Once an access log for a resource has been created, you cannot change its format unless you archive it or create a new access log file for the resource.
You can specify logging preferences using the Access Log Preferences page in the Server Manager, or you can manually configure the following directives in the obj.conf file. In the magnus.conf file, the server calls the flex-init function to initialize the flexible logging system and the flex-log function to record request-specific data in a flexible log format. To log requests using the common log file format, the server calls init-clf to initialize the Common Log subsystem which is used in the obj.conf, and the common-log to record request-specific data in the common log format (used by most HTTP servers).
For more information on the NSAPI logging functions, including valid directives and parameters, see the Sun Java System Web Server 6.1 SP12 NSAPI Programmer’s Guide.
The Sun Java System Web Server has an easy way to log a specific cookie using the flexlog facility. Add Req->headers.cookie.cookie_name to the Init fn=flex-init line in the magnus.conf file. This logs the value of the cookie variable cookie_name if the cookie variable is present in the request header, and logs - if it is not present.
Init fn=flex-init format.access="%Ses->client.ip% - %Req->vars.auth-user% [%SYSDATE%] \"%Req->reqpb.clf-request%\" %Req->srvhdrs.clf-status% %Req->srvhdrs.content-length% %Req->headers.cookie.jsessionid%""
All cookie names and header names must be in lowercase.
The Sun Java System Web Server 6.1 allows you to configure the information to be logged in the server’s errors logs.
Access the Administration Server.
Select the Preferences tab.
Click the Access Logging Options link.
Enter the required information.
Click OK and then Apply to save and apply the changes.
Access the server instance.
Select the Logs tab.
Click the Error Log Preferences link.
Enter the required information.
Click OK and then Apply to save and apply the changes.
The following table describes the attributes for the LOG element you can configure in the server.xml file:
Table 10–2 LOG attributes| Attribute | Default | Description | 
|---|---|---|
| file | errors | Specifies the file that stores messages from the default virtual server. Messages from other configured virtual servers are also stored here, unless the errorlog attribute is explicitly specified in the VS element. | 
| loglevel | info | Controls the default type of messages logged by other elements to the error log. Allowed values are as follows, from highest to lowest: finest, fine, fine, info, warning, failure, config, security, and catastrophe. | 
| logvsid | false | (Optional) If true, virtual server IDs are displayed in the virtual server logs. These are useful if multiple VS elements share the same log file. Note that in Sun Java System Web Server 6.1 the logvsid element cannot be configured in the magnus.conf file. | 
| logstdout | true | (Optional) If true, redirects stdout output to the errors log. Legal values are on, off, yes, no, 1, 0, true, false. | 
| logstderr | true | (Optional) If true, redirects the stderr output to the errors log. Legal values are on, off, yes, no, 1, 0, true, false. | 
| logtoconsole | true | (Optional, UNIX only) If true, redirects log messages to the console. | 
| createconsole | false | (Optional, Windows only) If true, creates a Windows console for the stderr output. Legal values are on, off, yes, no, 1, 0, true, false. | 
| usesyslog | false | (Optional) If true, uses the UNIX syslog service or Windows Event Logging to produce and manage logs. Legal values are on, off, yes, no, 1, 0, true, false. | 
You can view a server’s active and archived access log files.
To view the Administration Server’s access log from the Administration Server, choose the Preferences tab, and then choose the View Access Log Page .
To view an access log for the server instance from the Server Manager, choose the Logs tab, and then choose the View Access Log Page.
To view an access log for an individual virtual server from the Class Manager, select a virtual server to manage from the highlighted Manage Virtual Servers page, then click the link under the heading Access Log on the Virtual Server Manager page. You can specify the number of entries to view or entries with a conditional qualifier of your choice.
The following is an example of an access log in the Common Logfile Format (you specify the format in the Log Preferences window; see Setting Access Log Preferences for more information):
wiley.a.com - - [16/Feb/2001:21:18:26 -0800] “GET / HTTP/1.0” 200 751 wiley.a.com - - [17/Feb/2001:1:04:38 -0800] “GET /docs/grafx/icon.gif HTTP/1.0” 204 342 wiley.a.com - - [20/Feb/2001:4:36:53 -0800] “GET /help HTTP/1.0” 401 571 arrow.a.com - john [29/Mar/2001:4:36:53 -0800] “GET /help HTTP/1.0” 401 571
Viewing an Access Log File describes the last line of this sample access log.
Table 10–3 The fields in the last line of the sample access log file| Access Log Field | Example | 
|---|---|
| Hostname or IP address of client | arrow.a.com. (In this case, the hostname is shown because the web server’s setting for DNS lookups is enabled; if DNS lookups were disabled, the client’s IP address would appear. | 
| RFC 931 information | - (RFC 931 identity not implemented) | 
| Username | john (username entered by the client for authentication) | 
| Date/time of request | 29/Mar/1999:4:36:53 -0800 | 
| Request | GET /help | 
| Protocol | HTTP/1.0 | 
| Status code | 401 | 
| Bytes transferred | 571 | 
The following is an example of an access log using the flexible logging format (you specify the format in the Log Preferences page, see Setting Access Log Preferences for more information):
wiley.a.com - - [25/Mar/2001:12:55:26 -0800] "GET /index.htm HTTP/1.0" "GET" "/?-" "HTTP/ 1.0" 304 0 - Mozilla/2.0 (WinNT; I) wiley.a.com - - [25/Mar/2001:12:55:26 -0800] "GET / HTTP/1.0" "GET" "/?-" "HTTP/1.0" 304 0 - Mozilla/2.0 (WinNT; I) wiley.a.com - - [25/Mar/2001:12:55:26 -0800] "GET / HTTP/1.0" "GET" "/?-" "HTTP/1.0" 304 0 - Mozilla/2.0 (X11; I; IRIX 5.3 IP22)
The error log file contains errors that the server has encountered since the log file was created. It also contains information about the server, such as when the server was started. Unsuccessful user authentication is also recorded in the error log. Use the error log to find broken URL paths or missing files.
To view the Administration Server’s error log file, from the Administration Server, choose the Preferences tab, and choose the View Error Log Page.
To view a server instance’s error log file, from the Server Manager, choose the Logs tab, and choose the View Error Log Page.
To view an error log for an individual virtual server, from the Class Manager, select a virtual server to manage from the highlighted Manage Virtual Servers page, then click the link under the heading Error Log on the Virtual Server Manager page. You can specify the number of entries to view or entries with a conditional qualifier of your choice.
The following are two examples of entries in the error log; the first example shows an informational message indicating successful start up of the server, the second example indicates that the client wiley.a.com requested the file report.html, but the file wasn’t in the primary document directory on the server.
[[22/Jan/2001:14:31:41] info (39700): successful server startup [22/Jan/2001:14:31:41] info (39700): SunJava System-WebServer/6.1 BB1-01/22/2001 01:45 [22/Jan/2001:14:31:42] warning (13751): for host wiley.a.com trying to GET /report.html, send-file reports: can’t find /usr1/irenem/ES60-0424/docs/report.html (File not found)
The server-root/extras/log_anly directory contains the log analysis tool that runs through the Server Manager user interface. This log analyzer analyzes files in common log format only. The HTML document in the log_anly directory that explains the tool’s parameters. The server-root/extras/flex_anlg directory contains the command-line log analyzer for the flexible log file format. However, the Server Manager defaults to using the flexible log file reporting tool, regardless of whether you’ve selected common or flexible log file format.
Use the log analyzer to generate statistics about your default server, such as a summary of activity, most commonly accessed URLs and the server is accessed most frequently. You can run the log analyzer from the Sun Java System Web Server or the command line. The log analyzer cannot generate statistics for virtual servers other than the default server. However, statistics can be viewed for each virtual server as described in Viewing an Access Log File.
You must set the library path before attempting to run the flexanlg command line utility. The settings for various platforms are as follows:
Solaris and Linux:
LD_LIBRARY_PATH=server_root/bin/https/lib:$LD_LIBRARY_PATH
AIX:
LIBPATH=server_root/bin/https/lib:$LIBPATH
HP-UX:
SHLIB_PATH=server_root/bin/https/lib:$SHLIB_PATH
Windows:
path=server_root\bin\https\bin;%path%
Before running the log analyzer, you should archive the server logs. For more information about archiving server logs, see Archiving Log Files.
To run the log analyzer from the Server Manager, perform the follow these steps:
 To run the log analyzer from the Server Manager
To run the log analyzer from the Server ManagerClick Generate Report.
Fill in the fields.
Click OK.
The report appears in a new window.
For more information, see the Generate Report page in the online help.
To analyze access log files from the command line, run the flexanlg tool, which is in the server-install/extras/flex_anlg directory.
To run the flexanlg, type the following command at the command prompt:
flexanlg [ -P ] [-n name] [-x] [-r] [-p order] [-i file]* [ -m metafile ]* [ o file][ c opts] [-t opts] [-l opts]
The following output describes the syntax.
| flexanlg -h.):
-P: proxy log format                                  Default: no
-n servername: The name of the server
-x : Output in HTML                                   Default: no
-r : Resolve IP addresses to hostnames                Default: no
-p [c,t,l]: Output order (counts, time stats, lists)  Default: ctl
-i filename: Input log file(s)                        Default: none
-o filename: Output log file                          Default: stdout
-m filename: Meta file(s)                             Default: none
-c [h,n,r,f,e,u,o,k,c,z]: Count these item(s) -       Default: hnreuokc
    h: total hits
    n: 304 Not Modified status codes (Use Local Copy)
    r: 302 Found status codes (Redirects)
    f: 404 Not Found status codes (Document Not Found)
    e: 500 Server Error status codes (Misconfiguration)
    u: total unique URL’s
    o: total unique hosts
    k: total kilobytes transferred
    c: total kilobytes saved by caches
    z: Do not count any items.
-t [sx,mx,hx, xx,z]: Find general stats - Default:s5m5h24x10
    s(number): Find top (number) seconds of log
    m(number): Find top (number) minutes of log
    h(number): Find top (number) hours of log
    u(number): Find top (number) users of log
    a(number): Find top (number) user agents of log
    r(number): Find top (number) referers of log
    x(number): Find top (number) for miscellaneous keywords
    z: Do not find any general stats.
-l [cx,hx]: Make a list of - Default: c+3h5
    c(x,+x): Most commonly accessed URLs
             (x: Only list x entries)
             (+x: Only list if accessed more than x times)
    h(x,+x): Hosts (or IP addresses) most often accessing your server
             (x: Only list x entries)
             (+x: Only list if accessed more than x times)
    z: Do not make any lists
                | 
In addition to logging errors to the server error log (see Viewing the Error Log File), the Sun Java System Web Server logs severe system errors to the Event Viewer. The Event Viewer lets you monitor events on your system. Use the Event Viewer to see errors resulting from fundamental configuration problems, which can occur before the error log is opened.
To use the Event Viewer, perform the following steps:
 To use the Event Viewer
To use the Event ViewerFrom the Start menu, select Programs and then Administrative Tools. Choose Event Viewer in the Administrative Tools program group.
Choose Application from the Log menu.
The Application log appears in the Event Viewer. Errors from Sun Java System Web Server has a source label of https-serverid or WebServer6.1.
Choose Find from the View menu to search for one of these labels in the log. Choose Refresh from the View menu to see updated log entries.
For more information about the Event Viewer, consult your system documentation.