org.apache.wicket.protocol.http.RequestLogger.java Source code

Java tutorial

Introduction

Here is the source code for org.apache.wicket.protocol.http.RequestLogger.java

Source

/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.apache.wicket.protocol.http;

import org.apache.wicket.request.ILoggableRequestHandler;
import org.apache.wicket.request.IRequestHandler;
import org.apache.wicket.util.lang.Classes;
import org.apache.wicket.util.string.AppendingStringBuffer;
import org.apache.wicket.util.string.Strings;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * This is the logger class that can be set in the
 * {@link org.apache.wicket.protocol.http.WebApplication#getRequestLogger()} method. If this class
 * is set all request and live sessions will be recorded and displayed From the total created
 * sessions, to the peak session count and the current live sessions. For the live sessions the
 * request logger will record what request are happening what kind of {@link IRequestHandler} was
 * the event target and what {@link IRequestHandler} was the response target. It also records what
 * session data was touched for this and how long the request did take.
 * 
 * To view this information live see org.apache.wicket.devutils.inspector.InspectorBug that shows
 * the org.apache.wicket.devutils.inspector.InspectorPage with the org.apache.wicket.devutils.inspector.LiveSessionsPage.
 * 
 * This implementation uses a rounded buffer for storing the request data, and strives to minimize
 * contention on accessing the rounded buffer. At the beginning of your application start, the
 * buffer is empty and fills up during the lifetime of the application until the window size has
 * been reached, and new requests are written to the position containing the oldest request.
 * 
 * @since 1.2
 */
public class RequestLogger extends AbstractRequestLogger {
    /** log, don't change this as it is often used to direct request logging to a different file. */
    private static final Logger LOG = LoggerFactory.getLogger(RequestLogger.class);

    @Override
    protected void log(RequestData rd, SessionData sd) {
        if (LOG.isInfoEnabled()) {
            LOG.info(createRequestData(rd, sd));
        }
    }

    private String createRequestData(RequestData rd, SessionData sd) {
        AppendingStringBuffer sb = new AppendingStringBuffer(150);

        sb.append("startTime=\"");
        sb.append(formatDate(rd.getStartDate()));
        sb.append("\",duration=");
        sb.append(rd.getTimeTaken());
        sb.append(",url=\"");
        sb.append(rd.getRequestedUrl());
        sb.append('"');
        sb.append(",event={");
        sb.append(getRequestHandlerString(rd.getEventTarget()));
        sb.append("},response={");
        sb.append(getRequestHandlerString(rd.getResponseTarget()));
        sb.append("},sessionid=\"");
        sb.append(rd.getSessionId());
        sb.append('"');
        sb.append(",sessionsize=");
        sb.append(rd.getSessionSize());
        if (rd.getSessionInfo() != null && !Strings.isEmpty(rd.getSessionInfo().toString())) {
            sb.append(",sessioninfo={");
            sb.append(rd.getSessionInfo());
            sb.append('}');
        }
        if (sd != null) {
            sb.append(",sessionstart=\"");
            sb.append(formatDate(sd.getStartDate()));
            sb.append("\",requests=");
            sb.append(sd.getNumberOfRequests());
            sb.append(",totaltime=");
            sb.append(sd.getTotalTimeTaken());
        }
        sb.append(",activerequests=");
        sb.append(rd.getActiveRequest());

        Runtime runtime = Runtime.getRuntime();
        long max = runtime.maxMemory() / 1000000;
        long total = runtime.totalMemory() / 1000000;
        long used = total - runtime.freeMemory() / 1000000;
        sb.append(",maxmem=");
        sb.append(max);
        sb.append("M,total=");
        sb.append(total);
        sb.append("M,used=");
        sb.append(used);
        sb.append('M');

        return sb.toString();
    }

    private String getRequestHandlerString(IRequestHandler handler) {
        AppendingStringBuffer sb = new AppendingStringBuffer(128);
        if (handler != null) {
            Class<? extends IRequestHandler> handlerClass = handler.getClass();
            sb.append("handler=");
            sb.append(handlerClass.isAnonymousClass() ? handlerClass.getName() : Classes.simpleName(handlerClass));
            if (handler instanceof ILoggableRequestHandler) {
                sb.append(",data=");
                sb.append(((ILoggableRequestHandler) handler).getLogData());
            }
        } else {
            sb.append("none");
        }
        return sb.toString();
    }
}