From 1f3d9ccf5dfa324fc92aec6e5a679655045dca2f Mon Sep 17 00:00:00 2001 From: Zeeshan Lakhani Date: Fri, 8 May 2015 09:28:06 +0900 Subject: [PATCH] * config and build script updates for pulling in solr 4.10.4 (solr binary already pushed to uploads.basho) * minor updates to prevent benign but useless warnings in solr logs * patch update for move to 4.10.4 * move to jdk 7 for building solr 4.10.4, as it's the min version required (cherry picked from commit 9745d4785479051cd8731aa923de5f64c8f58b8b) --- priv/conf/_rest_managed.json | 1 + priv/conf/solrconfig.xml | 49 ++++---------- priv/default_schema.xml | 3 +- ....7.0.patch => no-stale-check-4.10.4.patch} | 66 ++++++++----------- tools/build-jar.sh | 4 +- tools/build-solr.sh | 6 +- tools/grab-solr.sh | 2 +- 7 files changed, 47 insertions(+), 84 deletions(-) create mode 100644 priv/conf/_rest_managed.json rename solr-patches/{no-stale-check-4.7.0.patch => no-stale-check-4.10.4.patch} (56%) diff --git a/priv/conf/_rest_managed.json b/priv/conf/_rest_managed.json new file mode 100644 index 00000000..6a4aec39 --- /dev/null +++ b/priv/conf/_rest_managed.json @@ -0,0 +1 @@ +{"initArgs":{},"managedList":[]} diff --git a/priv/conf/solrconfig.xml b/priv/conf/solrconfig.xml index 04113997..0eedfbb7 100644 --- a/priv/conf/solrconfig.xml +++ b/priv/conf/solrconfig.xml @@ -4,7 +4,7 @@ this file, see http://wiki.apache.org/solr/SolrConfigXml. --> - 4.7 + 4.10.4 + + + @@ -326,7 +335,6 @@ size="512" autowarmCount="0" showItems="32" /> - - - - - - - - + - diff --git a/solr-patches/no-stale-check-4.7.0.patch b/solr-patches/no-stale-check-4.10.4.patch similarity index 56% rename from solr-patches/no-stale-check-4.7.0.patch rename to solr-patches/no-stale-check-4.10.4.patch index 70b01c66..f26c3e14 100644 --- a/solr-patches/no-stale-check-4.7.0.patch +++ b/solr-patches/no-stale-check-4.10.4.patch @@ -1,73 +1,59 @@ -From a2e77eaa262bd24c8bf3250d85fa0b3cab7d33e7 Mon Sep 17 00:00:00 2001 -From: Ryan Zezeski -Date: Tue, 12 Feb 2013 11:54:21 -0500 -Subject: [PATCH] Disable stale check and nagle +commit 13449f7dc2ac0d205180611f2de6e1371cd88a4b +Author: Zeeshan Lakhani +Date: Thu May 7 00:20:08 2015 +0900 -* Apache HTTP's stale conn check causes additionall latency and - is not recommended for high-throughput/low-latency scenarios. - -* Disabling the stale check requires adding a periodic background - task which clears idles connections. This prevents the client - from pulling a conn closed by the server which causes an IOException. - -* Disable nagle as it's meant for protocols that use many small messages. ---- - .../solr/handler/component/HttpShardHandlerFactory.java | 3 +++ - .../org/apache/solr/client/solrj/impl/HttpClientUtil.java | 13 +++++++++++++ - 2 files changed, 16 insertions(+) + Update patches for Solr 4.10.4 diff --git a/solr/core/src/java/org/apache/solr/handler/component/HttpShardHandlerFactory.java b/solr/core/src/java/org/apache/solr/handler/component/HttpShardHandlerFactory.java -index 3f91f17..e8b018e 100644 +index f574f29..42168df 100644 --- a/solr/core/src/java/org/apache/solr/handler/component/HttpShardHandlerFactory.java +++ b/solr/core/src/java/org/apache/solr/handler/component/HttpShardHandlerFactory.java -@@ -17,6 +17,7 @@ package org.apache.solr.handler.component; - */ +@@ -29,6 +29,7 @@ import java.util.concurrent.ThreadPoolExecutor; + import java.util.concurrent.TimeUnit; import org.apache.commons.lang.StringUtils; +import org.apache.http.params.HttpConnectionParams; import org.apache.http.client.HttpClient; - import org.apache.solr.client.solrj.SolrServerException; - import org.apache.solr.client.solrj.impl.HttpClientUtil; -@@ -153,6 +154,8 @@ public class HttpShardHandlerFactory extends ShardHandlerFactory implements org. - clientParams.set(HttpClientUtil.PROP_CONNECTION_TIMEOUT, connectionTimeout); - clientParams.set(HttpClientUtil.PROP_USE_RETRY, false); + import org.apache.http.impl.client.DefaultHttpClient; + import org.apache.http.impl.client.DefaultHttpRequestRetryHandler; +@@ -163,7 +164,8 @@ public class HttpShardHandlerFactory extends ShardHandlerFactory implements org. + clientParams.set(HttpClientUtil.PROP_USE_RETRY, false); + } this.defaultClient = HttpClientUtil.createClient(clientParams); +- + this.defaultClient.getParams().setParameter(HttpConnectionParams.STALE_CONNECTION_CHECK, false); + this.defaultClient.getParams().setParameter(HttpConnectionParams.TCP_NODELAY, true); - this.loadbalancer = createLoadbalancer(defaultClient); - } - + // must come after createClient + if (useRetries) { + // our default retry handler will never retry on IOException if the request has been sent already, diff --git a/solr/solrj/src/java/org/apache/solr/client/solrj/impl/HttpClientUtil.java b/solr/solrj/src/java/org/apache/solr/client/solrj/impl/HttpClientUtil.java -index b7c0680..8ca13f3 100644 +index fcbc80d..c98c982 100644 --- a/solr/solrj/src/java/org/apache/solr/client/solrj/impl/HttpClientUtil.java +++ b/solr/solrj/src/java/org/apache/solr/client/solrj/impl/HttpClientUtil.java -@@ -18,6 +18,9 @@ package org.apache.solr.client.solrj.impl; +@@ -17,6 +17,9 @@ + package org.apache.solr.client.solrj.impl; import java.io.IOException; - import java.io.InputStream; +import java.util.concurrent.Executors; +import java.util.concurrent.ScheduledExecutorService; +import java.util.concurrent.TimeUnit; + import java.io.InputStream; import java.util.zip.GZIPInputStream; import java.util.zip.InflaterInputStream; - -@@ -110,6 +113,16 @@ public class HttpClientUtil { +@@ -115,6 +118,16 @@ public class HttpClientUtil { logger.debug("Creating new http client, config:" + config); } final DefaultHttpClient httpClient = new SystemDefaultHttpClient(); + final org.apache.http.conn.ClientConnectionManager mgr = httpClient.getConnectionManager(); + -+ // NOTE: The sweeper task is assuming hard-coded Jetty max-idle of 50s. ++ // Note: The sweeper task is assuming hard-coded Jetty max-idle of 50s. + final Runnable sweeper = new Runnable() { -+ public void run() { -+ mgr.closeIdleConnections(40, TimeUnit.SECONDS); -+ } -+ }; ++ public void run() { ++ mgr.closeIdleConnections(40, TimeUnit.SECONDS); ++ } ++ }; + final ScheduledExecutorService stp = Executors.newScheduledThreadPool(1); + stp.scheduleWithFixedDelay(sweeper, 5, 5, TimeUnit.SECONDS); configureClient(httpClient, config); return httpClient; } --- -1.9.0 - diff --git a/tools/build-jar.sh b/tools/build-jar.sh index 8e5da039..bdbe79ec 100755 --- a/tools/build-jar.sh +++ b/tools/build-jar.sh @@ -24,9 +24,9 @@ if [ ! -x "`which javac`" ] || [ ! -x "`which jar`" ]; then exit 1 fi -if ! javac -version 2>&1 | egrep "1\.6\.[0-9_.]+" +if ! javac -version 2>&1 | egrep "1\.7\.[0-9_.]+" then - echo "JDK 1.6 must be used to compile these jars" + echo "JDK 1.7 must be used to compile these jars" exit 1 fi diff --git a/tools/build-solr.sh b/tools/build-solr.sh index c980a061..0f8bedc9 100755 --- a/tools/build-solr.sh +++ b/tools/build-solr.sh @@ -8,7 +8,7 @@ #> #> Example: #> -#> ./build-solr.sh --patch-dir ~/yokozuna/solr-patches /tmp/build-solr solr-4.7.0-yz http://archive.apache.org/dist/lucene/solr/4.7.0/solr-4.7.0-src.tgz | tee build-solr.out +#> ./build-solr.sh --patch-dir ~/yokozuna/solr-patches /tmp/build-solr solr-4.10.4-yz http://archive.apache.org/dist/lucene/solr/4.10.4/solr-4.10.4-src.tgz | tee build-solr.out set -e @@ -79,9 +79,9 @@ WORK_DIR=$1; shift NAME=$1; shift URL=$1; shift -if ! javac -version 2>&1 | egrep "1\.6\.[0-9_.]+" +if ! javac -version 2>&1 | egrep "1\.7\.[0-9_.]+" then - echo "JDK 1.6 must be used to compile Solr" + echo "JDK 1.7 must be used to compile Solr" exit 1 fi diff --git a/tools/grab-solr.sh b/tools/grab-solr.sh index 91ecc38e..3981ea86 100755 --- a/tools/grab-solr.sh +++ b/tools/grab-solr.sh @@ -18,7 +18,7 @@ PRIV_DIR=../priv CONF_DIR=$PRIV_DIR/conf SOLR_DIR=$PRIV_DIR/solr BUILD_DIR=../build -VSN=solr-4.7.0-yz-1 +VSN=solr-4.10.4-yz-1 FILENAME=$VSN.tgz TMP_DIR=/var/tmp/yokozuna TMP_FILE=$TMP_DIR/$FILENAME