Package org.apache.wicket.protocol.http

Source Code of org.apache.wicket.protocol.http.RequestLogger

/*
* 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.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)
    {
      sb.append("handler=");
      sb.append(handler.getClass().isAnonymousClass() ? handler.getClass().getName()
        : handler.getClass().getSimpleName());
      if (handler instanceof ILoggableRequestHandler)
      {
        sb.append(",data=");
        sb.append(((ILoggableRequestHandler)handler).getLogData());
      }
    }
    else
    {
      sb.append("none");
    }
    return sb.toString();
  }
}
TOP

Related Classes of org.apache.wicket.protocol.http.RequestLogger

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.