When you copy paste config from wiki, just copy what you need. excluding documentation and comments
On Wed, Jan 13, 2010 at 12:51 AM, Stephen Weiss <swe...@stylesight.com> wrote: > Hi Solr List, > > We're trying to set up java-based replication with Solr 1.4 (dist tarball). > We are running this to start with on a pair of test servers just to see how > things go. > > There's one major problem we can't seem to get past. When we replicate > manually (via the admin page) things seem to go well. However, when > replication is triggered by a commit event on the master, the master gets a > NullPointerException and no replication seems to take place. > >> SEVERE: java.lang.NullPointerException >> at >> org.apache.solr.handler.ReplicationHandler$4.postCommit(ReplicationHandler.java:922) >> at >> org.apache.solr.update.UpdateHandler.callPostCommitCallbacks(UpdateHandler.java:78) >> at >> org.apache.solr.update.DirectUpdateHandler2.commit(DirectUpdateHandler2.java:411) >> at >> org.apache.solr.update.processor.RunUpdateProcessor.processCommit(RunUpdateProcessorFactory.java:85) >> at >> org.apache.solr.handler.XMLLoader.processUpdate(XMLLoader.java:169) >> at org.apache.solr.handler.XMLLoader.load(XMLLoader.java:69) >> at >> org.apache.solr.handler.ContentStreamHandlerBase.handleRequestBody(ContentStreamHandlerBase.java:54) >> at >> org.apache.solr.handler.RequestHandlerBase.handleRequest(RequestHandlerBase.java:131) >> at org.apache.solr.core.SolrCore.execute(SolrCore.java:1316) >> at >> org.apache.solr.servlet.SolrDispatchFilter.execute(SolrDispatchFilter.java:336) >> at >> org.apache.solr.servlet.SolrDispatchFilter.doFilter(SolrDispatchFilter.java:239) >> at >> org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1115) >> at >> org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:361) >> at >> org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216) >> at >> org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:181) >> at >> org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:766) >> at >> org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:417) >> at >> org.mortbay.jetty.handler.ContextHandlerCollection.handle(ContextHandlerCollection.java:230) >> at >> org.mortbay.jetty.handler.HandlerCollection.handle(HandlerCollection.java:114) >> at >> org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152) >> at org.mortbay.jetty.Server.handle(Server.java:324) >> at >> org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:534) >> at >> org.mortbay.jetty.HttpConnection$RequestHandler.content(HttpConnection.java:879) >> at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:741) >> at org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:213) >> at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:403) >> at >> org.mortbay.io.nio.SelectChannelEndPoint.run(SelectChannelEndPoint.java:409) >> at >> org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:522) >> > > > This is the master config: > > <requestHandler name="/replication" class="solr.ReplicationHandler" > > <lst name="master"> > <!--Replicate on 'optimize'. Other values can be 'commit', 'startup'. > It is possible to have multiple entries of this config string--> > <str name="replicateAfter">commit</str> > > <!--Create a backup after 'optimize'. Other values can be 'commit', > 'startup'. > It is possible to have multiple entries of this config string. Note > that this is > just for backup, replication does not require this. --> > <!-- <str name="backupAfter">optimize</str> --> > > <!--If configuration files need to be replicated give the names here, > separated by comma --> > <str > name="confFiles">solrconfig_slave.xml:solrconfig.xml,schema.xml,synonyms.txt,stopwords.txt,elevate.xml</str> > > <!--The default value of reservation is 10 secs.See the documentation > below. > Normally , you should not need to specify this --> > <str name="commitReserveDuration">00:00:10</str> > </lst> > </requestHandler> > > > and... the slave config: > > <requestHandler name="/replication" class="solr.ReplicationHandler" > > <lst name="slave"> > > <!--fully qualified url for the replication handler of master . It is > possible > to pass on this as a request param for the fetchindex command--> > <str > name="masterUrl">http://hostname.obscured.com:8080/solr/calendar_core/replication</str> > > <!--Interval in which the slave should poll master .Format is > HH:mm:ss . > If this is absent slave does not poll automatically. > But a fetchindex can be triggered from the admin or the http API --> > <str name="pollInterval">00:00:20</str> > > <!-- THE FOLLOWING PARAMETERS ARE USUALLY NOT REQUIRED--> > <!--to use compression while transferring the index files. The > possible values are internal|external > if the value is 'external' make sure that your master Solr has the > settings to honour the accept-encoding header. > see here for details http://wiki.apache.org/solr/SolrHttpCompression > If it is 'internal' everything will be taken care of automatically. > USE THIS ONLY IF YOUR BANDWIDTH IS LOW . THIS CAN ACTUALLY SLOWDOWN > REPLICATION IN A LAN--> > <str name="compression">internal</str> > <!-- ??? --> > > <!--The following values are used when the slave connects to the master > to download the index files. > Default values implicitly set as 5000ms and 10000ms respectively. > The user DOES NOT need to specify > these unless the bandwidth is extremely low or if there is an > extremely high latency--> > <str name="httpConnTimeout">5000</str> > <str name="httpReadTimeout">10000</str> > > <!-- If HTTP Basic authentication is enabled on the master, then the > slave can be configured with the following > <str name="httpBasicAuthUser">username</str> > <str name="httpBasicAuthPassword">password</str>--> > <!-- we use firewall for security... --> > > </lst> > </requestHandler> > > > Does anyone know off the top of their head what this might indicate, or know > what further troubleshooting steps we should be taking to isolate the issue? > > Also, on a (probably) unrelated topic, we're kinda confused by this section > of the slave config: > > <!--to use compression while transferring the index files. The > possible values are internal|external > if the value is 'external' make sure that your master Solr has the > settings to honour the accept-encoding header. > see here for details http://wiki.apache.org/solr/SolrHttpCompression > If it is 'internal' everything will be taken care of automatically. > USE THIS ONLY IF YOUR BANDWIDTH IS LOW . THIS CAN ACTUALLY SLOWDOWN > REPLICATION IN A LAN--> > <str name="compression">internal</str> > > Since we *are* on a LAN, what exactly should we be doing here? The language > is somewhat unclear... I thought that meant that we should just comment out > the line altogether, but others think it means that we should leave it set > to "internal". We get that compression is probably unnecessary for our more > vanilla setup, we're just not 100% sure how to express that correctly. > > Thanks in advance for any advice! > > -- > Steve > -- ----------------------------------------------------- Noble Paul | Systems Architect| AOL | http://aol.com