|
JMeter example source code file (Daemon.java)
The JMeter Daemon.java source code/* * 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.jmeter.protocol.http.proxy; import java.io.IOException; import java.io.InterruptedIOException; import java.net.ServerSocket; import java.net.Socket; import java.util.Collections; import java.util.HashMap; import java.util.Map; import org.apache.jorphan.logging.LoggingManager; import org.apache.jorphan.util.JOrphanUtils; import org.apache.log.Logger; /** * Web daemon thread. Creates main socket on port 8080 and listens on it * forever. For each client request, creates a proxy thread to handle the * request. * */ public class Daemon extends Thread { private static final Logger log = LoggingManager.getLoggerForClass(); /** * The time (in milliseconds) to wait when accepting a client connection. * The accept will be retried until the Daemon is told to stop. So this * interval is the longest time that the Daemon will have to wait after * being told to stop. */ private static final int ACCEPT_TIMEOUT = 1000; /** The port to listen on. */ private final int daemonPort; private final ServerSocket mainSocket; /** True if the Daemon is currently running. */ private volatile boolean running; /** The target which will receive the generated JMeter test components. */ private final ProxyControl target; /** * The proxy class which will be used to handle individual requests. This * class must be the {@link Proxy} class or a subclass. */ private final Class<? extends Proxy> proxyClass; /** * Create a new Daemon with the specified port and target. * * @param port * the port to listen on. * @param target * the target which will receive the generated JMeter test * components. * @throws IOException */ public Daemon(int port, ProxyControl target) throws IOException { this(port, target, Proxy.class); } /** * Create a new Daemon with the specified port and target, using the * specified class to handle individual requests. * * @param port * the port to listen on. * @param target * the target which will receive the generated JMeter test * components. * @param proxyClass * the proxy class to use to handle individual requests. This * class must be the {@link Proxy} class or a subclass. * @throws IOException */ public Daemon(int port, ProxyControl target, Class<? extends Proxy> proxyClass) throws IOException { super("HTTP Proxy Daemon"); this.target = target; this.daemonPort = port; this.proxyClass = proxyClass; log.info("Creating Daemon Socket on port: " + daemonPort); mainSocket = new ServerSocket(daemonPort); mainSocket.setSoTimeout(ACCEPT_TIMEOUT); } /** * Listen on the daemon port and handle incoming requests. This method will * not exit until {@link #stopServer()} is called or an error occurs. */ @Override public void run() { running = true; log.info("Proxy up and running!"); // Maps to contain page and form encodings // TODO - do these really need to be shared between all Proxy instances? Map<String, String> pageEncodings = Collections.synchronizedMap(new HashMap Other JMeter examples (source code examples)Here is a short list of links related to this JMeter Daemon.java source code file: |
... this post is sponsored by my books ... | |
![]() #1 New Release! |
![]() FP Best Seller |
Copyright 1998-2024 Alvin Alexander, alvinalexander.com
All Rights Reserved.
A percentage of advertising revenue from
pages under the /java/jwarehouse
URI on this website is
paid back to open source projects.