summaryrefslogtreecommitdiff
path: root/hadoop-common-project
diff options
context:
space:
mode:
authorChris Douglas <cdouglas@apache.org>2018-03-13 13:53:58 -0700
committerChris Douglas <cdouglas@apache.org>2018-03-13 14:20:44 -0700
commit9889e55e5a27506e92defc7910c36b3bee10a39d (patch)
treeb78ef0665cb17f2e2253ad90e4aabffa1bcf3d1b /hadoop-common-project
parentfc6f3e2a6f3b33394a44f2e4d2c13faf61a9484c (diff)
HADOOP-15311. HttpServer2 needs a way to configure the acceptor/selector count. Contributed by Erik Krogen
(cherry picked from commit 9d6994da1964c1125a33b3a65e7a7747e2d0bc59) (cherry picked from commit 80641508c721fe49c8ace4730b647efd3ce84fbd)
Diffstat (limited to 'hadoop-common-project')
-rw-r--r--hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/http/HttpServer2.java12
-rw-r--r--hadoop-common-project/hadoop-common/src/test/java/org/apache/hadoop/http/TestHttpServer.java23
2 files changed, 33 insertions, 2 deletions
diff --git a/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/http/HttpServer2.java b/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/http/HttpServer2.java
index fb49d2d487..d36cdf458b 100644
--- a/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/http/HttpServer2.java
+++ b/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/http/HttpServer2.java
@@ -133,6 +133,14 @@ public final class HttpServer2 implements FilterContainer {
"hadoop.http.socket.backlog.size";
public static final int HTTP_SOCKET_BACKLOG_SIZE_DEFAULT = 128;
public static final String HTTP_MAX_THREADS_KEY = "hadoop.http.max.threads";
+ public static final String HTTP_ACCEPTOR_COUNT_KEY =
+ "hadoop.http.acceptor.count";
+ // -1 to use default behavior of setting count based on CPU core count
+ public static final int HTTP_ACCEPTOR_COUNT_DEFAULT = -1;
+ public static final String HTTP_SELECTOR_COUNT_KEY =
+ "hadoop.http.selector.count";
+ // -1 to use default behavior of setting count based on CPU core count
+ public static final int HTTP_SELECTOR_COUNT_DEFAULT = -1;
public static final String HTTP_TEMP_DIR_KEY = "hadoop.http.temp.dir";
static final String FILTER_INITIALIZER_PROPERTY
@@ -464,7 +472,9 @@ public final class HttpServer2 implements FilterContainer {
private ServerConnector createHttpChannelConnector(
Server server, HttpConfiguration httpConfig) {
- ServerConnector conn = new ServerConnector(server);
+ ServerConnector conn = new ServerConnector(server,
+ conf.getInt(HTTP_ACCEPTOR_COUNT_KEY, HTTP_ACCEPTOR_COUNT_DEFAULT),
+ conf.getInt(HTTP_SELECTOR_COUNT_KEY, HTTP_SELECTOR_COUNT_DEFAULT));
ConnectionFactory connFactory = new HttpConnectionFactory(httpConfig);
conn.addConnectionFactory(connFactory);
configureChannelConnector(conn);
diff --git a/hadoop-common-project/hadoop-common/src/test/java/org/apache/hadoop/http/TestHttpServer.java b/hadoop-common-project/hadoop-common/src/test/java/org/apache/hadoop/http/TestHttpServer.java
index ca7e466b79..7350d09fb2 100644
--- a/hadoop-common-project/hadoop-common/src/test/java/org/apache/hadoop/http/TestHttpServer.java
+++ b/hadoop-common-project/hadoop-common/src/test/java/org/apache/hadoop/http/TestHttpServer.java
@@ -147,7 +147,7 @@ public class TestHttpServer extends HttpServerFunctionalTest {
@BeforeClass public static void setup() throws Exception {
Configuration conf = new Configuration();
- conf.setInt(HttpServer2.HTTP_MAX_THREADS_KEY, 10);
+ conf.setInt(HttpServer2.HTTP_MAX_THREADS_KEY, MAX_THREADS);
server = createTestServer(conf);
server.addServlet("echo", "/echo", EchoServlet.class);
server.addServlet("echomap", "/echomap", EchoMapServlet.class);
@@ -195,6 +195,27 @@ public class TestHttpServer extends HttpServerFunctionalTest {
ready.await();
start.countDown();
}
+
+ /**
+ * Test that the number of acceptors and selectors can be configured by
+ * trying to configure more of them than would be allowed based on the
+ * maximum thread count.
+ */
+ @Test
+ public void testAcceptorSelectorConfigurability() throws Exception {
+ Configuration conf = new Configuration();
+ conf.setInt(HttpServer2.HTTP_MAX_THREADS_KEY, MAX_THREADS);
+ conf.setInt(HttpServer2.HTTP_ACCEPTOR_COUNT_KEY, MAX_THREADS - 2);
+ conf.setInt(HttpServer2.HTTP_SELECTOR_COUNT_KEY, MAX_THREADS - 2);
+ HttpServer2 badserver = createTestServer(conf);
+ try {
+ badserver.start();
+ // Should not succeed
+ fail();
+ } catch (IOException ioe) {
+ assertTrue(ioe.getCause() instanceof IllegalStateException);
+ }
+ }
@Test public void testEcho() throws Exception {
assertEquals("a:b\nc:d\n",