From fca492361c4ae9670c94e7a482085605724c072d Mon Sep 17 00:00:00 2001 From: markt Date: Fri, 8 Jul 2011 11:40:36 +0000 Subject: [PATCH] Align the process methods some more. git-svn-id: https://svn.apache.org/repos/asf/tomcat/trunk@1144271 13f79535-47bb-0310-9956-ffa450edef68 --- java/org/apache/coyote/ajp/AjpAprProtocol.java | 1 - java/org/apache/coyote/ajp/AjpNioProtocol.java | 2 -- java/org/apache/coyote/ajp/AjpProtocol.java | 13 ++++++++++--- java/org/apache/tomcat/util/net/AbstractEndpoint.java | 2 ++ 4 files changed, 12 insertions(+), 6 deletions(-) diff --git a/java/org/apache/coyote/ajp/AjpAprProtocol.java b/java/org/apache/coyote/ajp/AjpAprProtocol.java index f1152bfee..661b68e24 100644 --- a/java/org/apache/coyote/ajp/AjpAprProtocol.java +++ b/java/org/apache/coyote/ajp/AjpAprProtocol.java @@ -174,7 +174,6 @@ public class AjpAprProtocol extends AbstractAjpProtocol { recycledProcessors.offer(processor); } return state; - } catch(java.net.SocketException e) { // SocketExceptions are normal log.debug(sm.getString( diff --git a/java/org/apache/coyote/ajp/AjpNioProtocol.java b/java/org/apache/coyote/ajp/AjpNioProtocol.java index 0d9299e2f..1a04b666d 100644 --- a/java/org/apache/coyote/ajp/AjpNioProtocol.java +++ b/java/org/apache/coyote/ajp/AjpNioProtocol.java @@ -206,7 +206,6 @@ public class AjpNioProtocol extends AbstractAjpProtocol { // In the middle of processing a request/response. Keep the // socket associated with the processor. connections.put(socket, processor); - socket.setAsync(true); } else if (state == SocketState.OPEN){ // In keep-alive but between requests. OK to recycle @@ -218,7 +217,6 @@ public class AjpNioProtocol extends AbstractAjpProtocol { release(socket, processor, true); } return state; - } catch(java.net.SocketException e) { // SocketExceptions are normal log.debug(sm.getString( diff --git a/java/org/apache/coyote/ajp/AjpProtocol.java b/java/org/apache/coyote/ajp/AjpProtocol.java index 75c943688..111d1a82d 100644 --- a/java/org/apache/coyote/ajp/AjpProtocol.java +++ b/java/org/apache/coyote/ajp/AjpProtocol.java @@ -125,8 +125,12 @@ public class AjpProtocol extends AbstractAjpProtocol { } @Override - public SocketState process(SocketWrapper socket, SocketStatus status) { + public SocketState process(SocketWrapper socket, + SocketStatus status) { AjpProcessor processor = connections.remove(socket); + + socket.setAsync(false); + try { if (processor == null) { processor = recycledProcessors.poll(); @@ -147,12 +151,15 @@ public class AjpProtocol extends AbstractAjpProtocol { state = processor.asyncPostProcess(); } } while (state == SocketState.ASYNC_END); - // TODO Better to add a new state to the AsyncStateMachine and - // remove ASYNC_END entirely if (state == SocketState.LONG) { + // In the middle of processing a request/response. Keep the + // socket associated with the processor. connections.put(socket, processor); + socket.setAsync(true); } else if (state == SocketState.OPEN){ + // In keep-alive but between requests. OK to recycle + // processor. Continue to poll for the next request. processor.recycle(false); recycledProcessors.offer(processor); } else { diff --git a/java/org/apache/tomcat/util/net/AbstractEndpoint.java b/java/org/apache/tomcat/util/net/AbstractEndpoint.java index 606923d0a..1b45069be 100644 --- a/java/org/apache/tomcat/util/net/AbstractEndpoint.java +++ b/java/org/apache/tomcat/util/net/AbstractEndpoint.java @@ -52,6 +52,8 @@ public abstract class AbstractEndpoint { * Different types of socket states to react upon. */ public enum SocketState { + // TODO Add a new state to the AsyncStateMachine and remove + // ASYNC_END (if possible) OPEN, CLOSED, LONG, ASYNC_END } -- 2.11.0