417223 - removed deprecated ThreadPool.dispatch
This commit is contained in:
parent
17bf8ccee0
commit
36c807c2f3
|
@ -64,27 +64,6 @@ public class DelegatingThreadPool extends ContainerLifeCycle implements ThreadPo
|
||||||
_executor.execute(job);
|
_executor.execute(job);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* ------------------------------------------------------------ */
|
|
||||||
@Override
|
|
||||||
public boolean dispatch(Runnable job)
|
|
||||||
{
|
|
||||||
final Executor executor=_executor;
|
|
||||||
if (executor instanceof ThreadPool)
|
|
||||||
return ((ThreadPool)executor).dispatch(job);
|
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
_executor.execute(job);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
catch(RejectedExecutionException e)
|
|
||||||
{
|
|
||||||
LOG.warn(e);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ------------------------------------------------------------ */
|
/* ------------------------------------------------------------ */
|
||||||
@Override
|
@Override
|
||||||
public int getIdleThreads()
|
public int getIdleThreads()
|
||||||
|
|
|
@ -49,15 +49,13 @@ import org.junit.Test;
|
||||||
public class IOTest
|
public class IOTest
|
||||||
{
|
{
|
||||||
@Test
|
@Test
|
||||||
public void testIO() throws InterruptedException
|
public void testIO() throws Exception
|
||||||
{
|
{
|
||||||
// Only a little test
|
// Only a little test
|
||||||
ByteArrayInputStream in = new ByteArrayInputStream("The quick brown fox jumped over the lazy dog".getBytes());
|
ByteArrayInputStream in = new ByteArrayInputStream("The quick brown fox jumped over the lazy dog".getBytes());
|
||||||
ByteArrayOutputStream out = new ByteArrayOutputStream();
|
ByteArrayOutputStream out = new ByteArrayOutputStream();
|
||||||
|
|
||||||
IO.copyThread(in, out);
|
IO.copy(in, out);
|
||||||
Thread.sleep(1500);
|
|
||||||
// System.err.println(out);
|
|
||||||
|
|
||||||
assertEquals("copyThread", out.toString(), "The quick brown fox jumped over the lazy dog");
|
assertEquals("copyThread", out.toString(), "The quick brown fox jumped over the lazy dog");
|
||||||
}
|
}
|
||||||
|
|
|
@ -62,12 +62,11 @@ public class SslConnectionTest
|
||||||
final AtomicInteger _dispatches = new AtomicInteger();
|
final AtomicInteger _dispatches = new AtomicInteger();
|
||||||
protected QueuedThreadPool _threadPool = new QueuedThreadPool()
|
protected QueuedThreadPool _threadPool = new QueuedThreadPool()
|
||||||
{
|
{
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean dispatch(Runnable job)
|
public void execute(Runnable job)
|
||||||
{
|
{
|
||||||
_dispatches.incrementAndGet();
|
_dispatches.incrementAndGet();
|
||||||
return super.dispatch(job);
|
super.execute(job);
|
||||||
}
|
}
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
|
@ -89,7 +89,7 @@ public class LowResourcesMonitorTest
|
||||||
|
|
||||||
for (int i=0;i<100;i++)
|
for (int i=0;i<100;i++)
|
||||||
{
|
{
|
||||||
_threadPool.dispatch(new Runnable()
|
_threadPool.execute(new Runnable()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public void run()
|
public void run()
|
||||||
|
|
|
@ -30,6 +30,7 @@ import java.util.HashMap;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import javax.servlet.AsyncContext;
|
||||||
import javax.servlet.ServletException;
|
import javax.servlet.ServletException;
|
||||||
import javax.servlet.http.HttpServlet;
|
import javax.servlet.http.HttpServlet;
|
||||||
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletRequest;
|
||||||
|
@ -304,7 +305,7 @@ public class CGI extends HttpServlet
|
||||||
LOG.debug("Environment: " + env.getExportString());
|
LOG.debug("Environment: " + env.getExportString());
|
||||||
LOG.debug("Command: " + execCmd);
|
LOG.debug("Command: " + execCmd);
|
||||||
|
|
||||||
Process p;
|
final Process p;
|
||||||
if (dir == null)
|
if (dir == null)
|
||||||
p = Runtime.getRuntime().exec(execCmd, env.getEnvArray());
|
p = Runtime.getRuntime().exec(execCmd, env.getEnvArray());
|
||||||
else
|
else
|
||||||
|
@ -316,13 +317,28 @@ public class CGI extends HttpServlet
|
||||||
else if (len > 0)
|
else if (len > 0)
|
||||||
writeProcessInput(p, req.getInputStream(), len);
|
writeProcessInput(p, req.getInputStream(), len);
|
||||||
|
|
||||||
IO.copyThread(p.getErrorStream(), System.err);
|
|
||||||
|
|
||||||
// hook processes output to browser's input (sync)
|
// hook processes output to browser's input (sync)
|
||||||
// if browser closes stream, we should detect it and kill process...
|
// if browser closes stream, we should detect it and kill process...
|
||||||
OutputStream os = null;
|
OutputStream os = null;
|
||||||
|
AsyncContext async=req.startAsync();
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
async.start(new Runnable()
|
||||||
|
{
|
||||||
|
@Override
|
||||||
|
public void run()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
IO.copy(p.getErrorStream(), System.err);
|
||||||
|
}
|
||||||
|
catch (IOException e)
|
||||||
|
{
|
||||||
|
LOG.warn(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
// read any headers off the top of our input stream
|
// read any headers off the top of our input stream
|
||||||
// NOTE: Multiline header items not supported!
|
// NOTE: Multiline header items not supported!
|
||||||
String line = null;
|
String line = null;
|
||||||
|
@ -398,6 +414,7 @@ public class CGI extends HttpServlet
|
||||||
}
|
}
|
||||||
p.destroy();
|
p.destroy();
|
||||||
// LOG.debug("CGI: terminated!");
|
// LOG.debug("CGI: terminated!");
|
||||||
|
async.complete();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -55,17 +55,6 @@ public class IO
|
||||||
/* ------------------------------------------------------------------- */
|
/* ------------------------------------------------------------------- */
|
||||||
public static final int bufferSize = 64*1024;
|
public static final int bufferSize = 64*1024;
|
||||||
|
|
||||||
/* ------------------------------------------------------------------- */
|
|
||||||
// TODO get rid of this singleton!
|
|
||||||
private static class Singleton {
|
|
||||||
static final QueuedThreadPool __pool=new QueuedThreadPool();
|
|
||||||
static
|
|
||||||
{
|
|
||||||
try{__pool.start();}
|
|
||||||
catch(Exception e){LOG.warn(e); System.exit(1);}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ------------------------------------------------------------------- */
|
/* ------------------------------------------------------------------- */
|
||||||
static class Job implements Runnable
|
static class Job implements Runnable
|
||||||
{
|
{
|
||||||
|
@ -118,23 +107,6 @@ public class IO
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ------------------------------------------------------------------- */
|
|
||||||
/** Copy Stream in to Stream out until EOF or exception.
|
|
||||||
* in own thread
|
|
||||||
*/
|
|
||||||
public static void copyThread(InputStream in, OutputStream out)
|
|
||||||
{
|
|
||||||
try{
|
|
||||||
Job job=new Job(in,out);
|
|
||||||
if (!Singleton.__pool.dispatch(job))
|
|
||||||
job.run();
|
|
||||||
}
|
|
||||||
catch(Exception e)
|
|
||||||
{
|
|
||||||
LOG.warn(e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ------------------------------------------------------------------- */
|
/* ------------------------------------------------------------------- */
|
||||||
/** Copy Stream in to Stream out until EOF or exception.
|
/** Copy Stream in to Stream out until EOF or exception.
|
||||||
*/
|
*/
|
||||||
|
@ -144,24 +116,6 @@ public class IO
|
||||||
copy(in,out,-1);
|
copy(in,out,-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ------------------------------------------------------------------- */
|
|
||||||
/** Copy Stream in to Stream out until EOF or exception
|
|
||||||
* in own thread
|
|
||||||
*/
|
|
||||||
public static void copyThread(Reader in, Writer out)
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
Job job=new Job(in,out);
|
|
||||||
if (!Singleton.__pool.dispatch(job))
|
|
||||||
job.run();
|
|
||||||
}
|
|
||||||
catch(Exception e)
|
|
||||||
{
|
|
||||||
LOG.warn(e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ------------------------------------------------------------------- */
|
/* ------------------------------------------------------------------- */
|
||||||
/** Copy Reader to Writer out until EOF or exception.
|
/** Copy Reader to Writer out until EOF or exception.
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -341,17 +341,10 @@ public class QueuedThreadPool extends AbstractLifeCycle implements SizedThreadPo
|
||||||
_detailedDump = detailedDump;
|
_detailedDump = detailedDump;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean dispatch(Runnable job)
|
|
||||||
{
|
|
||||||
LOG.debug("{} dispatched {}", this, job);
|
|
||||||
return isRunning() && _jobs.offer(job);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void execute(Runnable job)
|
public void execute(Runnable job)
|
||||||
{
|
{
|
||||||
if (!dispatch(job))
|
if (!isRunning() || !_jobs.offer(job))
|
||||||
{
|
{
|
||||||
LOG.warn("{} rejected {}", this, job);
|
LOG.warn("{} rejected {}", this, job);
|
||||||
throw new RejectedExecutionException(job.toString());
|
throw new RejectedExecutionException(job.toString());
|
||||||
|
|
|
@ -27,18 +27,13 @@ import org.eclipse.jetty.util.component.LifeCycle;
|
||||||
/* ------------------------------------------------------------ */
|
/* ------------------------------------------------------------ */
|
||||||
/** ThreadPool.
|
/** ThreadPool.
|
||||||
*
|
*
|
||||||
|
* A specialization of Executor interface that provides reporting methods (eg {@link #getThreads()})
|
||||||
|
* and the option of configuration methods (e.g. @link {@link SizedThreadPool#setMaxThreads(int)}).
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
@ManagedObject("Pool of Threads")
|
@ManagedObject("Pool of Threads")
|
||||||
public interface ThreadPool extends Executor
|
public interface ThreadPool extends Executor
|
||||||
{
|
{
|
||||||
/* ------------------------------------------------------------ */
|
|
||||||
/**
|
|
||||||
* @deprecated use {@link Executor#execute(Runnable)}
|
|
||||||
*/
|
|
||||||
@Deprecated
|
|
||||||
public abstract boolean dispatch(Runnable job);
|
|
||||||
|
|
||||||
/* ------------------------------------------------------------ */
|
/* ------------------------------------------------------------ */
|
||||||
/**
|
/**
|
||||||
* Blocks until the thread pool is {@link LifeCycle#stop stopped}.
|
* Blocks until the thread pool is {@link LifeCycle#stop stopped}.
|
||||||
|
|
|
@ -88,7 +88,7 @@ public class QueuedThreadPoolTest
|
||||||
waitForIdle(tp,5);
|
waitForIdle(tp,5);
|
||||||
|
|
||||||
RunningJob job=new RunningJob();
|
RunningJob job=new RunningJob();
|
||||||
tp.dispatch(job);
|
tp.execute(job);
|
||||||
waitForIdle(tp,4);
|
waitForIdle(tp,4);
|
||||||
waitForThreads(tp,5);
|
waitForThreads(tp,5);
|
||||||
|
|
||||||
|
@ -104,14 +104,14 @@ public class QueuedThreadPoolTest
|
||||||
for (int i=0;i<jobs.length;i++)
|
for (int i=0;i<jobs.length;i++)
|
||||||
{
|
{
|
||||||
jobs[i]=new RunningJob();
|
jobs[i]=new RunningJob();
|
||||||
tp.dispatch(jobs[i]);
|
tp.execute(jobs[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
waitForIdle(tp,1);
|
waitForIdle(tp,1);
|
||||||
waitForThreads(tp,6);
|
waitForThreads(tp,6);
|
||||||
|
|
||||||
job=new RunningJob();
|
job=new RunningJob();
|
||||||
tp.dispatch(job);
|
tp.execute(job);
|
||||||
waitForIdle(tp,1);
|
waitForIdle(tp,1);
|
||||||
waitForThreads(tp,7);
|
waitForThreads(tp,7);
|
||||||
|
|
||||||
|
@ -135,7 +135,7 @@ public class QueuedThreadPoolTest
|
||||||
for (int i=0;i<jobs.length;i++)
|
for (int i=0;i<jobs.length;i++)
|
||||||
{
|
{
|
||||||
jobs[i]=new RunningJob();
|
jobs[i]=new RunningJob();
|
||||||
tp.dispatch(jobs[i]);
|
tp.execute(jobs[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
waitForIdle(tp,0);
|
waitForIdle(tp,0);
|
||||||
|
@ -182,10 +182,10 @@ public class QueuedThreadPoolTest
|
||||||
waitForThreads(tp,2);
|
waitForThreads(tp,2);
|
||||||
|
|
||||||
sleep.set(200);
|
sleep.set(200);
|
||||||
tp.dispatch(job);
|
tp.execute(job);
|
||||||
tp.dispatch(job);
|
tp.execute(job);
|
||||||
for (int i=0;i<20;i++)
|
for (int i=0;i<20;i++)
|
||||||
tp.dispatch(job);
|
tp.execute(job);
|
||||||
|
|
||||||
waitForThreads(tp,10);
|
waitForThreads(tp,10);
|
||||||
waitForIdle(tp,0);
|
waitForIdle(tp,0);
|
||||||
|
@ -193,7 +193,7 @@ public class QueuedThreadPoolTest
|
||||||
sleep.set(5);
|
sleep.set(5);
|
||||||
for (int i=0;i<500;i++)
|
for (int i=0;i<500;i++)
|
||||||
{
|
{
|
||||||
tp.dispatch(job);
|
tp.execute(job);
|
||||||
Thread.sleep(10);
|
Thread.sleep(10);
|
||||||
}
|
}
|
||||||
waitForThreads(tp,2);
|
waitForThreads(tp,2);
|
||||||
|
@ -206,7 +206,7 @@ public class QueuedThreadPoolTest
|
||||||
QueuedThreadPool tp= new QueuedThreadPool();
|
QueuedThreadPool tp= new QueuedThreadPool();
|
||||||
tp.setStopTimeout(500);
|
tp.setStopTimeout(500);
|
||||||
tp.start();
|
tp.start();
|
||||||
tp.dispatch(new Runnable(){
|
tp.execute(new Runnable(){
|
||||||
public void run () {
|
public void run () {
|
||||||
while (true) {
|
while (true) {
|
||||||
try {
|
try {
|
||||||
|
|
Loading…
Reference in New Issue