remm 2005/05/15 08:49:31
Modified: http11/src/java/org/apache/coyote/http11
InternalAprInputBuffer.java
Log:
- Use a direct ByteBuffer for input as well, as the performance impact turned
out to be bigger than on output (probably
due to the fact that the byte array used is actually bigger).
- /usr/sbin/ab.exe -c 20 -k -n 20000 http://127.0.0.1:8080/tomcat.gif, Sun
Java 5 server, Windows XP with no firewall:
- APR HTTP: 1.00
- regular HTTP: 1.03
- when removing -k, APR is actually slightly faster now (about the same
very hard to measure difference, though)
- This means the difference is negligible, and I expect it to be impossible
to measure when testing over a network. If
confirmed, these results will make APR recommendable for everyone running a
Tomcat production server.
Revision Changes Path
1.6 +28 -6
jakarta-tomcat-connectors/http11/src/java/org/apache/coyote/http11/InternalAprInputBuffer.java
Index: InternalAprInputBuffer.java
===================================================================
RCS file:
/home/cvs/jakarta-tomcat-connectors/http11/src/java/org/apache/coyote/http11/InternalAprInputBuffer.java,v
retrieving revision 1.5
retrieving revision 1.6
diff -u -r1.5 -r1.6
--- InternalAprInputBuffer.java 15 Apr 2005 17:19:52 -0000 1.5
+++ InternalAprInputBuffer.java 15 May 2005 15:49:31 -0000 1.6
@@ -19,6 +19,7 @@
import java.io.IOException;
import java.io.EOFException;
+import java.nio.ByteBuffer;
import org.apache.tomcat.jni.Socket;
import org.apache.tomcat.jni.Status;
@@ -58,6 +59,7 @@
headerBuffer2 = new byte[headerBufferSize];
bodyBuffer = new byte[headerBufferSize];
buf = headerBuffer1;
+ bbuf = ByteBuffer.allocateDirect(headerBufferSize);
headerBuffer = new char[headerBufferSize];
ascbuf = headerBuffer;
@@ -162,6 +164,12 @@
/**
+ * Direct byte buffer used to perform actual reading.
+ */
+ protected ByteBuffer bbuf;
+
+
+ /**
* Underlying socket.
*/
protected long socket;
@@ -393,9 +401,12 @@
// Read new bytes if needed
if (pos >= lastValid) {
// Do a simple read with a short timeout
- int nRead = Socket.recvt
- (socket, buf, pos, buf.length - lastValid, readTimeout);
+ bbuf.clear();
+ int nRead = Socket.recvbt
+ (socket, bbuf, 0, buf.length - lastValid, readTimeout);
if (nRead > 0) {
+ bbuf.limit(nRead);
+ bbuf.get(buf, pos, nRead);
lastValid = pos + nRead;
} else {
if (Status.APR_STATUS_IS_ETIMEDOUT(-nRead)) {
@@ -417,9 +428,12 @@
if (pos >= lastValid) {
// Do a simple read with a short timeout
- int nRead = Socket.recvt
- (socket, buf, pos, buf.length - lastValid, readTimeout);
+ bbuf.clear();
+ int nRead = Socket.recvbt
+ (socket, bbuf, 0, buf.length - lastValid, readTimeout);
if (nRead > 0) {
+ bbuf.limit(nRead);
+ bbuf.get(buf, pos, nRead);
lastValid = pos + nRead;
} else {
if (Status.APR_STATUS_IS_ETIMEDOUT(-nRead)) {
@@ -758,8 +772,12 @@
(sm.getString("iib.requestheadertoolarge.error"));
}
- nRead = Socket.recv(socket, buf, pos, buf.length - lastValid);
+ bbuf.clear();
+ nRead = Socket.recvb
+ (socket, bbuf, 0, buf.length - lastValid);
if (nRead > 0) {
+ bbuf.limit(nRead);
+ bbuf.get(buf, pos, nRead);
lastValid = pos + nRead;
} else {
if (Status.APR_STATUS_IS_EAGAIN(-nRead)) {
@@ -774,8 +792,12 @@
buf = bodyBuffer;
pos = 0;
lastValid = 0;
- nRead = Socket.recv(socket, buf, 0, buf.length);
+ bbuf.clear();
+ nRead = Socket.recvb
+ (socket, bbuf, 0, buf.length);
if (nRead > 0) {
+ bbuf.limit(nRead);
+ bbuf.get(buf, 0, nRead);
lastValid = nRead;
} else {
throw new IOException(sm.getString("iib.failedread"));
---------------------------------------------------------------------
To unsubscribe, e-mail: [EMAIL PROTECTED]
For additional commands, e-mail: [EMAIL PROTECTED]