reworked the buffers mechanism to be less conditional
git-svn-id: svn+ssh://dev.eclipse.org/svnroot/rt/org.eclipse.jetty/jetty/trunk@396 7e9141cc-0065-0410-87d8-b60c137991c4
This commit is contained in:
parent
1c6a46a8b2
commit
0a8e71e89e
|
@ -10,6 +10,7 @@ jetty-7.0.0.M3-SNAPSHOT
|
||||||
+ Added ContinuationThrowable
|
+ Added ContinuationThrowable
|
||||||
+ 276545 Quoted cookie paths
|
+ 276545 Quoted cookie paths
|
||||||
+ 279725 Support 100 and 102 expectations
|
+ 279725 Support 100 and 102 expectations
|
||||||
|
+ Refactored AbstractBuffers to HttpBuffers for performance
|
||||||
|
|
||||||
jetty-7.0.0.M2 18 May 2009
|
jetty-7.0.0.M2 18 May 2009
|
||||||
+ JETTY-937 Work around Sun JVM bugs
|
+ JETTY-937 Work around Sun JVM bugs
|
||||||
|
|
|
@ -22,9 +22,9 @@ import java.util.Collection;
|
||||||
import javax.servlet.ServletInputStream;
|
import javax.servlet.ServletInputStream;
|
||||||
import javax.servlet.http.HttpServletResponse;
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
|
||||||
|
import org.eclipse.jetty.http.HttpException;
|
||||||
import org.eclipse.jetty.io.Buffer;
|
import org.eclipse.jetty.io.Buffer;
|
||||||
import org.eclipse.jetty.io.EndPoint;
|
import org.eclipse.jetty.io.EndPoint;
|
||||||
import org.eclipse.jetty.io.HttpException;
|
|
||||||
import org.eclipse.jetty.server.Connector;
|
import org.eclipse.jetty.server.Connector;
|
||||||
import org.eclipse.jetty.server.HttpConnection;
|
import org.eclipse.jetty.server.HttpConnection;
|
||||||
import org.eclipse.jetty.server.Request;
|
import org.eclipse.jetty.server.Request;
|
||||||
|
@ -42,8 +42,8 @@ public class Ajp13Connection extends HttpConnection
|
||||||
public Ajp13Connection(Connector connector, EndPoint endPoint, Server server)
|
public Ajp13Connection(Connector connector, EndPoint endPoint, Server server)
|
||||||
{
|
{
|
||||||
super(connector, endPoint, server,
|
super(connector, endPoint, server,
|
||||||
new Ajp13Parser(connector, endPoint),
|
new Ajp13Parser(connector.getRequestBuffers(), endPoint),
|
||||||
new Ajp13Generator(connector, endPoint, connector.getHeaderBufferSize(), connector.getResponseBufferSize()),
|
new Ajp13Generator(connector.getResponseBuffers(), endPoint),
|
||||||
new Ajp13Request()
|
new Ajp13Request()
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
|
@ -108,9 +108,9 @@ public class Ajp13Generator extends AbstractGenerator
|
||||||
private boolean _bufferPrepared = false;
|
private boolean _bufferPrepared = false;
|
||||||
|
|
||||||
/* ------------------------------------------------------------ */
|
/* ------------------------------------------------------------ */
|
||||||
public Ajp13Generator(Buffers buffers, EndPoint io, int headerBufferSize, int contentBufferSize)
|
public Ajp13Generator(Buffers buffers, EndPoint io)
|
||||||
{
|
{
|
||||||
super(buffers, io, headerBufferSize, contentBufferSize);
|
super(buffers, io);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ------------------------------------------------------------ */
|
/* ------------------------------------------------------------ */
|
||||||
|
@ -342,7 +342,7 @@ public class Ajp13Generator extends AbstractGenerator
|
||||||
|
|
||||||
// get a header buffer
|
// get a header buffer
|
||||||
if (_header == null)
|
if (_header == null)
|
||||||
_header = _buffers.getBuffer(_headerBufferSize);
|
_header = _buffers.getHeader();
|
||||||
|
|
||||||
Buffer tmpbuf = _buffer;
|
Buffer tmpbuf = _buffer;
|
||||||
_buffer = _header;
|
_buffer = _header;
|
||||||
|
@ -658,7 +658,7 @@ public class Ajp13Generator extends AbstractGenerator
|
||||||
|
|
||||||
if (_header == null)
|
if (_header == null)
|
||||||
{
|
{
|
||||||
_header = _buffers.getBuffer(_headerBufferSize);
|
_header = _buffers.getHeader();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (_buffer == null && _header != null && _header.space() >= AJP13_MORE_CONTENT.length)
|
if (_buffer == null && _header != null && _header.space() >= AJP13_MORE_CONTENT.length)
|
||||||
|
@ -709,7 +709,7 @@ public class Ajp13Generator extends AbstractGenerator
|
||||||
{
|
{
|
||||||
if (_buffer == null)
|
if (_buffer == null)
|
||||||
{
|
{
|
||||||
_buffer = _buffers.getBuffer(_contentBufferSize);
|
_buffer = _buffers.getBuffer();
|
||||||
_buffer.setPutIndex(7);
|
_buffer.setPutIndex(7);
|
||||||
_buffer.setGetIndex(7);
|
_buffer.setGetIndex(7);
|
||||||
}
|
}
|
||||||
|
@ -782,14 +782,13 @@ public class Ajp13Generator extends AbstractGenerator
|
||||||
public void sendCPong() throws IOException
|
public void sendCPong() throws IOException
|
||||||
{
|
{
|
||||||
|
|
||||||
Buffer buff = _buffers.getBuffer(AJP13_CPONG_RESPONSE.length);
|
Buffer buff = _buffers.getBuffer();
|
||||||
buff.put(AJP13_CPONG_RESPONSE);
|
buff.put(AJP13_CPONG_RESPONSE);
|
||||||
|
|
||||||
// flushing cpong response
|
// flushing cpong response
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
_endp.flush(buff);
|
_endp.flush(buff);
|
||||||
|
|
||||||
}
|
}
|
||||||
while(buff.length() >0);
|
while(buff.length() >0);
|
||||||
_buffers.returnBuffer(buff);
|
_buffers.returnBuffer(buff);
|
||||||
|
|
|
@ -234,10 +234,8 @@ public class Ajp13Parser implements Parser
|
||||||
if (_buffer == null)
|
if (_buffer == null)
|
||||||
{
|
{
|
||||||
if (_header == null)
|
if (_header == null)
|
||||||
{
|
_header = _buffers.getHeader();
|
||||||
_header = _buffers.getBuffer(Ajp13Packet.MAX_PACKET_SIZE);
|
|
||||||
_header.clear();
|
|
||||||
}
|
|
||||||
_buffer = _header;
|
_buffer = _header;
|
||||||
_tok0 = new View(_header);
|
_tok0 = new View(_header);
|
||||||
_tok1 = new View(_header);
|
_tok1 = new View(_header);
|
||||||
|
@ -491,7 +489,7 @@ public class Ajp13Parser implements Parser
|
||||||
_generator.getBodyChunk();
|
_generator.getBodyChunk();
|
||||||
if (_buffers != null && _body == null && _buffer == _header && _header.length() <= 0)
|
if (_buffers != null && _body == null && _buffer == _header && _header.length() <= 0)
|
||||||
{
|
{
|
||||||
_body = _buffers.getBuffer(Ajp13Packet.MAX_PACKET_SIZE);
|
_body = _buffers.getBuffer();
|
||||||
_body.clear();
|
_body.clear();
|
||||||
}
|
}
|
||||||
_state = STATE_AJP13CHUNK_START;
|
_state = STATE_AJP13CHUNK_START;
|
||||||
|
@ -503,7 +501,7 @@ public class Ajp13Parser implements Parser
|
||||||
|
|
||||||
if (_buffers != null && _body == null && _buffer == _header && _contentLength > (_header.capacity() - _header.getIndex()))
|
if (_buffers != null && _body == null && _buffer == _header && _contentLength > (_header.capacity() - _header.getIndex()))
|
||||||
{
|
{
|
||||||
_body = _buffers.getBuffer(Ajp13Packet.MAX_PACKET_SIZE);
|
_body = _buffers.getBuffer();
|
||||||
_body.clear();
|
_body.clear();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -33,13 +33,13 @@ public class TestAjpParser extends TestCase
|
||||||
byte[] src = TypeUtil.fromHexString(packet);
|
byte[] src = TypeUtil.fromHexString(packet);
|
||||||
|
|
||||||
ByteArrayBuffer buffer= new ByteArrayBuffer(Ajp13Packet.MAX_PACKET_SIZE);
|
ByteArrayBuffer buffer= new ByteArrayBuffer(Ajp13Packet.MAX_PACKET_SIZE);
|
||||||
SimpleBuffers buffers=new SimpleBuffers(new Buffer[]{buffer});
|
SimpleBuffers buffers=new SimpleBuffers(buffer,null);
|
||||||
|
|
||||||
EndPoint endp = new ByteArrayEndPoint(src,Ajp13Packet.MAX_PACKET_SIZE);
|
EndPoint endp = new ByteArrayEndPoint(src,Ajp13Packet.MAX_PACKET_SIZE);
|
||||||
|
|
||||||
Ajp13Parser parser = new Ajp13Parser(buffers,endp);
|
Ajp13Parser parser = new Ajp13Parser(buffers,endp);
|
||||||
parser.setEventHandler(new EH());
|
parser.setEventHandler(new EH());
|
||||||
parser.setGenerator(new Ajp13Generator(buffers,endp,0,0));
|
parser.setGenerator(new Ajp13Generator(buffers,endp));
|
||||||
|
|
||||||
parser.parseAvailable();
|
parser.parseAvailable();
|
||||||
|
|
||||||
|
@ -51,12 +51,11 @@ public class TestAjpParser extends TestCase
|
||||||
String packet="1234020102020008485454502f312e3100000f2f6363632d7777777777772f61616100000c38382e3838382e38382e383830ffff00116363632e6363636363636363632e636f6d0001bb010009a00b00116363632e6363636363636363632e636f6d00a00e005a4d6f7a696c6c612f352e30202857696e646f77733b20553b2057696e646f7773204e5420352e313b20656e2d55533b2072763a312e382e312e3129204765636b6f2f32303036313230342046697265666f782f322e302e302e3100a0010063746578742f786d6c2c6170706c69636174696f6e2f786d6c2c6170706c69636174696f6e2f7868746d6c2b786d6c2c746578742f68746d6c3b713d302e392c746578742f706c61696e3b713d302e382c696d6167652f706e672c2a2f2a3b713d302e3500a004000e656e2d75732c656e3b713d302e3500a003000c677a69702c6465666c61746500a002001e49534f2d383835392d312c7574662d383b713d302e372c2a3b713d302e3700000a4b6565702d416c69766500000333303000a006000a6b6565702d616c69766500000c4d61782d466f7277617264730000023130000800124448452d5253412d4145533235362d5348410009004039324643303544413043444141443232303137413743443141453939353132413330443938363838423843433041454643364231363035323543433232353341000b0100ff";
|
String packet="1234020102020008485454502f312e3100000f2f6363632d7777777777772f61616100000c38382e3838382e38382e383830ffff00116363632e6363636363636363632e636f6d0001bb010009a00b00116363632e6363636363636363632e636f6d00a00e005a4d6f7a696c6c612f352e30202857696e646f77733b20553b2057696e646f7773204e5420352e313b20656e2d55533b2072763a312e382e312e3129204765636b6f2f32303036313230342046697265666f782f322e302e302e3100a0010063746578742f786d6c2c6170706c69636174696f6e2f786d6c2c6170706c69636174696f6e2f7868746d6c2b786d6c2c746578742f68746d6c3b713d302e392c746578742f706c61696e3b713d302e382c696d6167652f706e672c2a2f2a3b713d302e3500a004000e656e2d75732c656e3b713d302e3500a003000c677a69702c6465666c61746500a002001e49534f2d383835392d312c7574662d383b713d302e372c2a3b713d302e3700000a4b6565702d416c69766500000333303000a006000a6b6565702d616c69766500000c4d61782d466f7277617264730000023130000800124448452d5253412d4145533235362d5348410009004039324643303544413043444141443232303137413743443141453939353132413330443938363838423843433041454643364231363035323543433232353341000b0100ff";
|
||||||
byte[] src=TypeUtil.fromHexString(packet);
|
byte[] src=TypeUtil.fromHexString(packet);
|
||||||
ByteArrayBuffer buffer=new ByteArrayBuffer(Ajp13Packet.MAX_PACKET_SIZE);
|
ByteArrayBuffer buffer=new ByteArrayBuffer(Ajp13Packet.MAX_PACKET_SIZE);
|
||||||
SimpleBuffers buffers=new SimpleBuffers(new Buffer[]
|
SimpleBuffers buffers=new SimpleBuffers(buffer,null);
|
||||||
{ buffer });
|
|
||||||
EndPoint endp=new ByteArrayEndPoint(src,Ajp13Packet.MAX_PACKET_SIZE);
|
EndPoint endp=new ByteArrayEndPoint(src,Ajp13Packet.MAX_PACKET_SIZE);
|
||||||
Ajp13Parser parser = new Ajp13Parser(buffers,endp);
|
Ajp13Parser parser = new Ajp13Parser(buffers,endp);
|
||||||
parser.setEventHandler(new EH());
|
parser.setEventHandler(new EH());
|
||||||
parser.setGenerator(new Ajp13Generator(buffers,endp,0,0));
|
parser.setGenerator(new Ajp13Generator(buffers,endp));
|
||||||
parser.parse();
|
parser.parse();
|
||||||
assertTrue(true);
|
assertTrue(true);
|
||||||
}
|
}
|
||||||
|
@ -66,12 +65,11 @@ public class TestAjpParser extends TestCase
|
||||||
String packet="1234028f02020008485454502f312e3100000d2f666f726d746573742e6a737000000d3139322e3136382e342e31383000ffff00107777772e777265636b6167652e6f726700005000000aa0010063746578742f786d6c2c6170706c69636174696f6e2f786d6c2c6170706c69636174696f6e2f7868746d6c2b786d6c2c746578742f68746d6c3b713d302e392c746578742f706c61696e3b713d302e382c696d6167652f706e672c2a2f2a3b713d302e3500a00200075554462d382c2a00a003000c677a69702c6465666c61746500a004000e656e2d67622c656e3b713d302e3500a006000a6b6565702d616c69766500a00900f95048505345535349443d37626361383232616638333466316465373663633630336366636435313938633b20667041757468436f6f6b69653d433035383430394537393344364245434633324230353234344242303039343230383344443645443533304230454637464137414544413745453231313538333745363033454435364332364446353531383635333335423433374531423637414641343533364345304546323342333642323133374243423932333943363631433131443330393842333938414546334546334146454344423746353842443b204a53455353494f4e49443d7365366331623864663432762e6a657474793300a00b00107777772e777265636b6167652e6f726700000a6b6565702d616c69766500000333303000a00e00654d6f7a696c6c612f352e3020285831313b20553b204c696e7578207838365f36343b20656e2d55533b2072763a312e382e302e3929204765636b6f2f3230303631323035202844656269616e2d312e382e302e392d3129204570697068616e792f322e313400a008000130000600066a657474793300ff";
|
String packet="1234028f02020008485454502f312e3100000d2f666f726d746573742e6a737000000d3139322e3136382e342e31383000ffff00107777772e777265636b6167652e6f726700005000000aa0010063746578742f786d6c2c6170706c69636174696f6e2f786d6c2c6170706c69636174696f6e2f7868746d6c2b786d6c2c746578742f68746d6c3b713d302e392c746578742f706c61696e3b713d302e382c696d6167652f706e672c2a2f2a3b713d302e3500a00200075554462d382c2a00a003000c677a69702c6465666c61746500a004000e656e2d67622c656e3b713d302e3500a006000a6b6565702d616c69766500a00900f95048505345535349443d37626361383232616638333466316465373663633630336366636435313938633b20667041757468436f6f6b69653d433035383430394537393344364245434633324230353234344242303039343230383344443645443533304230454637464137414544413745453231313538333745363033454435364332364446353531383635333335423433374531423637414641343533364345304546323342333642323133374243423932333943363631433131443330393842333938414546334546334146454344423746353842443b204a53455353494f4e49443d7365366331623864663432762e6a657474793300a00b00107777772e777265636b6167652e6f726700000a6b6565702d616c69766500000333303000a00e00654d6f7a696c6c612f352e3020285831313b20553b204c696e7578207838365f36343b20656e2d55533b2072763a312e382e302e3929204765636b6f2f3230303631323035202844656269616e2d312e382e302e392d3129204570697068616e792f322e313400a008000130000600066a657474793300ff";
|
||||||
byte[] src=TypeUtil.fromHexString(packet);
|
byte[] src=TypeUtil.fromHexString(packet);
|
||||||
ByteArrayBuffer buffer=new ByteArrayBuffer(Ajp13Packet.MAX_PACKET_SIZE);
|
ByteArrayBuffer buffer=new ByteArrayBuffer(Ajp13Packet.MAX_PACKET_SIZE);
|
||||||
SimpleBuffers buffers=new SimpleBuffers(new Buffer[]
|
SimpleBuffers buffers=new SimpleBuffers(buffer,null);
|
||||||
{ buffer });
|
|
||||||
EndPoint endp=new ByteArrayEndPoint(src,Ajp13Packet.MAX_PACKET_SIZE);
|
EndPoint endp=new ByteArrayEndPoint(src,Ajp13Packet.MAX_PACKET_SIZE);
|
||||||
Ajp13Parser parser = new Ajp13Parser(buffers,endp);
|
Ajp13Parser parser = new Ajp13Parser(buffers,endp);
|
||||||
parser.setEventHandler(new EH());
|
parser.setEventHandler(new EH());
|
||||||
parser.setGenerator(new Ajp13Generator(buffers,endp,0,0));
|
parser.setGenerator(new Ajp13Generator(buffers,endp));
|
||||||
parser.parse();
|
parser.parse();
|
||||||
assertTrue(true);
|
assertTrue(true);
|
||||||
}
|
}
|
||||||
|
@ -83,13 +81,13 @@ public class TestAjpParser extends TestCase
|
||||||
byte[] src = TypeUtil.fromHexString(packet);
|
byte[] src = TypeUtil.fromHexString(packet);
|
||||||
|
|
||||||
ByteArrayBuffer buffer= new ByteArrayBuffer(Ajp13Packet.MAX_PACKET_SIZE);
|
ByteArrayBuffer buffer= new ByteArrayBuffer(Ajp13Packet.MAX_PACKET_SIZE);
|
||||||
SimpleBuffers buffers=new SimpleBuffers(new Buffer[]{buffer});
|
SimpleBuffers buffers=new SimpleBuffers(buffer,null);
|
||||||
|
|
||||||
EndPoint endp = new ByteArrayEndPoint(src,Ajp13Packet.MAX_PACKET_SIZE);
|
EndPoint endp = new ByteArrayEndPoint(src,Ajp13Packet.MAX_PACKET_SIZE);
|
||||||
|
|
||||||
Ajp13Parser parser = new Ajp13Parser(buffers,endp);
|
Ajp13Parser parser = new Ajp13Parser(buffers,endp);
|
||||||
parser.setEventHandler(new EH());
|
parser.setEventHandler(new EH());
|
||||||
parser.setGenerator(new Ajp13Generator(buffers,endp,0,0));
|
parser.setGenerator(new Ajp13Generator(buffers,endp));
|
||||||
|
|
||||||
parser.parseAvailable();
|
parser.parseAvailable();
|
||||||
|
|
||||||
|
@ -102,13 +100,13 @@ public class TestAjpParser extends TestCase
|
||||||
byte[] src = TypeUtil.fromHexString(packet);
|
byte[] src = TypeUtil.fromHexString(packet);
|
||||||
|
|
||||||
ByteArrayBuffer buffer= new ByteArrayBuffer(Ajp13Packet.MAX_PACKET_SIZE);
|
ByteArrayBuffer buffer= new ByteArrayBuffer(Ajp13Packet.MAX_PACKET_SIZE);
|
||||||
SimpleBuffers buffers=new SimpleBuffers(new Buffer[]{buffer});
|
SimpleBuffers buffers=new SimpleBuffers(buffer,null);
|
||||||
|
|
||||||
EndPoint endp = new ByteArrayEndPoint(src,Ajp13Packet.MAX_PACKET_SIZE);
|
EndPoint endp = new ByteArrayEndPoint(src,Ajp13Packet.MAX_PACKET_SIZE);
|
||||||
|
|
||||||
Ajp13Parser parser = new Ajp13Parser(buffers,endp);
|
Ajp13Parser parser = new Ajp13Parser(buffers,endp);
|
||||||
parser.setEventHandler(new EH());
|
parser.setEventHandler(new EH());
|
||||||
parser.setGenerator(new Ajp13Generator(buffers,endp,0,0));
|
parser.setGenerator(new Ajp13Generator(buffers,endp));
|
||||||
|
|
||||||
parser.parseAvailable();
|
parser.parseAvailable();
|
||||||
|
|
||||||
|
@ -129,14 +127,14 @@ public class TestAjpParser extends TestCase
|
||||||
System.arraycopy(src,src.length-f,frag1,0,f);
|
System.arraycopy(src,src.length-f,frag1,0,f);
|
||||||
|
|
||||||
ByteArrayBuffer buffer= new ByteArrayBuffer(Ajp13Packet.MAX_PACKET_SIZE);
|
ByteArrayBuffer buffer= new ByteArrayBuffer(Ajp13Packet.MAX_PACKET_SIZE);
|
||||||
SimpleBuffers buffers=new SimpleBuffers(new Buffer[]{buffer});
|
SimpleBuffers buffers=new SimpleBuffers(buffer,null);
|
||||||
|
|
||||||
ByteArrayEndPoint endp = new ByteArrayEndPoint(frag0,Ajp13Packet.MAX_PACKET_SIZE);
|
ByteArrayEndPoint endp = new ByteArrayEndPoint(frag0,Ajp13Packet.MAX_PACKET_SIZE);
|
||||||
endp.setNonBlocking(true);
|
endp.setNonBlocking(true);
|
||||||
|
|
||||||
Ajp13Parser parser = new Ajp13Parser(buffers,endp);
|
Ajp13Parser parser = new Ajp13Parser(buffers,endp);
|
||||||
parser.setEventHandler(new EH());
|
parser.setEventHandler(new EH());
|
||||||
parser.setGenerator(new Ajp13Generator(buffers,endp,0,0));
|
parser.setGenerator(new Ajp13Generator(buffers,endp));
|
||||||
parser.parseNext();
|
parser.parseNext();
|
||||||
|
|
||||||
endp.setIn(new ByteArrayBuffer(frag1));
|
endp.setIn(new ByteArrayBuffer(frag1));
|
||||||
|
@ -153,13 +151,12 @@ public class TestAjpParser extends TestCase
|
||||||
String packet=getTestHeader();
|
String packet=getTestHeader();
|
||||||
byte[] src=TypeUtil.fromHexString(packet);
|
byte[] src=TypeUtil.fromHexString(packet);
|
||||||
ByteArrayBuffer buffer=new ByteArrayBuffer(Ajp13Packet.MAX_PACKET_SIZE);
|
ByteArrayBuffer buffer=new ByteArrayBuffer(Ajp13Packet.MAX_PACKET_SIZE);
|
||||||
SimpleBuffers buffers=new SimpleBuffers(new Buffer[]
|
SimpleBuffers buffers=new SimpleBuffers(buffer,null);
|
||||||
{ buffer });
|
|
||||||
ByteArrayEndPoint endp=new ByteArrayEndPoint(src,Ajp13Packet.MAX_PACKET_SIZE);
|
ByteArrayEndPoint endp=new ByteArrayEndPoint(src,Ajp13Packet.MAX_PACKET_SIZE);
|
||||||
endp.setNonBlocking(true);
|
endp.setNonBlocking(true);
|
||||||
|
|
||||||
final int count[]={0};
|
final int count[]={0};
|
||||||
Ajp13Generator gen = new Ajp13Generator(buffers,endp,0,0)
|
Ajp13Generator gen = new Ajp13Generator(buffers,endp)
|
||||||
{
|
{
|
||||||
public void getBodyChunk() throws IOException
|
public void getBodyChunk() throws IOException
|
||||||
{
|
{
|
||||||
|
@ -198,13 +195,12 @@ public class TestAjpParser extends TestCase
|
||||||
String packet="123400ff02040008485454502f312e3100000f2f746573742f64756d702f696e666f0000093132372e302e302e3100ffff00096c6f63616c686f7374000050000007a00e000d4a6176612f312e352e305f313100a00b00096c6f63616c686f737400a0010034746578742f68746d6c2c20696d6167652f6769662c20696d6167652f6a7065672c202a3b20713d2e322c202a2f2a3b20713d2e3200a006000a6b6565702d616c69766500a00700216170706c69636174696f6e2f782d7777772d666f726d2d75726c656e636f6465640000115472616e736665722d456e636f64696e670000076368756e6b656400000c4d61782d466f727761726473000002313000ff";
|
String packet="123400ff02040008485454502f312e3100000f2f746573742f64756d702f696e666f0000093132372e302e302e3100ffff00096c6f63616c686f7374000050000007a00e000d4a6176612f312e352e305f313100a00b00096c6f63616c686f737400a0010034746578742f68746d6c2c20696d6167652f6769662c20696d6167652f6a7065672c202a3b20713d2e322c202a2f2a3b20713d2e3200a006000a6b6565702d616c69766500a00700216170706c69636174696f6e2f782d7777772d666f726d2d75726c656e636f6465640000115472616e736665722d456e636f64696e670000076368756e6b656400000c4d61782d466f727761726473000002313000ff";
|
||||||
byte[] src=TypeUtil.fromHexString(packet);
|
byte[] src=TypeUtil.fromHexString(packet);
|
||||||
ByteArrayBuffer buffer=new ByteArrayBuffer(Ajp13Packet.MAX_PACKET_SIZE);
|
ByteArrayBuffer buffer=new ByteArrayBuffer(Ajp13Packet.MAX_PACKET_SIZE);
|
||||||
SimpleBuffers buffers=new SimpleBuffers(new Buffer[]
|
SimpleBuffers buffers=new SimpleBuffers(buffer,null);
|
||||||
{ buffer });
|
|
||||||
ByteArrayEndPoint endp=new ByteArrayEndPoint(src,Ajp13Packet.MAX_PACKET_SIZE);
|
ByteArrayEndPoint endp=new ByteArrayEndPoint(src,Ajp13Packet.MAX_PACKET_SIZE);
|
||||||
endp.setNonBlocking(true);
|
endp.setNonBlocking(true);
|
||||||
|
|
||||||
final int count[]={0};
|
final int count[]={0};
|
||||||
Ajp13Generator gen = new Ajp13Generator(buffers,endp,0,0)
|
Ajp13Generator gen = new Ajp13Generator(buffers,endp)
|
||||||
{
|
{
|
||||||
public void getBodyChunk() throws IOException
|
public void getBodyChunk() throws IOException
|
||||||
{
|
{
|
||||||
|
@ -258,14 +254,14 @@ public class TestAjpParser extends TestCase
|
||||||
System.arraycopy(src,src.length-f,frag1,0,f);
|
System.arraycopy(src,src.length-f,frag1,0,f);
|
||||||
|
|
||||||
ByteArrayBuffer buffer= new ByteArrayBuffer(Ajp13Packet.MAX_PACKET_SIZE);
|
ByteArrayBuffer buffer= new ByteArrayBuffer(Ajp13Packet.MAX_PACKET_SIZE);
|
||||||
SimpleBuffers buffers=new SimpleBuffers(new Buffer[]{buffer});
|
SimpleBuffers buffers=new SimpleBuffers(buffer,null);
|
||||||
|
|
||||||
ByteArrayEndPoint endp = new ByteArrayEndPoint(frag0,Ajp13Packet.MAX_PACKET_SIZE);
|
ByteArrayEndPoint endp = new ByteArrayEndPoint(frag0,Ajp13Packet.MAX_PACKET_SIZE);
|
||||||
endp.setNonBlocking(true);
|
endp.setNonBlocking(true);
|
||||||
|
|
||||||
Ajp13Parser parser = new Ajp13Parser(buffers,endp);
|
Ajp13Parser parser = new Ajp13Parser(buffers,endp);
|
||||||
parser.setEventHandler(new EH());
|
parser.setEventHandler(new EH());
|
||||||
parser.setGenerator(new Ajp13Generator(buffers,endp,0,0));
|
parser.setGenerator(new Ajp13Generator(buffers,endp));
|
||||||
parser.parseNext();
|
parser.parseNext();
|
||||||
|
|
||||||
endp.setIn(new ByteArrayBuffer(frag1));
|
endp.setIn(new ByteArrayBuffer(frag1));
|
||||||
|
@ -291,14 +287,14 @@ public class TestAjpParser extends TestCase
|
||||||
System.arraycopy(src,src.length-f,frag1,0,f);
|
System.arraycopy(src,src.length-f,frag1,0,f);
|
||||||
|
|
||||||
ByteArrayBuffer buffer= new ByteArrayBuffer(Ajp13Packet.MAX_PACKET_SIZE);
|
ByteArrayBuffer buffer= new ByteArrayBuffer(Ajp13Packet.MAX_PACKET_SIZE);
|
||||||
SimpleBuffers buffers=new SimpleBuffers(new Buffer[]{buffer});
|
SimpleBuffers buffers=new SimpleBuffers(buffer,null);
|
||||||
|
|
||||||
ByteArrayEndPoint endp = new ByteArrayEndPoint(frag0,Ajp13Packet.MAX_PACKET_SIZE);
|
ByteArrayEndPoint endp = new ByteArrayEndPoint(frag0,Ajp13Packet.MAX_PACKET_SIZE);
|
||||||
endp.setNonBlocking(true);
|
endp.setNonBlocking(true);
|
||||||
|
|
||||||
Ajp13Parser parser = new Ajp13Parser(buffers,endp);
|
Ajp13Parser parser = new Ajp13Parser(buffers,endp);
|
||||||
parser.setEventHandler(new EH());
|
parser.setEventHandler(new EH());
|
||||||
parser.setGenerator(new Ajp13Generator(buffers,endp,0,0));
|
parser.setGenerator(new Ajp13Generator(buffers,endp));
|
||||||
parser.parseNext();
|
parser.parseNext();
|
||||||
|
|
||||||
endp.setIn(new ByteArrayBuffer(frag1));
|
endp.setIn(new ByteArrayBuffer(frag1));
|
||||||
|
|
|
@ -35,8 +35,8 @@ import javax.net.ssl.X509TrustManager;
|
||||||
|
|
||||||
import org.eclipse.jetty.client.security.Authorization;
|
import org.eclipse.jetty.client.security.Authorization;
|
||||||
import org.eclipse.jetty.client.security.RealmResolver;
|
import org.eclipse.jetty.client.security.RealmResolver;
|
||||||
|
import org.eclipse.jetty.http.HttpBuffers;
|
||||||
import org.eclipse.jetty.http.HttpSchemes;
|
import org.eclipse.jetty.http.HttpSchemes;
|
||||||
import org.eclipse.jetty.io.AbstractBuffers;
|
|
||||||
import org.eclipse.jetty.io.Buffer;
|
import org.eclipse.jetty.io.Buffer;
|
||||||
import org.eclipse.jetty.io.ByteArrayBuffer;
|
import org.eclipse.jetty.io.ByteArrayBuffer;
|
||||||
import org.eclipse.jetty.io.nio.DirectNIOBuffer;
|
import org.eclipse.jetty.io.nio.DirectNIOBuffer;
|
||||||
|
@ -78,7 +78,7 @@ import org.eclipse.jetty.util.thread.Timeout;
|
||||||
* @see {@link HttpExchange}
|
* @see {@link HttpExchange}
|
||||||
* @see {@link HttpDestination}
|
* @see {@link HttpDestination}
|
||||||
*/
|
*/
|
||||||
public class HttpClient extends AbstractBuffers implements Attributes
|
public class HttpClient extends HttpBuffers implements Attributes
|
||||||
{
|
{
|
||||||
public static final int CONNECTOR_SOCKET = 0;
|
public static final int CONNECTOR_SOCKET = 0;
|
||||||
public static final int CONNECTOR_SELECT_CHANNEL = 2;
|
public static final int CONNECTOR_SELECT_CHANNEL = 2;
|
||||||
|
@ -341,26 +341,50 @@ public class HttpClient extends AbstractBuffers implements Attributes
|
||||||
|
|
||||||
/* ------------------------------------------------------------ */
|
/* ------------------------------------------------------------ */
|
||||||
/**
|
/**
|
||||||
* Create a new NIO buffer. If using direct buffers, it will create a direct
|
* @see org.eclipse.jetty.http.HttpBuffers#newRequestBuffer(int)
|
||||||
* NIO buffer, other than an indirect buffer.
|
|
||||||
*/
|
*/
|
||||||
public Buffer newBuffer(int size)
|
@Override
|
||||||
|
protected Buffer newRequestBuffer(int size)
|
||||||
{
|
{
|
||||||
if (_connectorType != CONNECTOR_SOCKET)
|
if (_connectorType == CONNECTOR_SOCKET)
|
||||||
{
|
|
||||||
Buffer buf = null;
|
|
||||||
if (size==getHeaderBufferSize())
|
|
||||||
buf=new IndirectNIOBuffer(size);
|
|
||||||
else if (_useDirectBuffers)
|
|
||||||
buf=new DirectNIOBuffer(size);
|
|
||||||
else
|
|
||||||
buf=new IndirectNIOBuffer(size);
|
|
||||||
return buf;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
return new ByteArrayBuffer(size);
|
return new ByteArrayBuffer(size);
|
||||||
}
|
return _useDirectBuffers?new DirectNIOBuffer(size):new IndirectNIOBuffer(size);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ------------------------------------------------------------ */
|
||||||
|
/**
|
||||||
|
* @see org.eclipse.jetty.http.HttpBuffers#newRequestHeader(int)
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
protected Buffer newRequestHeader(int size)
|
||||||
|
{
|
||||||
|
if (_connectorType == CONNECTOR_SOCKET)
|
||||||
|
return new ByteArrayBuffer(size);
|
||||||
|
return new IndirectNIOBuffer(size);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ------------------------------------------------------------ */
|
||||||
|
/**
|
||||||
|
* @see org.eclipse.jetty.http.HttpBuffers#newResponseBuffer(int)
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
protected Buffer newResponseBuffer(int size)
|
||||||
|
{
|
||||||
|
if (_connectorType == CONNECTOR_SOCKET)
|
||||||
|
return new ByteArrayBuffer(size);
|
||||||
|
return _useDirectBuffers?new DirectNIOBuffer(size):new IndirectNIOBuffer(size);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ------------------------------------------------------------ */
|
||||||
|
/**
|
||||||
|
* @see org.eclipse.jetty.http.HttpBuffers#newResponseHeader(int)
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
protected Buffer newResponseHeader(int size)
|
||||||
|
{
|
||||||
|
if (_connectorType == CONNECTOR_SOCKET)
|
||||||
|
return new ByteArrayBuffer(size);
|
||||||
|
return new IndirectNIOBuffer(size);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ------------------------------------------------------------ */
|
/* ------------------------------------------------------------ */
|
||||||
|
|
|
@ -108,11 +108,11 @@ public class HttpConnection implements Connection
|
||||||
};
|
};
|
||||||
|
|
||||||
/* ------------------------------------------------------------ */
|
/* ------------------------------------------------------------ */
|
||||||
HttpConnection(Buffers buffers, EndPoint endp, int hbs, int cbs)
|
HttpConnection(Buffers requestBuffers, Buffers responseBuffers, EndPoint endp)
|
||||||
{
|
{
|
||||||
_endp = endp;
|
_endp = endp;
|
||||||
_generator = new HttpGenerator(buffers,endp,hbs,cbs);
|
_generator = new HttpGenerator(requestBuffers,endp);
|
||||||
_parser = new HttpParser(buffers,endp,new Handler(),hbs,cbs);
|
_parser = new HttpParser(responseBuffers,endp,new Handler());
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setReserved (boolean reserved)
|
public void setReserved (boolean reserved)
|
||||||
|
|
|
@ -19,14 +19,17 @@ import java.nio.channels.SocketChannel;
|
||||||
|
|
||||||
import javax.net.ssl.SSLContext;
|
import javax.net.ssl.SSLContext;
|
||||||
import javax.net.ssl.SSLEngine;
|
import javax.net.ssl.SSLEngine;
|
||||||
|
import javax.net.ssl.SSLSession;
|
||||||
|
|
||||||
|
import org.eclipse.jetty.http.HttpBuffers;
|
||||||
import org.eclipse.jetty.http.HttpMethods;
|
import org.eclipse.jetty.http.HttpMethods;
|
||||||
import org.eclipse.jetty.http.HttpVersions;
|
import org.eclipse.jetty.http.HttpVersions;
|
||||||
import org.eclipse.jetty.http.ssl.SslSelectChannelEndPoint;
|
import org.eclipse.jetty.http.ssl.SslSelectChannelEndPoint;
|
||||||
import org.eclipse.jetty.io.AbstractBuffers;
|
|
||||||
import org.eclipse.jetty.io.Buffer;
|
import org.eclipse.jetty.io.Buffer;
|
||||||
import org.eclipse.jetty.io.Buffers;
|
import org.eclipse.jetty.io.Buffers;
|
||||||
import org.eclipse.jetty.io.Connection;
|
import org.eclipse.jetty.io.Connection;
|
||||||
|
import org.eclipse.jetty.io.ThreadLocalBuffers;
|
||||||
|
import org.eclipse.jetty.io.nio.DirectNIOBuffer;
|
||||||
import org.eclipse.jetty.io.nio.IndirectNIOBuffer;
|
import org.eclipse.jetty.io.nio.IndirectNIOBuffer;
|
||||||
import org.eclipse.jetty.io.nio.SelectChannelEndPoint;
|
import org.eclipse.jetty.io.nio.SelectChannelEndPoint;
|
||||||
import org.eclipse.jetty.io.nio.SelectorManager;
|
import org.eclipse.jetty.io.nio.SelectorManager;
|
||||||
|
@ -40,7 +43,7 @@ class SelectConnector extends AbstractLifeCycle implements HttpClient.Connector,
|
||||||
private Buffers _sslBuffers;
|
private Buffers _sslBuffers;
|
||||||
private boolean _blockingConnect;
|
private boolean _blockingConnect;
|
||||||
|
|
||||||
SelectorManager _selectorManager=new Manager();
|
Manager _selectorManager=new Manager();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param httpClient
|
* @param httpClient
|
||||||
|
@ -71,7 +74,32 @@ class SelectConnector extends AbstractLifeCycle implements HttpClient.Connector,
|
||||||
/* ------------------------------------------------------------ */
|
/* ------------------------------------------------------------ */
|
||||||
protected void doStart() throws Exception
|
protected void doStart() throws Exception
|
||||||
{
|
{
|
||||||
|
super.doStart();
|
||||||
|
|
||||||
_selectorManager.start();
|
_selectorManager.start();
|
||||||
|
|
||||||
|
SSLEngine sslEngine=_selectorManager.newSslEngine();
|
||||||
|
SSLSession ssl_session=sslEngine.getSession();
|
||||||
|
|
||||||
|
ThreadLocalBuffers buffers = new ThreadLocalBuffers()
|
||||||
|
{
|
||||||
|
@Override
|
||||||
|
protected Buffer newBuffer(int size)
|
||||||
|
{
|
||||||
|
// TODO indirect?
|
||||||
|
return new DirectNIOBuffer(size);
|
||||||
|
}
|
||||||
|
@Override
|
||||||
|
protected Buffer newHeader(int size)
|
||||||
|
{
|
||||||
|
// TODO indirect?
|
||||||
|
return new DirectNIOBuffer(size);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
buffers.setBufferSize(ssl_session.getApplicationBufferSize());
|
||||||
|
buffers.setHeaderSize(ssl_session.getPacketBufferSize());
|
||||||
|
_sslBuffers=buffers;
|
||||||
|
|
||||||
_httpClient._threadPool.dispatch(this);
|
_httpClient._threadPool.dispatch(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -134,7 +162,7 @@ class SelectConnector extends AbstractLifeCycle implements HttpClient.Connector,
|
||||||
|
|
||||||
protected Connection newConnection(SocketChannel channel, SelectChannelEndPoint endpoint)
|
protected Connection newConnection(SocketChannel channel, SelectChannelEndPoint endpoint)
|
||||||
{
|
{
|
||||||
return new HttpConnection(_httpClient,endpoint,SelectConnector.this._httpClient.getHeaderBufferSize(),SelectConnector.this._httpClient.getRequestBufferSize());
|
return new HttpConnection(_httpClient.getRequestBuffers(),_httpClient.getResponseBuffers(),endpoint);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected SelectChannelEndPoint newEndPoint(SocketChannel channel, SelectSet selectSet, SelectionKey key) throws IOException
|
protected SelectChannelEndPoint newEndPoint(SocketChannel channel, SelectSet selectSet, SelectionKey key) throws IOException
|
||||||
|
@ -180,29 +208,8 @@ class SelectConnector extends AbstractLifeCycle implements HttpClient.Connector,
|
||||||
sslEngine.setUseClientMode(true);
|
sslEngine.setUseClientMode(true);
|
||||||
sslEngine.beginHandshake();
|
sslEngine.beginHandshake();
|
||||||
|
|
||||||
if (_sslBuffers==null)
|
|
||||||
{
|
|
||||||
AbstractBuffers buffers = new AbstractBuffers()
|
|
||||||
{
|
|
||||||
public Buffer newBuffer( int size )
|
|
||||||
{
|
|
||||||
return new IndirectNIOBuffer( size);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
buffers.setRequestBufferSize( sslEngine.getSession().getPacketBufferSize());
|
|
||||||
buffers.setResponseBufferSize(sslEngine.getSession().getApplicationBufferSize());
|
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
buffers.start();
|
|
||||||
}
|
|
||||||
catch(Exception e)
|
|
||||||
{
|
|
||||||
throw new IllegalStateException(e);
|
|
||||||
}
|
|
||||||
_sslBuffers=buffers;
|
|
||||||
}
|
|
||||||
|
|
||||||
return sslEngine;
|
return sslEngine;
|
||||||
}
|
}
|
||||||
|
|
|
@ -59,7 +59,7 @@ class SocketConnector extends AbstractLifeCycle implements HttpClient.Connector
|
||||||
|
|
||||||
EndPoint endpoint=new SocketEndPoint(socket);
|
EndPoint endpoint=new SocketEndPoint(socket);
|
||||||
|
|
||||||
final HttpConnection connection=new HttpConnection(_httpClient,endpoint,_httpClient.getHeaderBufferSize(),_httpClient.getRequestBufferSize());
|
final HttpConnection connection=new HttpConnection(_httpClient.getRequestBuffers(),_httpClient.getResponseBuffers(),endpoint);
|
||||||
connection.setDestination(destination);
|
connection.setDestination(destination);
|
||||||
destination.onNewConnection(connection);
|
destination.onNewConnection(connection);
|
||||||
_httpClient.getThreadPool().dispatch(new Runnable()
|
_httpClient.getThreadPool().dispatch(new Runnable()
|
||||||
|
|
|
@ -49,8 +49,6 @@ public abstract class AbstractGenerator implements Generator
|
||||||
|
|
||||||
protected final Buffers _buffers; // source of buffers
|
protected final Buffers _buffers; // source of buffers
|
||||||
protected final EndPoint _endp;
|
protected final EndPoint _endp;
|
||||||
protected final int _headerBufferSize;
|
|
||||||
protected int _contentBufferSize;
|
|
||||||
|
|
||||||
protected int _state = STATE_HEADER;
|
protected int _state = STATE_HEADER;
|
||||||
|
|
||||||
|
@ -83,12 +81,10 @@ public abstract class AbstractGenerator implements Generator
|
||||||
* @param headerBufferSize Size of the buffer to allocate for HTTP header
|
* @param headerBufferSize Size of the buffer to allocate for HTTP header
|
||||||
* @param contentBufferSize Size of the buffer to allocate for HTTP content
|
* @param contentBufferSize Size of the buffer to allocate for HTTP content
|
||||||
*/
|
*/
|
||||||
public AbstractGenerator(Buffers buffers, EndPoint io, int headerBufferSize, int contentBufferSize)
|
public AbstractGenerator(Buffers buffers, EndPoint io)
|
||||||
{
|
{
|
||||||
this._buffers = buffers;
|
this._buffers = buffers;
|
||||||
this._endp = io;
|
this._endp = io;
|
||||||
_headerBufferSize=headerBufferSize;
|
|
||||||
_contentBufferSize=contentBufferSize;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ------------------------------------------------------------------------------- */
|
/* ------------------------------------------------------------------------------- */
|
||||||
|
@ -112,17 +108,15 @@ public abstract class AbstractGenerator implements Generator
|
||||||
_contentLength = HttpTokens.UNKNOWN_CONTENT;
|
_contentLength = HttpTokens.UNKNOWN_CONTENT;
|
||||||
|
|
||||||
// always return the buffer
|
// always return the buffer
|
||||||
Buffer buffer=_buffer;
|
if (_buffer!=null)
|
||||||
|
_buffers.returnBuffer(_buffer);
|
||||||
_buffer=null;
|
_buffer=null;
|
||||||
if (buffer!=null && _header!=buffer)
|
|
||||||
_buffers.returnBuffer(buffer);
|
|
||||||
|
|
||||||
if (returnBuffers)
|
if (returnBuffers)
|
||||||
{
|
{
|
||||||
buffer=_header;
|
if (_header!=null)
|
||||||
|
_buffers.returnBuffer(_header);
|
||||||
_header=null;
|
_header=null;
|
||||||
if (buffer!=null)
|
|
||||||
_buffers.returnBuffer(buffer);
|
|
||||||
}
|
}
|
||||||
else if (_header != null)
|
else if (_header != null)
|
||||||
_header.clear();
|
_header.clear();
|
||||||
|
@ -152,7 +146,9 @@ public abstract class AbstractGenerator implements Generator
|
||||||
*/
|
*/
|
||||||
public int getContentBufferSize()
|
public int getContentBufferSize()
|
||||||
{
|
{
|
||||||
return _contentBufferSize;
|
if (_buffer==null)
|
||||||
|
_buffer=_buffers.getBuffer();
|
||||||
|
return _buffer.capacity();
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ------------------------------------------------------------ */
|
/* ------------------------------------------------------------ */
|
||||||
|
@ -161,12 +157,13 @@ public abstract class AbstractGenerator implements Generator
|
||||||
*/
|
*/
|
||||||
public void increaseContentBufferSize(int contentBufferSize)
|
public void increaseContentBufferSize(int contentBufferSize)
|
||||||
{
|
{
|
||||||
if (contentBufferSize > _contentBufferSize)
|
if (_buffer==null)
|
||||||
|
_buffer=_buffers.getBuffer();
|
||||||
|
if (contentBufferSize > _buffer.capacity())
|
||||||
{
|
{
|
||||||
_contentBufferSize = contentBufferSize;
|
|
||||||
if (_buffer != null)
|
if (_buffer != null)
|
||||||
{
|
{
|
||||||
Buffer nb = _buffers.getBuffer(_contentBufferSize);
|
Buffer nb = _buffers.getBuffer(contentBufferSize);
|
||||||
nb.put(_buffer);
|
nb.put(_buffer);
|
||||||
_buffers.returnBuffer(_buffer);
|
_buffers.returnBuffer(_buffer);
|
||||||
_buffer = nb;
|
_buffer = nb;
|
||||||
|
@ -312,8 +309,10 @@ public abstract class AbstractGenerator implements Generator
|
||||||
if (reason!=null)
|
if (reason!=null)
|
||||||
{
|
{
|
||||||
int len=reason.length();
|
int len=reason.length();
|
||||||
if (len>_headerBufferSize/2)
|
|
||||||
len=_headerBufferSize/2;
|
// TODO don't hard code
|
||||||
|
if (len>1024)
|
||||||
|
len=1024;
|
||||||
_reason=new ByteArrayBuffer(len);
|
_reason=new ByteArrayBuffer(len);
|
||||||
for (int i=0;i<len;i++)
|
for (int i=0;i<len;i++)
|
||||||
{
|
{
|
||||||
|
|
|
@ -0,0 +1,181 @@
|
||||||
|
// ========================================================================
|
||||||
|
// Copyright (c) 2004-2009 Mort Bay Consulting Pty. Ltd.
|
||||||
|
// ------------------------------------------------------------------------
|
||||||
|
// All rights reserved. This program and the accompanying materials
|
||||||
|
// are made available under the terms of the Eclipse Public License v1.0
|
||||||
|
// and Apache License v2.0 which accompanies this distribution.
|
||||||
|
// The Eclipse Public License is available at
|
||||||
|
// http://www.eclipse.org/legal/epl-v10.html
|
||||||
|
// The Apache License v2.0 is available at
|
||||||
|
// http://www.opensource.org/licenses/apache2.0.php
|
||||||
|
// You may elect to redistribute this code under either of these licenses.
|
||||||
|
// ========================================================================
|
||||||
|
|
||||||
|
package org.eclipse.jetty.http;
|
||||||
|
|
||||||
|
import org.eclipse.jetty.io.Buffer;
|
||||||
|
import org.eclipse.jetty.io.Buffers;
|
||||||
|
import org.eclipse.jetty.io.ThreadLocalBuffers;
|
||||||
|
import org.eclipse.jetty.util.component.AbstractLifeCycle;
|
||||||
|
|
||||||
|
/* ------------------------------------------------------------ */
|
||||||
|
/** Abstract Buffer pool.
|
||||||
|
* simple unbounded pool of buffers for header, request and response sizes.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public abstract class HttpBuffers extends AbstractLifeCycle
|
||||||
|
{
|
||||||
|
|
||||||
|
private final ThreadLocalBuffers _requestBuffers = new ThreadLocalBuffers()
|
||||||
|
{
|
||||||
|
@Override
|
||||||
|
protected Buffer newBuffer(int size)
|
||||||
|
{
|
||||||
|
return newRequestBuffer(size);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected Buffer newHeader(int size)
|
||||||
|
{
|
||||||
|
return newRequestHeader(size);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
private final ThreadLocalBuffers _responseBuffers = new ThreadLocalBuffers()
|
||||||
|
{
|
||||||
|
@Override
|
||||||
|
protected Buffer newBuffer(int size)
|
||||||
|
{
|
||||||
|
return newResponseBuffer(size);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected Buffer newHeader(int size)
|
||||||
|
{
|
||||||
|
return newResponseHeader(size);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
public HttpBuffers()
|
||||||
|
{
|
||||||
|
super();
|
||||||
|
_requestBuffers.setBufferSize(8*1024);
|
||||||
|
_requestBuffers.setHeaderSize(6*1024);
|
||||||
|
_responseBuffers.setBufferSize(12*1024);
|
||||||
|
_responseBuffers.setHeaderSize(6*1024);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void doStart()
|
||||||
|
throws Exception
|
||||||
|
{
|
||||||
|
super.doStart();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return Returns the headerBufferSize.
|
||||||
|
* @deprecated use {@link #getRequestHeaderSize()} or {@link #getResponseHeaderSize()}
|
||||||
|
*/
|
||||||
|
public int getHeaderBufferSize()
|
||||||
|
{
|
||||||
|
return _requestBuffers.getHeaderSize();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Buffers getRequestBuffers()
|
||||||
|
{
|
||||||
|
return _requestBuffers;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return Returns the requestBufferSize.
|
||||||
|
*/
|
||||||
|
public int getRequestBufferSize()
|
||||||
|
{
|
||||||
|
return _requestBuffers.getBufferSize();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return Returns the request header size.
|
||||||
|
*/
|
||||||
|
public int getRequestHeaderSize()
|
||||||
|
{
|
||||||
|
return _requestBuffers.getHeaderSize();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Buffers getResponseBuffers()
|
||||||
|
{
|
||||||
|
return _requestBuffers;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return Returns the responseBufferSize.
|
||||||
|
*/
|
||||||
|
public int getResponseBufferSize()
|
||||||
|
{
|
||||||
|
return _responseBuffers.getBufferSize();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return Returns the response header size.
|
||||||
|
*/
|
||||||
|
public int getResponseHeaderSize()
|
||||||
|
{
|
||||||
|
return _responseBuffers.getHeaderSize();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected abstract Buffer newRequestBuffer(int size);
|
||||||
|
|
||||||
|
protected abstract Buffer newRequestHeader(int size);
|
||||||
|
|
||||||
|
protected abstract Buffer newResponseBuffer(int size);
|
||||||
|
|
||||||
|
protected abstract Buffer newResponseHeader(int size);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param headerBufferSize The headerBufferSize to set.
|
||||||
|
* @deprecated
|
||||||
|
*/
|
||||||
|
public void setHeaderBufferSize( int headerBufferSize )
|
||||||
|
{
|
||||||
|
setRequestHeaderSize(headerBufferSize);
|
||||||
|
setResponseHeaderSize(headerBufferSize);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param size The requestBufferSize to set.
|
||||||
|
*/
|
||||||
|
public void setRequestBufferSize( int size )
|
||||||
|
{
|
||||||
|
if (isStarted())
|
||||||
|
throw new IllegalStateException();
|
||||||
|
_requestBuffers.setBufferSize(size);
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* @param size
|
||||||
|
*/
|
||||||
|
public void setRequestHeaderSize( int size )
|
||||||
|
{
|
||||||
|
if (isStarted())
|
||||||
|
throw new IllegalStateException();
|
||||||
|
_requestBuffers.setHeaderSize(size);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param size The response buffer size in bytes.
|
||||||
|
*/
|
||||||
|
public void setResponseBufferSize( int size )
|
||||||
|
{
|
||||||
|
if (isStarted())
|
||||||
|
throw new IllegalStateException();
|
||||||
|
_responseBuffers.setBufferSize(size);
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* @param size
|
||||||
|
*/
|
||||||
|
public void setResponseHeaderSize( int size )
|
||||||
|
{
|
||||||
|
if (isStarted())
|
||||||
|
throw new IllegalStateException();
|
||||||
|
_responseBuffers.setHeaderSize(size);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -11,7 +11,7 @@
|
||||||
// You may elect to redistribute this code under either of these licenses.
|
// You may elect to redistribute this code under either of these licenses.
|
||||||
// ========================================================================
|
// ========================================================================
|
||||||
|
|
||||||
package org.eclipse.jetty.io;
|
package org.eclipse.jetty.http;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
|
@ -115,9 +115,9 @@ public class HttpGenerator extends AbstractGenerator
|
||||||
* @param headerBufferSize Size of the buffer to allocate for HTTP header
|
* @param headerBufferSize Size of the buffer to allocate for HTTP header
|
||||||
* @param contentBufferSize Size of the buffer to allocate for HTTP content
|
* @param contentBufferSize Size of the buffer to allocate for HTTP content
|
||||||
*/
|
*/
|
||||||
public HttpGenerator(Buffers buffers, EndPoint io, int headerBufferSize, int contentBufferSize)
|
public HttpGenerator(Buffers buffers, EndPoint io)
|
||||||
{
|
{
|
||||||
super(buffers,io,headerBufferSize,contentBufferSize);
|
super(buffers,io);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ------------------------------------------------------------------------------- */
|
/* ------------------------------------------------------------------------------- */
|
||||||
|
@ -188,7 +188,7 @@ public class HttpGenerator extends AbstractGenerator
|
||||||
{
|
{
|
||||||
// Yes - so we better check we have a buffer
|
// Yes - so we better check we have a buffer
|
||||||
if (_buffer == null)
|
if (_buffer == null)
|
||||||
_buffer = _buffers.getBuffer(_contentBufferSize);
|
_buffer = _buffers.getBuffer();
|
||||||
|
|
||||||
// Copy _content to buffer;
|
// Copy _content to buffer;
|
||||||
int len=_buffer.put(_content);
|
int len=_buffer.put(_content);
|
||||||
|
@ -255,7 +255,7 @@ public class HttpGenerator extends AbstractGenerator
|
||||||
|
|
||||||
// we better check we have a buffer
|
// we better check we have a buffer
|
||||||
if (_buffer == null)
|
if (_buffer == null)
|
||||||
_buffer = _buffers.getBuffer(_contentBufferSize);
|
_buffer = _buffers.getBuffer();
|
||||||
|
|
||||||
// Copy _content to buffer;
|
// Copy _content to buffer;
|
||||||
_buffer.put(b);
|
_buffer.put(b);
|
||||||
|
@ -288,7 +288,7 @@ public class HttpGenerator extends AbstractGenerator
|
||||||
|
|
||||||
// we better check we have a buffer
|
// we better check we have a buffer
|
||||||
if (_buffer == null)
|
if (_buffer == null)
|
||||||
_buffer = _buffers.getBuffer(_contentBufferSize);
|
_buffer = _buffers.getBuffer();
|
||||||
|
|
||||||
_contentWritten-=_buffer.length();
|
_contentWritten-=_buffer.length();
|
||||||
|
|
||||||
|
@ -323,7 +323,7 @@ public class HttpGenerator extends AbstractGenerator
|
||||||
|
|
||||||
// get a header buffer
|
// get a header buffer
|
||||||
if (_header == null)
|
if (_header == null)
|
||||||
_header = _buffers.getBuffer(_headerBufferSize);
|
_header = _buffers.getHeader();
|
||||||
|
|
||||||
boolean has_server = false;
|
boolean has_server = false;
|
||||||
|
|
||||||
|
|
|
@ -21,7 +21,6 @@ import org.eclipse.jetty.io.Buffers;
|
||||||
import org.eclipse.jetty.io.ByteArrayBuffer;
|
import org.eclipse.jetty.io.ByteArrayBuffer;
|
||||||
import org.eclipse.jetty.io.EndPoint;
|
import org.eclipse.jetty.io.EndPoint;
|
||||||
import org.eclipse.jetty.io.EofException;
|
import org.eclipse.jetty.io.EofException;
|
||||||
import org.eclipse.jetty.io.HttpException;
|
|
||||||
import org.eclipse.jetty.io.View;
|
import org.eclipse.jetty.io.View;
|
||||||
import org.eclipse.jetty.io.BufferCache.CachedBuffer;
|
import org.eclipse.jetty.io.BufferCache.CachedBuffer;
|
||||||
import org.eclipse.jetty.util.StringUtil;
|
import org.eclipse.jetty.util.StringUtil;
|
||||||
|
@ -62,9 +61,6 @@ public class HttpParser implements Parser
|
||||||
private Buffer _body; // Buffer for large content
|
private Buffer _body; // Buffer for large content
|
||||||
private Buffer _buffer; // The current buffer in use (either _header or _content)
|
private Buffer _buffer; // The current buffer in use (either _header or _content)
|
||||||
private final View _contentView=new View(); // View of the content in the buffer for {@link Input}
|
private final View _contentView=new View(); // View of the content in the buffer for {@link Input}
|
||||||
private int _headerBufferSize;
|
|
||||||
|
|
||||||
private int _contentBufferSize;
|
|
||||||
private CachedBuffer _cached;
|
private CachedBuffer _cached;
|
||||||
private View.CaseInsensitive _tok0; // Saved token: header name, request method or response version
|
private View.CaseInsensitive _tok0; // Saved token: header name, request method or response version
|
||||||
private View.CaseInsensitive _tok1; // Saved token: header value, request URI or response code
|
private View.CaseInsensitive _tok1; // Saved token: header value, request URI or response code
|
||||||
|
@ -108,13 +104,11 @@ public class HttpParser implements Parser
|
||||||
* @param headerBufferSize size in bytes of header buffer
|
* @param headerBufferSize size in bytes of header buffer
|
||||||
* @param contentBufferSize size in bytes of content buffer
|
* @param contentBufferSize size in bytes of content buffer
|
||||||
*/
|
*/
|
||||||
public HttpParser(Buffers buffers, EndPoint endp, EventHandler handler, int headerBufferSize, int contentBufferSize)
|
public HttpParser(Buffers buffers, EndPoint endp, EventHandler handler)
|
||||||
{
|
{
|
||||||
_buffers=buffers;
|
_buffers=buffers;
|
||||||
_endp=endp;
|
_endp=endp;
|
||||||
_handler=handler;
|
_handler=handler;
|
||||||
_headerBufferSize=headerBufferSize;
|
|
||||||
_contentBufferSize=contentBufferSize;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ------------------------------------------------------------------------------- */
|
/* ------------------------------------------------------------------------------- */
|
||||||
|
@ -240,7 +234,7 @@ public class HttpParser implements Parser
|
||||||
{
|
{
|
||||||
if (_header == null)
|
if (_header == null)
|
||||||
{
|
{
|
||||||
_header=_buffers.getBuffer(_headerBufferSize);
|
_header=_buffers.getHeader();
|
||||||
}
|
}
|
||||||
_buffer=_header;
|
_buffer=_header;
|
||||||
_tok0=new View.CaseInsensitive(_header);
|
_tok0=new View.CaseInsensitive(_header);
|
||||||
|
@ -522,7 +516,7 @@ public class HttpParser implements Parser
|
||||||
case HttpTokens.EOF_CONTENT:
|
case HttpTokens.EOF_CONTENT:
|
||||||
_state=STATE_EOF_CONTENT;
|
_state=STATE_EOF_CONTENT;
|
||||||
if(_body==null && _buffers!=null)
|
if(_body==null && _buffers!=null)
|
||||||
_body=_buffers.getBuffer(_contentBufferSize);
|
_body=_buffers.getBuffer();
|
||||||
|
|
||||||
_handler.headerComplete(); // May recurse here !
|
_handler.headerComplete(); // May recurse here !
|
||||||
break;
|
break;
|
||||||
|
@ -530,7 +524,7 @@ public class HttpParser implements Parser
|
||||||
case HttpTokens.CHUNKED_CONTENT:
|
case HttpTokens.CHUNKED_CONTENT:
|
||||||
_state=STATE_CHUNKED_CONTENT;
|
_state=STATE_CHUNKED_CONTENT;
|
||||||
if (_body==null && _buffers!=null)
|
if (_body==null && _buffers!=null)
|
||||||
_body=_buffers.getBuffer(_contentBufferSize);
|
_body=_buffers.getBuffer();
|
||||||
_handler.headerComplete(); // May recurse here !
|
_handler.headerComplete(); // May recurse here !
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -544,7 +538,7 @@ public class HttpParser implements Parser
|
||||||
_state=STATE_CONTENT;
|
_state=STATE_CONTENT;
|
||||||
if(_forceContentBuffer ||
|
if(_forceContentBuffer ||
|
||||||
(_buffers!=null && _body==null && _buffer==_header && _contentLength>=(_header.capacity()-_header.getIndex())))
|
(_buffers!=null && _body==null && _buffer==_header && _contentLength>=(_header.capacity()-_header.getIndex())))
|
||||||
_body=_buffers.getBuffer(_contentBufferSize);
|
_body=_buffers.getBuffer();
|
||||||
_handler.headerComplete(); // May recurse here !
|
_handler.headerComplete(); // May recurse here !
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -957,7 +951,6 @@ public class HttpParser implements Parser
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (_header!=null)
|
if (_header!=null)
|
||||||
{
|
{
|
||||||
_header.setMarkIndex(-1);
|
_header.setMarkIndex(-1);
|
||||||
|
@ -965,7 +958,6 @@ public class HttpParser implements Parser
|
||||||
{
|
{
|
||||||
_buffers.returnBuffer(_header);
|
_buffers.returnBuffer(_header);
|
||||||
_header=null;
|
_header=null;
|
||||||
_buffer=null;
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -1004,7 +996,7 @@ public class HttpParser implements Parser
|
||||||
{
|
{
|
||||||
if (_header == null)
|
if (_header == null)
|
||||||
{
|
{
|
||||||
_header=_buffers.getBuffer(_headerBufferSize);
|
_header=_buffers.getHeader();
|
||||||
}
|
}
|
||||||
return _header;
|
return _header;
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,6 +26,7 @@ import javax.net.ssl.SSLEngineResult.HandshakeStatus;
|
||||||
|
|
||||||
import org.eclipse.jetty.io.Buffer;
|
import org.eclipse.jetty.io.Buffer;
|
||||||
import org.eclipse.jetty.io.Buffers;
|
import org.eclipse.jetty.io.Buffers;
|
||||||
|
import org.eclipse.jetty.io.nio.DirectNIOBuffer;
|
||||||
import org.eclipse.jetty.io.nio.NIOBuffer;
|
import org.eclipse.jetty.io.nio.NIOBuffer;
|
||||||
import org.eclipse.jetty.io.nio.SelectChannelEndPoint;
|
import org.eclipse.jetty.io.nio.SelectChannelEndPoint;
|
||||||
import org.eclipse.jetty.io.nio.SelectorManager;
|
import org.eclipse.jetty.io.nio.SelectorManager;
|
||||||
|
@ -86,9 +87,9 @@ public class SslSelectChannelEndPoint extends SelectChannelEndPoint
|
||||||
_session=engine.getSession();
|
_session=engine.getSession();
|
||||||
|
|
||||||
// TODO pool buffers and use only when needed.
|
// TODO pool buffers and use only when needed.
|
||||||
_outNIOBuffer=(NIOBuffer)buffers.getBuffer(_session.getPacketBufferSize());
|
_outNIOBuffer=(NIOBuffer)_buffers.getBuffer(_session.getPacketBufferSize());
|
||||||
_outBuffer=_outNIOBuffer.getByteBuffer();
|
_outBuffer=_outNIOBuffer.getByteBuffer();
|
||||||
_inNIOBuffer=(NIOBuffer)buffers.getBuffer(_session.getPacketBufferSize());
|
_inNIOBuffer=(NIOBuffer)_buffers.getBuffer(_session.getPacketBufferSize());
|
||||||
_inBuffer=_inNIOBuffer.getByteBuffer();
|
_inBuffer=_inNIOBuffer.getByteBuffer();
|
||||||
|
|
||||||
// h.append("CONSTRUCTED\n");
|
// h.append("CONSTRUCTED\n");
|
||||||
|
|
|
@ -39,7 +39,7 @@ public class HttpGeneratorClientTest extends TestCase
|
||||||
Buffer bb=new ByteArrayBuffer(8096);
|
Buffer bb=new ByteArrayBuffer(8096);
|
||||||
Buffer sb=new ByteArrayBuffer(1500);
|
Buffer sb=new ByteArrayBuffer(1500);
|
||||||
ByteArrayEndPoint endp = new ByteArrayEndPoint(new byte[0],4096);
|
ByteArrayEndPoint endp = new ByteArrayEndPoint(new byte[0],4096);
|
||||||
HttpGenerator generator = new HttpGenerator(new SimpleBuffers(new Buffer[]{sb,bb}),endp, sb.capacity(), bb.capacity());
|
HttpGenerator generator = new HttpGenerator(new SimpleBuffers(sb,bb),endp);
|
||||||
|
|
||||||
generator.setRequest("GET","/usr");
|
generator.setRequest("GET","/usr");
|
||||||
|
|
||||||
|
@ -67,7 +67,7 @@ public class HttpGeneratorClientTest extends TestCase
|
||||||
Buffer bb=new ByteArrayBuffer(8096);
|
Buffer bb=new ByteArrayBuffer(8096);
|
||||||
Buffer sb=new ByteArrayBuffer(1500);
|
Buffer sb=new ByteArrayBuffer(1500);
|
||||||
ByteArrayEndPoint endp = new ByteArrayEndPoint(new byte[0],4096);
|
ByteArrayEndPoint endp = new ByteArrayEndPoint(new byte[0],4096);
|
||||||
HttpGenerator generator = new HttpGenerator(new SimpleBuffers(new Buffer[]{sb,bb}),endp, sb.capacity(), bb.capacity());
|
HttpGenerator generator = new HttpGenerator(new SimpleBuffers(sb,bb),endp);
|
||||||
|
|
||||||
generator.setRequest("GET","/usr");
|
generator.setRequest("GET","/usr");
|
||||||
|
|
||||||
|
@ -94,7 +94,7 @@ public class HttpGeneratorClientTest extends TestCase
|
||||||
Buffer bb=new ByteArrayBuffer(8096);
|
Buffer bb=new ByteArrayBuffer(8096);
|
||||||
Buffer sb=new ByteArrayBuffer(1500);
|
Buffer sb=new ByteArrayBuffer(1500);
|
||||||
ByteArrayEndPoint endp = new ByteArrayEndPoint(new byte[0],4096);
|
ByteArrayEndPoint endp = new ByteArrayEndPoint(new byte[0],4096);
|
||||||
HttpGenerator generator = new HttpGenerator(new SimpleBuffers(new Buffer[]{sb,bb}),endp, sb.capacity(), bb.capacity());
|
HttpGenerator generator = new HttpGenerator(new SimpleBuffers(sb,bb),endp);
|
||||||
|
|
||||||
generator.setRequest("GET","/usr");
|
generator.setRequest("GET","/usr");
|
||||||
|
|
||||||
|
@ -122,7 +122,7 @@ public class HttpGeneratorClientTest extends TestCase
|
||||||
Buffer sb=new ByteArrayBuffer(1500);
|
Buffer sb=new ByteArrayBuffer(1500);
|
||||||
HttpFields fields = new HttpFields();
|
HttpFields fields = new HttpFields();
|
||||||
ByteArrayEndPoint endp = new ByteArrayEndPoint(new byte[0],4096);
|
ByteArrayEndPoint endp = new ByteArrayEndPoint(new byte[0],4096);
|
||||||
HttpGenerator hb = new HttpGenerator(new SimpleBuffers(new Buffer[]{sb,bb}),endp, sb.capacity(), bb.capacity());
|
HttpGenerator hb = new HttpGenerator(new SimpleBuffers(sb,bb),endp);
|
||||||
Handler handler = new Handler();
|
Handler handler = new Handler();
|
||||||
HttpParser parser=null;
|
HttpParser parser=null;
|
||||||
|
|
||||||
|
|
|
@ -47,7 +47,7 @@ public class HttpGeneratorTest extends TestCase
|
||||||
Buffer sb=new ByteArrayBuffer(1500);
|
Buffer sb=new ByteArrayBuffer(1500);
|
||||||
HttpFields fields = new HttpFields();
|
HttpFields fields = new HttpFields();
|
||||||
ByteArrayEndPoint endp = new ByteArrayEndPoint(new byte[0],4096);
|
ByteArrayEndPoint endp = new ByteArrayEndPoint(new byte[0],4096);
|
||||||
HttpGenerator hb = new HttpGenerator(new SimpleBuffers(new Buffer[]{sb,bb}),endp, sb.capacity(), bb.capacity());
|
HttpGenerator hb = new HttpGenerator(new SimpleBuffers(sb,bb),endp);
|
||||||
Handler handler = new Handler();
|
Handler handler = new Handler();
|
||||||
HttpParser parser=null;
|
HttpParser parser=null;
|
||||||
|
|
||||||
|
|
|
@ -69,10 +69,10 @@ public class HttpParserTest extends TestCase
|
||||||
StringEndPoint io=new StringEndPoint();
|
StringEndPoint io=new StringEndPoint();
|
||||||
io.setInput("POST /foo HTTP/1.0\015\012" + "\015\012");
|
io.setInput("POST /foo HTTP/1.0\015\012" + "\015\012");
|
||||||
ByteArrayBuffer buffer= new ByteArrayBuffer(4096);
|
ByteArrayBuffer buffer= new ByteArrayBuffer(4096);
|
||||||
SimpleBuffers buffers=new SimpleBuffers(new Buffer[]{buffer});
|
SimpleBuffers buffers=new SimpleBuffers(buffer,null);
|
||||||
|
|
||||||
Handler handler = new Handler();
|
Handler handler = new Handler();
|
||||||
HttpParser parser= new HttpParser(buffers,io, handler, buffer.capacity(), 0);
|
HttpParser parser= new HttpParser(buffers,io, handler);
|
||||||
parser.parse();
|
parser.parse();
|
||||||
assertEquals("POST", f0);
|
assertEquals("POST", f0);
|
||||||
assertEquals("/foo", f1);
|
assertEquals("/foo", f1);
|
||||||
|
@ -86,11 +86,11 @@ public class HttpParserTest extends TestCase
|
||||||
StringEndPoint io=new StringEndPoint();
|
StringEndPoint io=new StringEndPoint();
|
||||||
io.setInput("GET /999\015\012");
|
io.setInput("GET /999\015\012");
|
||||||
ByteArrayBuffer buffer= new ByteArrayBuffer(4096);
|
ByteArrayBuffer buffer= new ByteArrayBuffer(4096);
|
||||||
SimpleBuffers buffers=new SimpleBuffers(new Buffer[]{buffer});
|
SimpleBuffers buffers=new SimpleBuffers(buffer,null);
|
||||||
|
|
||||||
f2= null;
|
f2= null;
|
||||||
Handler handler = new Handler();
|
Handler handler = new Handler();
|
||||||
HttpParser parser= new HttpParser(buffers,io, handler, buffer.capacity(), 0);
|
HttpParser parser= new HttpParser(buffers,io, handler);
|
||||||
parser.parse();
|
parser.parse();
|
||||||
assertEquals("GET", f0);
|
assertEquals("GET", f0);
|
||||||
assertEquals("/999", f1);
|
assertEquals("/999", f1);
|
||||||
|
@ -104,11 +104,11 @@ public class HttpParserTest extends TestCase
|
||||||
StringEndPoint io=new StringEndPoint();
|
StringEndPoint io=new StringEndPoint();
|
||||||
io.setInput("POST /222 \015\012");
|
io.setInput("POST /222 \015\012");
|
||||||
ByteArrayBuffer buffer= new ByteArrayBuffer(4096);
|
ByteArrayBuffer buffer= new ByteArrayBuffer(4096);
|
||||||
SimpleBuffers buffers=new SimpleBuffers(new Buffer[]{buffer});
|
SimpleBuffers buffers=new SimpleBuffers(buffer,null);
|
||||||
|
|
||||||
f2= null;
|
f2= null;
|
||||||
Handler handler = new Handler();
|
Handler handler = new Handler();
|
||||||
HttpParser parser= new HttpParser(buffers,io, handler, buffer.capacity(), 0);
|
HttpParser parser= new HttpParser(buffers,io, handler);
|
||||||
parser.parse();
|
parser.parse();
|
||||||
assertEquals("POST", f0);
|
assertEquals("POST", f0);
|
||||||
assertEquals("/222", f1);
|
assertEquals("/222", f1);
|
||||||
|
@ -122,10 +122,10 @@ public class HttpParserTest extends TestCase
|
||||||
StringEndPoint io=new StringEndPoint();
|
StringEndPoint io=new StringEndPoint();
|
||||||
io.setInput("POST /fo\u0690 HTTP/1.0\015\012" + "\015\012");
|
io.setInput("POST /fo\u0690 HTTP/1.0\015\012" + "\015\012");
|
||||||
ByteArrayBuffer buffer= new ByteArrayBuffer(4096);
|
ByteArrayBuffer buffer= new ByteArrayBuffer(4096);
|
||||||
SimpleBuffers buffers=new SimpleBuffers(new Buffer[]{buffer});
|
SimpleBuffers buffers=new SimpleBuffers(buffer,null);
|
||||||
|
|
||||||
Handler handler = new Handler();
|
Handler handler = new Handler();
|
||||||
HttpParser parser= new HttpParser(buffers,io, handler, buffer.capacity(), 0);
|
HttpParser parser= new HttpParser(buffers,io, handler);
|
||||||
parser.parse();
|
parser.parse();
|
||||||
assertEquals("POST", f0);
|
assertEquals("POST", f0);
|
||||||
assertEquals("/fo\u0690", f1);
|
assertEquals("/fo\u0690", f1);
|
||||||
|
@ -139,10 +139,10 @@ public class HttpParserTest extends TestCase
|
||||||
StringEndPoint io=new StringEndPoint();
|
StringEndPoint io=new StringEndPoint();
|
||||||
io.setInput("POST /foo?param=\u0690 HTTP/1.0\015\012" + "\015\012");
|
io.setInput("POST /foo?param=\u0690 HTTP/1.0\015\012" + "\015\012");
|
||||||
ByteArrayBuffer buffer= new ByteArrayBuffer(4096);
|
ByteArrayBuffer buffer= new ByteArrayBuffer(4096);
|
||||||
SimpleBuffers buffers=new SimpleBuffers(new Buffer[]{buffer});
|
SimpleBuffers buffers=new SimpleBuffers(buffer,null);
|
||||||
|
|
||||||
Handler handler = new Handler();
|
Handler handler = new Handler();
|
||||||
HttpParser parser= new HttpParser(buffers,io, handler, buffer.capacity(), 0);
|
HttpParser parser= new HttpParser(buffers,io, handler);
|
||||||
parser.parse();
|
parser.parse();
|
||||||
assertEquals("POST", f0);
|
assertEquals("POST", f0);
|
||||||
assertEquals("/foo?param=\u0690", f1);
|
assertEquals("/foo?param=\u0690", f1);
|
||||||
|
@ -156,10 +156,10 @@ public class HttpParserTest extends TestCase
|
||||||
StringEndPoint io=new StringEndPoint();
|
StringEndPoint io=new StringEndPoint();
|
||||||
io.setInput("CONNECT 192.168.1.2:80 HTTP/1.1\015\012" + "\015\012");
|
io.setInput("CONNECT 192.168.1.2:80 HTTP/1.1\015\012" + "\015\012");
|
||||||
ByteArrayBuffer buffer= new ByteArrayBuffer(4096);
|
ByteArrayBuffer buffer= new ByteArrayBuffer(4096);
|
||||||
SimpleBuffers buffers=new SimpleBuffers(new Buffer[]{buffer});
|
SimpleBuffers buffers=new SimpleBuffers(buffer,null);
|
||||||
|
|
||||||
Handler handler = new Handler();
|
Handler handler = new Handler();
|
||||||
HttpParser parser= new HttpParser(buffers,io, handler, buffer.capacity(), 0);
|
HttpParser parser= new HttpParser(buffers,io, handler);
|
||||||
parser.parse();
|
parser.parse();
|
||||||
assertTrue(handler.request);
|
assertTrue(handler.request);
|
||||||
assertEquals("CONNECT", f0);
|
assertEquals("CONNECT", f0);
|
||||||
|
@ -184,10 +184,10 @@ public class HttpParserTest extends TestCase
|
||||||
+ "Server5: notServer\015\012"
|
+ "Server5: notServer\015\012"
|
||||||
+ "\015\012");
|
+ "\015\012");
|
||||||
ByteArrayBuffer buffer= new ByteArrayBuffer(4096);
|
ByteArrayBuffer buffer= new ByteArrayBuffer(4096);
|
||||||
SimpleBuffers buffers=new SimpleBuffers(new Buffer[]{buffer});
|
SimpleBuffers buffers=new SimpleBuffers(buffer,null);
|
||||||
|
|
||||||
Handler handler = new Handler();
|
Handler handler = new Handler();
|
||||||
HttpParser parser= new HttpParser(buffers,io, handler, buffer.capacity(), 0);
|
HttpParser parser= new HttpParser(buffers,io, handler);
|
||||||
parser.parse();
|
parser.parse();
|
||||||
assertEquals("GET", f0);
|
assertEquals("GET", f0);
|
||||||
assertEquals("/", f1);
|
assertEquals("/", f1);
|
||||||
|
@ -223,10 +223,10 @@ public class HttpParserTest extends TestCase
|
||||||
+ "0\015\012");
|
+ "0\015\012");
|
||||||
ByteArrayBuffer buffer= new ByteArrayBuffer(4096);
|
ByteArrayBuffer buffer= new ByteArrayBuffer(4096);
|
||||||
ByteArrayBuffer content=new ByteArrayBuffer(8192);
|
ByteArrayBuffer content=new ByteArrayBuffer(8192);
|
||||||
SimpleBuffers buffers=new SimpleBuffers(new Buffer[]{buffer,content});
|
SimpleBuffers buffers=new SimpleBuffers(buffer,content);
|
||||||
|
|
||||||
Handler handler = new Handler();
|
Handler handler = new Handler();
|
||||||
HttpParser parser= new HttpParser(buffers,io, handler, buffer.capacity(), content.capacity());
|
HttpParser parser= new HttpParser(buffers,io, handler);
|
||||||
parser.parse();
|
parser.parse();
|
||||||
assertEquals("GET", f0);
|
assertEquals("GET", f0);
|
||||||
assertEquals("/chunk", f1);
|
assertEquals("/chunk", f1);
|
||||||
|
@ -263,10 +263,10 @@ public class HttpParserTest extends TestCase
|
||||||
|
|
||||||
ByteArrayBuffer buffer= new ByteArrayBuffer(4096);
|
ByteArrayBuffer buffer= new ByteArrayBuffer(4096);
|
||||||
ByteArrayBuffer content=new ByteArrayBuffer(8192);
|
ByteArrayBuffer content=new ByteArrayBuffer(8192);
|
||||||
SimpleBuffers buffers=new SimpleBuffers(new Buffer[]{buffer,content});
|
SimpleBuffers buffers=new SimpleBuffers(buffer,content);
|
||||||
|
|
||||||
Handler handler = new Handler();
|
Handler handler = new Handler();
|
||||||
HttpParser parser= new HttpParser(buffers,io, handler, buffer.capacity(), content.capacity());
|
HttpParser parser= new HttpParser(buffers,io, handler);
|
||||||
parser.parse();
|
parser.parse();
|
||||||
assertEquals("GET", f0);
|
assertEquals("GET", f0);
|
||||||
assertEquals("/mp", f1);
|
assertEquals("/mp", f1);
|
||||||
|
@ -341,10 +341,10 @@ public class HttpParserTest extends TestCase
|
||||||
{
|
{
|
||||||
ByteArrayBuffer buffer= new ByteArrayBuffer(tests[t]);
|
ByteArrayBuffer buffer= new ByteArrayBuffer(tests[t]);
|
||||||
ByteArrayBuffer content=new ByteArrayBuffer(8192);
|
ByteArrayBuffer content=new ByteArrayBuffer(8192);
|
||||||
SimpleBuffers buffers=new SimpleBuffers(new Buffer[]{buffer,content});
|
SimpleBuffers buffers=new SimpleBuffers(buffer,content);
|
||||||
|
|
||||||
Handler handler = new Handler();
|
Handler handler = new Handler();
|
||||||
HttpParser parser= new HttpParser(buffers,io, handler, buffer.capacity(), content.capacity());
|
HttpParser parser= new HttpParser(buffers,io, handler);
|
||||||
|
|
||||||
|
|
||||||
io.setInput(http);
|
io.setInput(http);
|
||||||
|
@ -396,10 +396,10 @@ public class HttpParserTest extends TestCase
|
||||||
+ "\015\012"
|
+ "\015\012"
|
||||||
+ "0123456789\015\012");
|
+ "0123456789\015\012");
|
||||||
ByteArrayBuffer buffer= new ByteArrayBuffer(4096);
|
ByteArrayBuffer buffer= new ByteArrayBuffer(4096);
|
||||||
SimpleBuffers buffers=new SimpleBuffers(new Buffer[]{buffer});
|
SimpleBuffers buffers=new SimpleBuffers(buffer,null);
|
||||||
|
|
||||||
Handler handler = new Handler();
|
Handler handler = new Handler();
|
||||||
HttpParser parser= new HttpParser(buffers,io, handler, buffer.capacity(), 0);
|
HttpParser parser= new HttpParser(buffers,io, handler);
|
||||||
parser.parse();
|
parser.parse();
|
||||||
assertEquals("HTTP/1.1", f0);
|
assertEquals("HTTP/1.1", f0);
|
||||||
assertEquals("200", f1);
|
assertEquals("200", f1);
|
||||||
|
@ -418,10 +418,10 @@ public class HttpParserTest extends TestCase
|
||||||
+ "Connection: close\015\012"
|
+ "Connection: close\015\012"
|
||||||
+ "\015\012");
|
+ "\015\012");
|
||||||
ByteArrayBuffer buffer= new ByteArrayBuffer(4096);
|
ByteArrayBuffer buffer= new ByteArrayBuffer(4096);
|
||||||
SimpleBuffers buffers=new SimpleBuffers(new Buffer[]{buffer});
|
SimpleBuffers buffers=new SimpleBuffers(buffer,null);
|
||||||
|
|
||||||
Handler handler = new Handler();
|
Handler handler = new Handler();
|
||||||
HttpParser parser= new HttpParser(buffers,io, handler, buffer.capacity(), 0);
|
HttpParser parser= new HttpParser(buffers,io, handler);
|
||||||
parser.parse();
|
parser.parse();
|
||||||
assertEquals("HTTP/1.1", f0);
|
assertEquals("HTTP/1.1", f0);
|
||||||
assertEquals("304", f1);
|
assertEquals("304", f1);
|
||||||
|
@ -444,10 +444,10 @@ public class HttpParserTest extends TestCase
|
||||||
+ "\015\012"
|
+ "\015\012"
|
||||||
+ "0123456789\015\012");
|
+ "0123456789\015\012");
|
||||||
ByteArrayBuffer buffer= new ByteArrayBuffer(4096);
|
ByteArrayBuffer buffer= new ByteArrayBuffer(4096);
|
||||||
SimpleBuffers buffers=new SimpleBuffers(new Buffer[]{buffer});
|
SimpleBuffers buffers=new SimpleBuffers(buffer,null);
|
||||||
|
|
||||||
Handler handler = new Handler();
|
Handler handler = new Handler();
|
||||||
HttpParser parser= new HttpParser(buffers,io, handler, buffer.capacity(), 0);
|
HttpParser parser= new HttpParser(buffers,io, handler);
|
||||||
parser.parse();
|
parser.parse();
|
||||||
assertEquals("HTTP/1.1", f0);
|
assertEquals("HTTP/1.1", f0);
|
||||||
assertEquals("204", f1);
|
assertEquals("204", f1);
|
||||||
|
|
|
@ -1,191 +0,0 @@
|
||||||
// ========================================================================
|
|
||||||
// Copyright (c) 2004-2009 Mort Bay Consulting Pty. Ltd.
|
|
||||||
// ------------------------------------------------------------------------
|
|
||||||
// All rights reserved. This program and the accompanying materials
|
|
||||||
// are made available under the terms of the Eclipse Public License v1.0
|
|
||||||
// and Apache License v2.0 which accompanies this distribution.
|
|
||||||
// The Eclipse Public License is available at
|
|
||||||
// http://www.eclipse.org/legal/epl-v10.html
|
|
||||||
// The Apache License v2.0 is available at
|
|
||||||
// http://www.opensource.org/licenses/apache2.0.php
|
|
||||||
// You may elect to redistribute this code under either of these licenses.
|
|
||||||
// ========================================================================
|
|
||||||
|
|
||||||
package org.eclipse.jetty.io;
|
|
||||||
|
|
||||||
import org.eclipse.jetty.util.component.AbstractLifeCycle;
|
|
||||||
|
|
||||||
/* ------------------------------------------------------------ */
|
|
||||||
/** Abstract Buffer pool.
|
|
||||||
* simple unbounded pool of buffers for header, request and response sizes.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public abstract class AbstractBuffers extends AbstractLifeCycle implements Buffers
|
|
||||||
{
|
|
||||||
private int _headerBufferSize=6*1024;
|
|
||||||
private int _requestBufferSize=8*1024;
|
|
||||||
private int _responseBufferSize=12*1024;
|
|
||||||
|
|
||||||
final static private int __HEADER=0;
|
|
||||||
final static private int __REQUEST=1;
|
|
||||||
final static private int __RESPONSE=2;
|
|
||||||
final static private int __OTHER=3;
|
|
||||||
final private int[] _pool={2,1,1,1};
|
|
||||||
|
|
||||||
private final ThreadLocal _buffers=new ThreadLocal()
|
|
||||||
{
|
|
||||||
protected Object initialValue()
|
|
||||||
{
|
|
||||||
return new ThreadBuffers(_pool[__HEADER],_pool[__REQUEST],_pool[__RESPONSE],_pool[__OTHER]);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
public AbstractBuffers()
|
|
||||||
{
|
|
||||||
super();
|
|
||||||
}
|
|
||||||
|
|
||||||
public Buffer getBuffer(final int size )
|
|
||||||
{
|
|
||||||
final int set = (size==_headerBufferSize)?__HEADER
|
|
||||||
:(size==_responseBufferSize)?__RESPONSE
|
|
||||||
:(size==_requestBufferSize)?__REQUEST:__OTHER;
|
|
||||||
|
|
||||||
final ThreadBuffers thread_buffers = (ThreadBuffers)_buffers.get();
|
|
||||||
|
|
||||||
final Buffer[] buffers=thread_buffers._buffers[set];
|
|
||||||
for (int i=0;i<buffers.length;i++)
|
|
||||||
{
|
|
||||||
final Buffer b=buffers[i];
|
|
||||||
if (b!=null && b.capacity()==size)
|
|
||||||
{
|
|
||||||
buffers[i]=null;
|
|
||||||
return b;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return newBuffer(size);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void returnBuffer( Buffer buffer )
|
|
||||||
{
|
|
||||||
buffer.clear();
|
|
||||||
if (buffer.isVolatile() || buffer.isImmutable())
|
|
||||||
return;
|
|
||||||
|
|
||||||
int size=buffer.capacity();
|
|
||||||
final int set = (size==_headerBufferSize)?__HEADER
|
|
||||||
:(size==_responseBufferSize)?__RESPONSE
|
|
||||||
:(size==_requestBufferSize)?__REQUEST:__OTHER;
|
|
||||||
|
|
||||||
final ThreadBuffers thread_buffers = (ThreadBuffers)_buffers.get();
|
|
||||||
final Buffer[] buffers=thread_buffers._buffers[set];
|
|
||||||
for (int i=0;i<buffers.length;i++)
|
|
||||||
{
|
|
||||||
if (buffers[i]==null)
|
|
||||||
{
|
|
||||||
buffers[i]=buffer;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void doStart()
|
|
||||||
throws Exception
|
|
||||||
{
|
|
||||||
super.doStart();
|
|
||||||
if (_headerBufferSize==_requestBufferSize && _headerBufferSize==_responseBufferSize)
|
|
||||||
{
|
|
||||||
_pool[__HEADER]+=_pool[__REQUEST]+_pool[__RESPONSE];
|
|
||||||
_pool[__REQUEST]=0;
|
|
||||||
_pool[__RESPONSE]=0;
|
|
||||||
}
|
|
||||||
else if (_headerBufferSize==_requestBufferSize)
|
|
||||||
{
|
|
||||||
_pool[__HEADER]+=_pool[__REQUEST];
|
|
||||||
_pool[__REQUEST]=0;
|
|
||||||
}
|
|
||||||
else if (_headerBufferSize==_responseBufferSize)
|
|
||||||
{
|
|
||||||
_pool[__HEADER]+=_pool[__RESPONSE];
|
|
||||||
_pool[__RESPONSE]=0;
|
|
||||||
}
|
|
||||||
else if (_requestBufferSize==_responseBufferSize)
|
|
||||||
{
|
|
||||||
_pool[__RESPONSE]+=_pool[__REQUEST];
|
|
||||||
_pool[__REQUEST]=0;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return Returns the headerBufferSize.
|
|
||||||
*/
|
|
||||||
public int getHeaderBufferSize()
|
|
||||||
{
|
|
||||||
return _headerBufferSize;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param headerBufferSize The headerBufferSize to set.
|
|
||||||
*/
|
|
||||||
public void setHeaderBufferSize( int headerBufferSize )
|
|
||||||
{
|
|
||||||
if (isStarted())
|
|
||||||
throw new IllegalStateException();
|
|
||||||
_headerBufferSize = headerBufferSize;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return Returns the requestBufferSize.
|
|
||||||
*/
|
|
||||||
public int getRequestBufferSize()
|
|
||||||
{
|
|
||||||
return _requestBufferSize;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param requestBufferSize The requestBufferSize to set.
|
|
||||||
*/
|
|
||||||
public void setRequestBufferSize( int requestBufferSize )
|
|
||||||
{
|
|
||||||
if (isStarted())
|
|
||||||
throw new IllegalStateException();
|
|
||||||
_requestBufferSize = requestBufferSize;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return Returns the responseBufferSize.
|
|
||||||
*/
|
|
||||||
public int getResponseBufferSize()
|
|
||||||
{
|
|
||||||
return _responseBufferSize;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param responseBufferSize The responseBufferSize to set.
|
|
||||||
*/
|
|
||||||
public void setResponseBufferSize( int responseBufferSize )
|
|
||||||
{
|
|
||||||
if (isStarted())
|
|
||||||
throw new IllegalStateException();
|
|
||||||
_responseBufferSize = responseBufferSize;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected abstract Buffer newBuffer( int size );
|
|
||||||
|
|
||||||
protected static class ThreadBuffers
|
|
||||||
{
|
|
||||||
final Buffer[][] _buffers;
|
|
||||||
ThreadBuffers(int headers,int requests,int responses,int others)
|
|
||||||
{
|
|
||||||
_buffers = new Buffer[4][];
|
|
||||||
_buffers[__HEADER]=new Buffer[headers];
|
|
||||||
_buffers[__REQUEST]=new Buffer[requests];
|
|
||||||
_buffers[__RESPONSE]=new Buffer[responses];
|
|
||||||
_buffers[__OTHER]=new Buffer[others];
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -20,11 +20,12 @@ package org.eclipse.jetty.io;
|
||||||
* of specific types of buffers (eg NIO). The concept of big and little buffers
|
* of specific types of buffers (eg NIO). The concept of big and little buffers
|
||||||
* is supported, but these terms have no absolute meaning and must be determined by context.
|
* is supported, but these terms have no absolute meaning and must be determined by context.
|
||||||
*
|
*
|
||||||
*
|
|
||||||
*
|
|
||||||
*/
|
*/
|
||||||
public interface Buffers
|
public interface Buffers
|
||||||
{
|
{
|
||||||
public Buffer getBuffer(int size);
|
Buffer getHeader();
|
||||||
public void returnBuffer(Buffer buffer);
|
Buffer getBuffer();
|
||||||
|
Buffer getBuffer(int size);
|
||||||
|
|
||||||
|
void returnBuffer(Buffer buffer);
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,52 +21,90 @@ package org.eclipse.jetty.io;
|
||||||
*/
|
*/
|
||||||
public class SimpleBuffers implements Buffers
|
public class SimpleBuffers implements Buffers
|
||||||
{
|
{
|
||||||
Buffer[] _buffers;
|
final Buffer _header;
|
||||||
|
final Buffer _buffer;
|
||||||
|
boolean _headerOut;
|
||||||
|
boolean _bufferOut;
|
||||||
|
|
||||||
/* ------------------------------------------------------------ */
|
/* ------------------------------------------------------------ */
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
public SimpleBuffers(Buffer[] buffers)
|
public SimpleBuffers(Buffer header, Buffer buffer)
|
||||||
{
|
{
|
||||||
_buffers=buffers;
|
_header=header;
|
||||||
|
_buffer=buffer;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ------------------------------------------------------------ */
|
||||||
|
public Buffer getBuffer()
|
||||||
|
{
|
||||||
|
synchronized(this)
|
||||||
|
{
|
||||||
|
if (_buffer!=null && !_bufferOut)
|
||||||
|
{
|
||||||
|
_bufferOut=true;
|
||||||
|
return _buffer;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (_buffer!=null && _header!=null && _header.capacity()==_buffer.capacity() && !_headerOut)
|
||||||
|
{
|
||||||
|
_headerOut=true;
|
||||||
|
return _header;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (_buffer!=null)
|
||||||
|
return new ByteArrayBuffer(_buffer.capacity());
|
||||||
|
return new ByteArrayBuffer(4096);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ------------------------------------------------------------ */
|
||||||
|
public Buffer getHeader()
|
||||||
|
{
|
||||||
|
synchronized(this)
|
||||||
|
{
|
||||||
|
if (_header!=null && !_headerOut)
|
||||||
|
{
|
||||||
|
_headerOut=true;
|
||||||
|
return _header;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (_buffer!=null && _header!=null && _header.capacity()==_buffer.capacity() && !_bufferOut)
|
||||||
|
{
|
||||||
|
_bufferOut=true;
|
||||||
|
return _buffer;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (_header!=null)
|
||||||
|
return new ByteArrayBuffer(_header.capacity());
|
||||||
|
return new ByteArrayBuffer(4096);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ------------------------------------------------------------ */
|
/* ------------------------------------------------------------ */
|
||||||
/*
|
|
||||||
* @see org.eclipse.io.Buffers#getBuffer(boolean)
|
|
||||||
*/
|
|
||||||
public Buffer getBuffer(int size)
|
public Buffer getBuffer(int size)
|
||||||
{
|
{
|
||||||
if (_buffers!=null)
|
synchronized(this)
|
||||||
{
|
{
|
||||||
for (int i=0;i<_buffers.length;i++)
|
if (_header!=null && _header.capacity()==size)
|
||||||
{
|
return getHeader();
|
||||||
if (_buffers[i]!=null && _buffers[i].capacity()==size)
|
if (_buffer!=null && _buffer.capacity()==size)
|
||||||
{
|
return getBuffer();
|
||||||
Buffer b=_buffers[i];
|
return null;
|
||||||
_buffers[i]=null;
|
|
||||||
return b;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return new ByteArrayBuffer(size);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ------------------------------------------------------------ */
|
/* ------------------------------------------------------------ */
|
||||||
/*
|
|
||||||
* @see org.eclipse.io.Buffers#returnBuffer(org.eclipse.io.Buffer)
|
|
||||||
*/
|
|
||||||
public void returnBuffer(Buffer buffer)
|
public void returnBuffer(Buffer buffer)
|
||||||
{
|
{
|
||||||
buffer.clear();
|
synchronized(this)
|
||||||
if (_buffers!=null)
|
|
||||||
{
|
{
|
||||||
for (int i=0;i<_buffers.length;i++)
|
buffer.clear();
|
||||||
{
|
if (buffer==_header)
|
||||||
if (_buffers[i]==null)
|
_headerOut=false;
|
||||||
_buffers[i]=buffer;
|
if (buffer==_buffer)
|
||||||
}
|
_bufferOut=false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,157 @@
|
||||||
|
// ========================================================================
|
||||||
|
// Copyright (c) 2004-2009 Mort Bay Consulting Pty. Ltd.
|
||||||
|
// ------------------------------------------------------------------------
|
||||||
|
// All rights reserved. This program and the accompanying materials
|
||||||
|
// are made available under the terms of the Eclipse Public License v1.0
|
||||||
|
// and Apache License v2.0 which accompanies this distribution.
|
||||||
|
// The Eclipse Public License is available at
|
||||||
|
// http://www.eclipse.org/legal/epl-v10.html
|
||||||
|
// The Apache License v2.0 is available at
|
||||||
|
// http://www.opensource.org/licenses/apache2.0.php
|
||||||
|
// You may elect to redistribute this code under either of these licenses.
|
||||||
|
// ========================================================================
|
||||||
|
|
||||||
|
package org.eclipse.jetty.io;
|
||||||
|
|
||||||
|
import org.eclipse.jetty.util.component.AbstractLifeCycle;
|
||||||
|
|
||||||
|
/* ------------------------------------------------------------ */
|
||||||
|
/** Abstract Buffer pool.
|
||||||
|
* simple unbounded pool of buffers for header, request and response sizes.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public abstract class ThreadLocalBuffers implements Buffers
|
||||||
|
{
|
||||||
|
private int _bufferSize=12*1024;
|
||||||
|
private int _headerSize=6*1024;
|
||||||
|
|
||||||
|
private final ThreadLocal<ThreadBuffers> _buffers=new ThreadLocal<ThreadBuffers>()
|
||||||
|
{
|
||||||
|
protected ThreadBuffers initialValue()
|
||||||
|
{
|
||||||
|
return new ThreadBuffers();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
public Buffer getBuffer()
|
||||||
|
{
|
||||||
|
ThreadBuffers buffers = (ThreadBuffers)_buffers.get();
|
||||||
|
if (buffers._buffer!=null)
|
||||||
|
{
|
||||||
|
Buffer b=buffers._buffer;
|
||||||
|
buffers._buffer=null;
|
||||||
|
return b;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (buffers._other!=null && buffers._other.capacity()==_bufferSize)
|
||||||
|
{
|
||||||
|
Buffer b=buffers._other;
|
||||||
|
buffers._other=null;
|
||||||
|
return b;
|
||||||
|
}
|
||||||
|
|
||||||
|
return newBuffer(_bufferSize);
|
||||||
|
}
|
||||||
|
|
||||||
|
public Buffer getHeader()
|
||||||
|
{
|
||||||
|
ThreadBuffers buffers = (ThreadBuffers)_buffers.get();
|
||||||
|
if (buffers._header!=null)
|
||||||
|
{
|
||||||
|
Buffer b=buffers._header;
|
||||||
|
buffers._header=null;
|
||||||
|
return b;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (buffers._other!=null && buffers._other.capacity()==_headerSize)
|
||||||
|
{
|
||||||
|
Buffer b=buffers._other;
|
||||||
|
buffers._other=null;
|
||||||
|
return b;
|
||||||
|
}
|
||||||
|
|
||||||
|
return newHeader(_headerSize);
|
||||||
|
}
|
||||||
|
|
||||||
|
public Buffer getBuffer(int size)
|
||||||
|
{
|
||||||
|
ThreadBuffers buffers = (ThreadBuffers)_buffers.get();
|
||||||
|
if (buffers._other!=null && buffers._other.capacity()==size)
|
||||||
|
{
|
||||||
|
Buffer b=buffers._other;
|
||||||
|
buffers._other=null;
|
||||||
|
return b;
|
||||||
|
}
|
||||||
|
|
||||||
|
return newBuffer(size);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void returnBuffer(Buffer buffer)
|
||||||
|
{
|
||||||
|
buffer.clear();
|
||||||
|
if (buffer.isVolatile() || buffer.isImmutable())
|
||||||
|
return;
|
||||||
|
|
||||||
|
int size=buffer.capacity();
|
||||||
|
|
||||||
|
ThreadBuffers buffers = (ThreadBuffers)_buffers.get();
|
||||||
|
|
||||||
|
if (size==_bufferSize && buffers._buffer==null)
|
||||||
|
{
|
||||||
|
buffers._buffer=buffer;
|
||||||
|
}
|
||||||
|
else if (size==_headerSize && buffers._header==null)
|
||||||
|
{
|
||||||
|
buffers._header=buffer;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
buffers._other=buffer;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return Returns the buffer size in bytes.
|
||||||
|
*/
|
||||||
|
public int getBufferSize()
|
||||||
|
{
|
||||||
|
return _bufferSize;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return Returns the header size in bytes.
|
||||||
|
*/
|
||||||
|
public int getHeaderSize()
|
||||||
|
{
|
||||||
|
return _headerSize;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected abstract Buffer newBuffer(int size);
|
||||||
|
|
||||||
|
protected abstract Buffer newHeader(int size);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param size The buffer size in bytes
|
||||||
|
*/
|
||||||
|
public void setBufferSize( int size )
|
||||||
|
{
|
||||||
|
_bufferSize = size;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param size The header size in bytes
|
||||||
|
*/
|
||||||
|
public void setHeaderSize( int size )
|
||||||
|
{
|
||||||
|
_headerSize = size;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected static class ThreadBuffers
|
||||||
|
{
|
||||||
|
Buffer _buffer;
|
||||||
|
Buffer _header;
|
||||||
|
Buffer _other;
|
||||||
|
}
|
||||||
|
}
|
|
@ -23,7 +23,6 @@ import org.eclipse.jetty.io.AsyncEndPoint;
|
||||||
import org.eclipse.jetty.io.Buffer;
|
import org.eclipse.jetty.io.Buffer;
|
||||||
import org.eclipse.jetty.io.Connection;
|
import org.eclipse.jetty.io.Connection;
|
||||||
import org.eclipse.jetty.io.EofException;
|
import org.eclipse.jetty.io.EofException;
|
||||||
import org.eclipse.jetty.io.HttpException;
|
|
||||||
import org.eclipse.jetty.io.nio.SelectorManager.SelectSet;
|
import org.eclipse.jetty.io.nio.SelectorManager.SelectSet;
|
||||||
import org.eclipse.jetty.util.log.Log;
|
import org.eclipse.jetty.util.log.Log;
|
||||||
import org.eclipse.jetty.util.thread.Timeout;
|
import org.eclipse.jetty.util.thread.Timeout;
|
||||||
|
@ -432,9 +431,10 @@ public class SelectChannelEndPoint extends ChannelEndPoint implements Runnable,
|
||||||
try{close();}
|
try{close();}
|
||||||
catch(IOException e2){Log.ignore(e2);}
|
catch(IOException e2){Log.ignore(e2);}
|
||||||
}
|
}
|
||||||
catch (HttpException e)
|
catch (IOException e)
|
||||||
{
|
{
|
||||||
Log.debug("BAD", e);
|
Log.warn(e.toString());
|
||||||
|
Log.debug(e);
|
||||||
try{close();}
|
try{close();}
|
||||||
catch(IOException e2){Log.ignore(e2);}
|
catch(IOException e2){Log.ignore(e2);}
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,13 +20,13 @@ import java.util.concurrent.atomic.AtomicLong;
|
||||||
|
|
||||||
import junit.framework.TestCase;
|
import junit.framework.TestCase;
|
||||||
|
|
||||||
public class AbstractBuffersTest
|
public class ThreadLocalBuffersTest
|
||||||
extends TestCase
|
extends TestCase
|
||||||
{
|
{
|
||||||
public boolean _stress = Boolean.getBoolean("STRESS");
|
public boolean _stress = Boolean.getBoolean("STRESS");
|
||||||
private int _headerBufferSize = 6 * 1024;
|
private int _headerBufferSize = 6 * 1024;
|
||||||
|
|
||||||
InnerAbstractBuffers buffers;
|
InnerBuffers httpBuffers;
|
||||||
|
|
||||||
List<Thread> threadList = new ArrayList<Thread>();
|
List<Thread> threadList = new ArrayList<Thread>();
|
||||||
|
|
||||||
|
@ -63,7 +63,7 @@ public class AbstractBuffersTest
|
||||||
{
|
{
|
||||||
threadList.clear();
|
threadList.clear();
|
||||||
buffersRetrieved = new AtomicLong( 0 );
|
buffersRetrieved = new AtomicLong( 0 );
|
||||||
buffers = new InnerAbstractBuffers();
|
httpBuffers = new InnerBuffers();
|
||||||
|
|
||||||
for ( int i = 0; i < numThreads; ++i )
|
for ( int i = 0; i < numThreads; ++i )
|
||||||
{
|
{
|
||||||
|
@ -115,11 +115,16 @@ public class AbstractBuffersTest
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
class InnerAbstractBuffers
|
class InnerBuffers extends ThreadLocalBuffers
|
||||||
extends AbstractBuffers
|
|
||||||
{
|
{
|
||||||
|
@Override
|
||||||
|
protected Buffer newBuffer(int size)
|
||||||
|
{
|
||||||
|
return new ByteArrayBuffer( size );
|
||||||
|
}
|
||||||
|
|
||||||
public Buffer newBuffer( int size )
|
@Override
|
||||||
|
protected Buffer newHeader(int size)
|
||||||
{
|
{
|
||||||
return new ByteArrayBuffer( size );
|
return new ByteArrayBuffer( size );
|
||||||
}
|
}
|
||||||
|
@ -153,7 +158,7 @@ public class AbstractBuffersTest
|
||||||
|
|
||||||
if ( runTest )
|
if ( runTest )
|
||||||
{
|
{
|
||||||
Buffer buf = buffers.getBuffer( _headerBufferSize );
|
Buffer buf = httpBuffers.getHeader();
|
||||||
|
|
||||||
buffersRetrieved.getAndIncrement();
|
buffersRetrieved.getAndIncrement();
|
||||||
|
|
||||||
|
@ -162,7 +167,7 @@ public class AbstractBuffersTest
|
||||||
|
|
||||||
// sleep( threadWaitTime );
|
// sleep( threadWaitTime );
|
||||||
|
|
||||||
buffers.returnBuffer( buf );
|
httpBuffers.returnBuffer(buf);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
|
@ -20,10 +20,12 @@ import java.net.UnknownHostException;
|
||||||
|
|
||||||
import javax.servlet.ServletRequest;
|
import javax.servlet.ServletRequest;
|
||||||
|
|
||||||
|
import org.eclipse.jetty.http.HttpBuffers;
|
||||||
import org.eclipse.jetty.http.HttpFields;
|
import org.eclipse.jetty.http.HttpFields;
|
||||||
import org.eclipse.jetty.http.HttpHeaders;
|
import org.eclipse.jetty.http.HttpHeaders;
|
||||||
import org.eclipse.jetty.http.HttpSchemes;
|
import org.eclipse.jetty.http.HttpSchemes;
|
||||||
import org.eclipse.jetty.io.AbstractBuffers;
|
import org.eclipse.jetty.io.Buffer;
|
||||||
|
import org.eclipse.jetty.io.ByteArrayBuffer;
|
||||||
import org.eclipse.jetty.io.EndPoint;
|
import org.eclipse.jetty.io.EndPoint;
|
||||||
import org.eclipse.jetty.io.EofException;
|
import org.eclipse.jetty.io.EofException;
|
||||||
import org.eclipse.jetty.util.component.LifeCycle;
|
import org.eclipse.jetty.util.component.LifeCycle;
|
||||||
|
@ -43,7 +45,7 @@ import org.eclipse.jetty.util.thread.ThreadPool;
|
||||||
*
|
*
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
public abstract class AbstractConnector extends AbstractBuffers implements Connector
|
public abstract class AbstractConnector extends HttpBuffers implements Connector
|
||||||
{
|
{
|
||||||
private String _name;
|
private String _name;
|
||||||
|
|
||||||
|
@ -98,6 +100,37 @@ public abstract class AbstractConnector extends AbstractBuffers implements Conne
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* ------------------------------------------------------------------------------- */
|
||||||
|
public final Buffer newBuffer(int size)
|
||||||
|
{
|
||||||
|
// TODO remove once no overrides established
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ------------------------------------------------------------------------------- */
|
||||||
|
public Buffer newRequestBuffer(int size)
|
||||||
|
{
|
||||||
|
return new ByteArrayBuffer(size);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ------------------------------------------------------------------------------- */
|
||||||
|
public Buffer newRequestHeader(int size)
|
||||||
|
{
|
||||||
|
return new ByteArrayBuffer(size);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ------------------------------------------------------------------------------- */
|
||||||
|
public Buffer newResponseBuffer(int size)
|
||||||
|
{
|
||||||
|
return new ByteArrayBuffer(size);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ------------------------------------------------------------------------------- */
|
||||||
|
public Buffer newResponseHeader(int size)
|
||||||
|
{
|
||||||
|
return new ByteArrayBuffer(size);
|
||||||
|
}
|
||||||
|
|
||||||
/* ------------------------------------------------------------------------------- */
|
/* ------------------------------------------------------------------------------- */
|
||||||
/*
|
/*
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -33,7 +33,7 @@ import org.eclipse.jetty.util.thread.ThreadPool;
|
||||||
*
|
*
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
public interface Connector extends LifeCycle, Buffers
|
public interface Connector extends LifeCycle
|
||||||
{
|
{
|
||||||
/* ------------------------------------------------------------ */
|
/* ------------------------------------------------------------ */
|
||||||
/**
|
/**
|
||||||
|
@ -59,17 +59,42 @@ public interface Connector extends LifeCycle, Buffers
|
||||||
|
|
||||||
/* ------------------------------------------------------------ */
|
/* ------------------------------------------------------------ */
|
||||||
/**
|
/**
|
||||||
* @return Returns the headerBufferSize.
|
* @return Returns the request header buffer size in bytes.
|
||||||
*/
|
*/
|
||||||
int getHeaderBufferSize();
|
int getRequestHeaderSize();
|
||||||
|
|
||||||
/* ------------------------------------------------------------ */
|
/* ------------------------------------------------------------ */
|
||||||
/**
|
/**
|
||||||
* Set the size of the buffer to be used for request and response headers.
|
* Set the size of the buffer to be used for request headers.
|
||||||
* An idle connection will at most have one buffer of this size allocated.
|
* @param size The size in bytes.
|
||||||
* @param headerBufferSize The headerBufferSize to set.
|
|
||||||
*/
|
*/
|
||||||
void setHeaderBufferSize(int headerBufferSize);
|
void setRequestHeaderSize(int size);
|
||||||
|
|
||||||
|
/* ------------------------------------------------------------ */
|
||||||
|
/**
|
||||||
|
* @return Returns the response header buffer size in bytes.
|
||||||
|
*/
|
||||||
|
int getResponseHeaderSize();
|
||||||
|
|
||||||
|
/* ------------------------------------------------------------ */
|
||||||
|
/**
|
||||||
|
* Set the size of the buffer to be used for request headers.
|
||||||
|
* @param size The size in bytes.
|
||||||
|
*/
|
||||||
|
void setResponseHeaderSize(int size);
|
||||||
|
|
||||||
|
|
||||||
|
/* ------------------------------------------------------------ */
|
||||||
|
/**
|
||||||
|
* @return factory for request buffers
|
||||||
|
*/
|
||||||
|
Buffers getRequestBuffers();
|
||||||
|
|
||||||
|
/* ------------------------------------------------------------ */
|
||||||
|
/**
|
||||||
|
* @return factory for response buffers
|
||||||
|
*/
|
||||||
|
Buffers getResponseBuffers();
|
||||||
|
|
||||||
|
|
||||||
/* ------------------------------------------------------------ */
|
/* ------------------------------------------------------------ */
|
||||||
|
|
|
@ -25,7 +25,9 @@ import org.eclipse.jetty.continuation.ContinuationThrowable;
|
||||||
import org.eclipse.jetty.http.AbstractGenerator;
|
import org.eclipse.jetty.http.AbstractGenerator;
|
||||||
import org.eclipse.jetty.http.EncodedHttpURI;
|
import org.eclipse.jetty.http.EncodedHttpURI;
|
||||||
import org.eclipse.jetty.http.Generator;
|
import org.eclipse.jetty.http.Generator;
|
||||||
|
import org.eclipse.jetty.http.HttpBuffers;
|
||||||
import org.eclipse.jetty.http.HttpContent;
|
import org.eclipse.jetty.http.HttpContent;
|
||||||
|
import org.eclipse.jetty.http.HttpException;
|
||||||
import org.eclipse.jetty.http.HttpFields;
|
import org.eclipse.jetty.http.HttpFields;
|
||||||
import org.eclipse.jetty.http.HttpGenerator;
|
import org.eclipse.jetty.http.HttpGenerator;
|
||||||
import org.eclipse.jetty.http.HttpHeaderValues;
|
import org.eclipse.jetty.http.HttpHeaderValues;
|
||||||
|
@ -41,7 +43,6 @@ import org.eclipse.jetty.io.Buffer;
|
||||||
import org.eclipse.jetty.io.Connection;
|
import org.eclipse.jetty.io.Connection;
|
||||||
import org.eclipse.jetty.io.EndPoint;
|
import org.eclipse.jetty.io.EndPoint;
|
||||||
import org.eclipse.jetty.io.EofException;
|
import org.eclipse.jetty.io.EofException;
|
||||||
import org.eclipse.jetty.io.HttpException;
|
|
||||||
import org.eclipse.jetty.io.BufferCache.CachedBuffer;
|
import org.eclipse.jetty.io.BufferCache.CachedBuffer;
|
||||||
import org.eclipse.jetty.io.nio.SelectChannelEndPoint;
|
import org.eclipse.jetty.io.nio.SelectChannelEndPoint;
|
||||||
import org.eclipse.jetty.util.QuotedStringTokenizer;
|
import org.eclipse.jetty.util.QuotedStringTokenizer;
|
||||||
|
@ -128,12 +129,13 @@ public class HttpConnection implements Connection
|
||||||
_uri = URIUtil.__CHARSET==StringUtil.__UTF8?new HttpURI():new EncodedHttpURI(URIUtil.__CHARSET);
|
_uri = URIUtil.__CHARSET==StringUtil.__UTF8?new HttpURI():new EncodedHttpURI(URIUtil.__CHARSET);
|
||||||
_connector = connector;
|
_connector = connector;
|
||||||
_endp = endpoint;
|
_endp = endpoint;
|
||||||
_parser = new HttpParser(_connector, endpoint, new RequestHandler(), _connector.getHeaderBufferSize(), _connector.getRequestBufferSize());
|
HttpBuffers ab = (HttpBuffers)_connector;
|
||||||
|
_parser = new HttpParser(ab.getRequestBuffers(), endpoint, new RequestHandler());
|
||||||
_requestFields = new HttpFields();
|
_requestFields = new HttpFields();
|
||||||
_responseFields = new HttpFields();
|
_responseFields = new HttpFields();
|
||||||
_request = new Request(this);
|
_request = new Request(this);
|
||||||
_response = new Response(this);
|
_response = new Response(this);
|
||||||
_generator = new HttpGenerator(_connector, _endp, _connector.getHeaderBufferSize(), _connector.getResponseBufferSize());
|
_generator = new HttpGenerator(ab.getResponseBuffers(), _endp);
|
||||||
_generator.setSendServerVersion(server.getSendServerVersion());
|
_generator.setSendServerVersion(server.getSendServerVersion());
|
||||||
_server = server;
|
_server = server;
|
||||||
}
|
}
|
||||||
|
|
|
@ -149,12 +149,6 @@ public class LocalConnector extends AbstractConnector
|
||||||
return _out;
|
return _out;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ------------------------------------------------------------ */
|
|
||||||
public Buffer newBuffer(int size)
|
|
||||||
{
|
|
||||||
return new ByteArrayBuffer(size);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ------------------------------------------------------------ */
|
/* ------------------------------------------------------------ */
|
||||||
protected void accept(int acceptorID) throws IOException, InterruptedException
|
protected void accept(int acceptorID) throws IOException, InterruptedException
|
||||||
{
|
{
|
||||||
|
|
|
@ -21,11 +21,11 @@ import java.util.HashSet;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
|
import org.eclipse.jetty.http.HttpException;
|
||||||
import org.eclipse.jetty.io.Buffer;
|
import org.eclipse.jetty.io.Buffer;
|
||||||
import org.eclipse.jetty.io.ByteArrayBuffer;
|
import org.eclipse.jetty.io.ByteArrayBuffer;
|
||||||
import org.eclipse.jetty.io.EndPoint;
|
import org.eclipse.jetty.io.EndPoint;
|
||||||
import org.eclipse.jetty.io.EofException;
|
import org.eclipse.jetty.io.EofException;
|
||||||
import org.eclipse.jetty.io.HttpException;
|
|
||||||
import org.eclipse.jetty.io.bio.SocketEndPoint;
|
import org.eclipse.jetty.io.bio.SocketEndPoint;
|
||||||
import org.eclipse.jetty.server.AbstractConnector;
|
import org.eclipse.jetty.server.AbstractConnector;
|
||||||
import org.eclipse.jetty.server.HttpConnection;
|
import org.eclipse.jetty.server.HttpConnection;
|
||||||
|
@ -111,12 +111,6 @@ public class SocketConnector extends AbstractConnector
|
||||||
return new HttpConnection(this, endpoint, getServer());
|
return new HttpConnection(this, endpoint, getServer());
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ------------------------------------------------------------------------------- */
|
|
||||||
public Buffer newBuffer(int size)
|
|
||||||
{
|
|
||||||
return new ByteArrayBuffer(size);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ------------------------------------------------------------------------------- */
|
/* ------------------------------------------------------------------------------- */
|
||||||
public void customize(EndPoint endpoint, Request request)
|
public void customize(EndPoint endpoint, Request request)
|
||||||
throws IOException
|
throws IOException
|
||||||
|
|
|
@ -45,9 +45,9 @@ import javax.servlet.ServletRequestListener;
|
||||||
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletRequest;
|
||||||
import javax.servlet.http.HttpServletResponse;
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
|
||||||
|
import org.eclipse.jetty.http.HttpException;
|
||||||
import org.eclipse.jetty.http.MimeTypes;
|
import org.eclipse.jetty.http.MimeTypes;
|
||||||
import org.eclipse.jetty.io.Buffer;
|
import org.eclipse.jetty.io.Buffer;
|
||||||
import org.eclipse.jetty.io.HttpException;
|
|
||||||
import org.eclipse.jetty.server.Dispatcher;
|
import org.eclipse.jetty.server.Dispatcher;
|
||||||
import org.eclipse.jetty.server.DispatcherType;
|
import org.eclipse.jetty.server.DispatcherType;
|
||||||
import org.eclipse.jetty.server.Handler;
|
import org.eclipse.jetty.server.Handler;
|
||||||
|
|
|
@ -47,31 +47,43 @@ public abstract class AbstractNIOConnector extends AbstractConnector implements
|
||||||
_useDirectBuffers=direct;
|
_useDirectBuffers=direct;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// TODO
|
||||||
|
// Header buffers always byte array buffers (efficiency of random access)
|
||||||
|
// There are lots of things to consider here... DIRECT buffers are faster to
|
||||||
|
// send but more expensive to build and access! so we have choices to make...
|
||||||
|
// + headers are constructed bit by bit and parsed bit by bit, so INDiRECT looks
|
||||||
|
// good for them.
|
||||||
|
// + but will a gather write of an INDIRECT header with a DIRECT body be any good?
|
||||||
|
// this needs to be benchmarked.
|
||||||
|
// + Will it be possible to get a DIRECT header buffer just for the gather writes of
|
||||||
|
// content from file mapped buffers?
|
||||||
|
// + Are gather writes worth the effort? Maybe they will work well with two INDIRECT
|
||||||
|
// buffers being copied into a single kernel buffer?
|
||||||
|
|
||||||
/* ------------------------------------------------------------------------------- */
|
/* ------------------------------------------------------------------------------- */
|
||||||
public Buffer newBuffer(int size)
|
public Buffer newRequestBuffer(int size)
|
||||||
{
|
{
|
||||||
// TODO
|
return _useDirectBuffers?new DirectNIOBuffer(size):new IndirectNIOBuffer(size);
|
||||||
// Header buffers always byte array buffers (efficiency of random access)
|
|
||||||
// There are lots of things to consider here... DIRECT buffers are faster to
|
|
||||||
// send but more expensive to build and access! so we have choices to make...
|
|
||||||
// + headers are constructed bit by bit and parsed bit by bit, so INDiRECT looks
|
|
||||||
// good for them.
|
|
||||||
// + but will a gather write of an INDIRECT header with a DIRECT body be any good?
|
|
||||||
// this needs to be benchmarked.
|
|
||||||
// + Will it be possible to get a DIRECT header buffer just for the gather writes of
|
|
||||||
// content from file mapped buffers?
|
|
||||||
// + Are gather writes worth the effort? Maybe they will work well with two INDIRECT
|
|
||||||
// buffers being copied into a single kernel buffer?
|
|
||||||
//
|
|
||||||
Buffer buf = null;
|
|
||||||
if (size==getHeaderBufferSize())
|
|
||||||
buf= new IndirectNIOBuffer(size);
|
|
||||||
else
|
|
||||||
buf = _useDirectBuffers
|
|
||||||
?(NIOBuffer)new DirectNIOBuffer(size)
|
|
||||||
:(NIOBuffer)new IndirectNIOBuffer(size);
|
|
||||||
return buf;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* ------------------------------------------------------------------------------- */
|
||||||
|
public Buffer newRequestHeader(int size)
|
||||||
|
{
|
||||||
|
return new IndirectNIOBuffer(size);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ------------------------------------------------------------------------------- */
|
||||||
|
public Buffer newResponseBuffer(int size)
|
||||||
|
{
|
||||||
|
return _useDirectBuffers?new DirectNIOBuffer(size):new IndirectNIOBuffer(size);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ------------------------------------------------------------------------------- */
|
||||||
|
public Buffer newResponseHeader(int size)
|
||||||
|
{
|
||||||
|
// TODO maybe can be direct?
|
||||||
|
return new IndirectNIOBuffer(size);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,9 +20,9 @@ import java.nio.channels.ByteChannel;
|
||||||
import java.nio.channels.ServerSocketChannel;
|
import java.nio.channels.ServerSocketChannel;
|
||||||
import java.nio.channels.SocketChannel;
|
import java.nio.channels.SocketChannel;
|
||||||
|
|
||||||
|
import org.eclipse.jetty.http.HttpException;
|
||||||
import org.eclipse.jetty.io.EndPoint;
|
import org.eclipse.jetty.io.EndPoint;
|
||||||
import org.eclipse.jetty.io.EofException;
|
import org.eclipse.jetty.io.EofException;
|
||||||
import org.eclipse.jetty.io.HttpException;
|
|
||||||
import org.eclipse.jetty.io.nio.ChannelEndPoint;
|
import org.eclipse.jetty.io.nio.ChannelEndPoint;
|
||||||
import org.eclipse.jetty.server.HttpConnection;
|
import org.eclipse.jetty.server.HttpConnection;
|
||||||
import org.eclipse.jetty.server.Request;
|
import org.eclipse.jetty.server.Request;
|
||||||
|
|
|
@ -44,8 +44,10 @@ import org.eclipse.jetty.http.HttpSchemes;
|
||||||
import org.eclipse.jetty.http.security.Password;
|
import org.eclipse.jetty.http.security.Password;
|
||||||
import org.eclipse.jetty.http.ssl.SslSelectChannelEndPoint;
|
import org.eclipse.jetty.http.ssl.SslSelectChannelEndPoint;
|
||||||
import org.eclipse.jetty.io.Buffer;
|
import org.eclipse.jetty.io.Buffer;
|
||||||
|
import org.eclipse.jetty.io.Buffers;
|
||||||
import org.eclipse.jetty.io.Connection;
|
import org.eclipse.jetty.io.Connection;
|
||||||
import org.eclipse.jetty.io.EndPoint;
|
import org.eclipse.jetty.io.EndPoint;
|
||||||
|
import org.eclipse.jetty.io.ThreadLocalBuffers;
|
||||||
import org.eclipse.jetty.io.bio.SocketEndPoint;
|
import org.eclipse.jetty.io.bio.SocketEndPoint;
|
||||||
import org.eclipse.jetty.io.nio.DirectNIOBuffer;
|
import org.eclipse.jetty.io.nio.DirectNIOBuffer;
|
||||||
import org.eclipse.jetty.io.nio.IndirectNIOBuffer;
|
import org.eclipse.jetty.io.nio.IndirectNIOBuffer;
|
||||||
|
@ -114,60 +116,7 @@ public class SslSelectChannelConnector extends SelectChannelConnector
|
||||||
private String _truststore;
|
private String _truststore;
|
||||||
private String _truststoreType="JKS"; // type of the key store
|
private String _truststoreType="JKS"; // type of the key store
|
||||||
private SSLContext _context;
|
private SSLContext _context;
|
||||||
|
Buffers _sslBuffers;
|
||||||
private int _packetBufferSize;
|
|
||||||
private int _applicationBufferSize;
|
|
||||||
private ConcurrentLinkedQueue<Buffer> _packetBuffers = new ConcurrentLinkedQueue<Buffer>();
|
|
||||||
private ConcurrentLinkedQueue<Buffer> _applicationBuffers = new ConcurrentLinkedQueue<Buffer>();
|
|
||||||
|
|
||||||
/* ------------------------------------------------------------ */
|
|
||||||
/* (non-Javadoc)
|
|
||||||
* @see org.eclipse.jetty.io.AbstractBuffers#getBuffer(int)
|
|
||||||
*/
|
|
||||||
public Buffer getBuffer(int size)
|
|
||||||
{
|
|
||||||
// TODO why is this reimplemented?
|
|
||||||
Buffer buffer;
|
|
||||||
if (size==_applicationBufferSize)
|
|
||||||
{
|
|
||||||
buffer = _applicationBuffers.poll();
|
|
||||||
if (buffer==null)
|
|
||||||
buffer=new IndirectNIOBuffer(size);
|
|
||||||
}
|
|
||||||
else if (size==_packetBufferSize)
|
|
||||||
{
|
|
||||||
buffer = _packetBuffers.poll();
|
|
||||||
if (buffer==null)
|
|
||||||
buffer=getUseDirectBuffers()
|
|
||||||
?(NIOBuffer)new DirectNIOBuffer(size)
|
|
||||||
:(NIOBuffer)new IndirectNIOBuffer(size);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
buffer=super.getBuffer(size);
|
|
||||||
|
|
||||||
return buffer;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ------------------------------------------------------------ */
|
|
||||||
/* (non-Javadoc)
|
|
||||||
* @see org.eclipse.jetty.io.AbstractBuffers#returnBuffer(org.eclipse.io.Buffer)
|
|
||||||
*/
|
|
||||||
public void returnBuffer(Buffer buffer)
|
|
||||||
{
|
|
||||||
buffer.clear();
|
|
||||||
int size=buffer.capacity();
|
|
||||||
ByteBuffer bbuf = ((NIOBuffer)buffer).getByteBuffer();
|
|
||||||
bbuf.position(0);
|
|
||||||
bbuf.limit(size);
|
|
||||||
|
|
||||||
if (size==_applicationBufferSize)
|
|
||||||
_applicationBuffers.add(buffer);
|
|
||||||
else if (size==_packetBufferSize)
|
|
||||||
_packetBuffers.add(buffer);
|
|
||||||
else
|
|
||||||
super.returnBuffer(buffer);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -528,7 +477,7 @@ public class SslSelectChannelConnector extends SelectChannelConnector
|
||||||
/* ------------------------------------------------------------------------------- */
|
/* ------------------------------------------------------------------------------- */
|
||||||
protected SelectChannelEndPoint newEndPoint(SocketChannel channel, SelectSet selectSet, SelectionKey key) throws IOException
|
protected SelectChannelEndPoint newEndPoint(SocketChannel channel, SelectSet selectSet, SelectionKey key) throws IOException
|
||||||
{
|
{
|
||||||
return new SslSelectChannelEndPoint(this,channel,selectSet,key,createSSLEngine());
|
return new SslSelectChannelEndPoint(_sslBuffers,channel,selectSet,key,createSSLEngine());
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ------------------------------------------------------------------------------- */
|
/* ------------------------------------------------------------------------------- */
|
||||||
|
@ -591,9 +540,29 @@ public class SslSelectChannelConnector extends SelectChannelConnector
|
||||||
SSLEngine engine=createSSLEngine();
|
SSLEngine engine=createSSLEngine();
|
||||||
SSLSession ssl_session=engine.getSession();
|
SSLSession ssl_session=engine.getSession();
|
||||||
|
|
||||||
setHeaderBufferSize(ssl_session.getApplicationBufferSize());
|
ThreadLocalBuffers buffers = new ThreadLocalBuffers()
|
||||||
setRequestBufferSize(ssl_session.getApplicationBufferSize());
|
{
|
||||||
setResponseBufferSize(ssl_session.getApplicationBufferSize());
|
@Override
|
||||||
|
protected Buffer newBuffer(int size)
|
||||||
|
{
|
||||||
|
// TODO indirect?
|
||||||
|
return new DirectNIOBuffer(size);
|
||||||
|
}
|
||||||
|
@Override
|
||||||
|
protected Buffer newHeader(int size)
|
||||||
|
{
|
||||||
|
// TODO indirect?
|
||||||
|
return new DirectNIOBuffer(size);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
buffers.setBufferSize(ssl_session.getApplicationBufferSize());
|
||||||
|
buffers.setHeaderSize(ssl_session.getPacketBufferSize());
|
||||||
|
_sslBuffers=buffers;
|
||||||
|
|
||||||
|
if (getRequestHeaderSize()<ssl_session.getApplicationBufferSize())
|
||||||
|
setRequestHeaderSize(ssl_session.getApplicationBufferSize());
|
||||||
|
if (getRequestBufferSize()<ssl_session.getApplicationBufferSize())
|
||||||
|
setRequestBufferSize(ssl_session.getApplicationBufferSize());
|
||||||
|
|
||||||
super.doStart();
|
super.doStart();
|
||||||
}
|
}
|
||||||
|
|
|
@ -67,6 +67,8 @@ public class StressTest extends TestCase
|
||||||
c_connector.setAcceptors(4);
|
c_connector.setAcceptors(4);
|
||||||
c_connector.setAcceptQueueSize(1000);
|
c_connector.setAcceptQueueSize(1000);
|
||||||
|
|
||||||
|
//c_connector.setPort(8080);
|
||||||
|
|
||||||
_connector=c_connector;
|
_connector=c_connector;
|
||||||
_connector.setMaxIdleTime(30000);
|
_connector.setMaxIdleTime(30000);
|
||||||
|
|
||||||
|
@ -75,6 +77,8 @@ public class StressTest extends TestCase
|
||||||
_server.start();
|
_server.start();
|
||||||
_port=_connector.getLocalPort();
|
_port=_connector.getLocalPort();
|
||||||
_addr=Inet4Address.getLocalHost();
|
_addr=Inet4Address.getLocalHost();
|
||||||
|
//_addr=Inet4Address.getByName("10.10.1.16");
|
||||||
|
System.err.println("ADDR "+_addr+":"+_port);
|
||||||
|
|
||||||
for (Queue q:_latencies)
|
for (Queue q:_latencies)
|
||||||
q.clear();
|
q.clear();
|
||||||
|
|
|
@ -35,9 +35,9 @@ import javax.servlet.http.HttpServletRequest;
|
||||||
import javax.servlet.http.HttpServletResponse;
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
|
||||||
import org.eclipse.jetty.continuation.ContinuationThrowable;
|
import org.eclipse.jetty.continuation.ContinuationThrowable;
|
||||||
|
import org.eclipse.jetty.http.HttpException;
|
||||||
import org.eclipse.jetty.http.PathMap;
|
import org.eclipse.jetty.http.PathMap;
|
||||||
import org.eclipse.jetty.io.EofException;
|
import org.eclipse.jetty.io.EofException;
|
||||||
import org.eclipse.jetty.io.HttpException;
|
|
||||||
import org.eclipse.jetty.security.IdentityService;
|
import org.eclipse.jetty.security.IdentityService;
|
||||||
import org.eclipse.jetty.security.SecurityHandler;
|
import org.eclipse.jetty.security.SecurityHandler;
|
||||||
import org.eclipse.jetty.server.Dispatcher;
|
import org.eclipse.jetty.server.Dispatcher;
|
||||||
|
|
|
@ -54,7 +54,7 @@ public class Jetty6ContinuationTest extends ContinuationBase
|
||||||
public void testJetty6() throws Exception
|
public void testJetty6() throws Exception
|
||||||
{
|
{
|
||||||
_filter.setInitParameter("debug","true");
|
_filter.setInitParameter("debug","true");
|
||||||
_filter.setInitParameter("faux","false");
|
//_filter.setInitParameter("faux","false");
|
||||||
_server.start();
|
_server.start();
|
||||||
_port=_connector.getLocalPort();
|
_port=_connector.getLocalPort();
|
||||||
|
|
||||||
|
|
|
@ -154,7 +154,7 @@ public class HttpTester
|
||||||
Buffer bb=new ByteArrayBuffer(32*1024 + (_genContent!=null?_genContent.length:0));
|
Buffer bb=new ByteArrayBuffer(32*1024 + (_genContent!=null?_genContent.length:0));
|
||||||
Buffer sb=new ByteArrayBuffer(4*1024);
|
Buffer sb=new ByteArrayBuffer(4*1024);
|
||||||
StringEndPoint endp = new StringEndPoint(_charset);
|
StringEndPoint endp = new StringEndPoint(_charset);
|
||||||
HttpGenerator generator = new HttpGenerator(new SimpleBuffers(new Buffer[]{sb,bb}),endp, sb.capacity(), bb.capacity());
|
HttpGenerator generator = new HttpGenerator(new SimpleBuffers(sb,bb),endp);
|
||||||
|
|
||||||
if (_method!=null)
|
if (_method!=null)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue