[
https://issues.apache.org/jira/browse/SOLR-4136?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
Hoss Man updated SOLR-4136:
---------------------------
Attachment: SOLR-4136.patch
Context...
*
http://mail-archives.apache.org/mod_mbox/lucene-solr-user/201211.mbox/%3Calpine.DEB.2.02.1211292004430.2543@frisbee%3E
*
http://mail-archives.apache.org/mod_mbox/lucene-solr-user/201211.mbox/%[email protected]%3E
Mark's suggestion in that email regarding my original question (about
prohibiting "/" in nodeNames) was that zkcontroller should replace them "/"
with "_" -- but that would cause potential collisions between contexts like
"/foo/solr" and "/foo_solr", so i think using something like URLEncoding makes
more sense (and shouldn't impact existing ZK cluster state data for most
existing users)
The attached patch enhances the test base classes to allow for randomized
hostContext values, and then uses this URLEncoding logic in ZKController to
build nodeNames -- and in most cases seems to work. But thinking about "_" in
paths got me paranoid about explicitly testing that which is how I discovered
the crufty logic in OverseerCollectionProcessor. (NOTE: you can see the
obvious OverseerCollectionProcessor errors trying to talk to the wrong URL in
the test logs, and they seem to explain the subsequent test failure message,
but it's also possible there is a subsequent problem i haven't noticed yet)
I haven't dug into this part of the code/problem very much yet, but i *think*
the right fix here is to clean this up this code so that intead of making
assumptions about the node name, is uses the clusterstate to lookup the
base_url from the nodeName.
Logged error (repeated for multiple shards)...
{noformat}
[junit4:junit4] 2> 204647 T33 oasc.SolrException.log SEVERE Collection
createcollection of awholynewcollection_1 failed
[junit4:junit4] 2> 204686 T31 oasc.DistributedQueue$LatchChildWatcher.process
Watcher fired on path: /overseer/collection-queue-work state: SyncConnected
type NodeChildrenChanged
[junit4:junit4] 2> 204688 T33
oasc.OverseerCollectionProcessor.createCollection Create collection
awholynewcollection_2 on [127.0.0.1:57855_randctxmqvf%2F_ay,
127.0.0.1:37463_randctxmqvf%2F_ay]
[junit4:junit4] 2> 204691 T33
oasc.OverseerCollectionProcessor.createCollection SEVERE Error talking to
shard: 127.0.0.1:37463/randctxmqvf%2F/ay org.apache.solr.common.SolrException:
Server at http://127.0.0.1:37463/randctxmqvf%2F/ay returned non ok status:404,
message:Not Found
[junit4:junit4] 2> at
org.apache.solr.client.solrj.impl.HttpSolrServer.request(HttpSolrServer.java:372)
[junit4:junit4] 2> at
org.apache.solr.client.solrj.impl.HttpSolrServer.request(HttpSolrServer.java:181)
[junit4:junit4] 2> at
org.apache.solr.handler.component.HttpShardHandler$1.call(HttpShardHandler.java:166)
[junit4:junit4] 2> at
org.apache.solr.handler.component.HttpShardHandler$1.call(HttpShardHandler.java:133)
[junit4:junit4] 2> at
java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:334)
{noformat}
Final test failure message...
{noformat}
<testcase classname="org.apache.solr.cloud.BasicDistributedZkTest"
name="testDistribSearch" time="268.833">
<failure message="Could not find new 2 slice collection called
awholynewcollection_0"
type="java.lang.AssertionError">java.lang.AssertionError: Could not find new 2
slice collection called awholynewcollection_0
at
__randomizedtesting.SeedInfo.seed([1BD856523B97C07C:9A3ED84A4CC8A040]:0)
at org.junit.Assert.fail(Assert.java:93)
at
org.apache.solr.cloud.BasicDistributedZkTest.checkForCollection(BasicDistributedZkTest.java:1053)
at
org.apache.solr.cloud.BasicDistributedZkTest.testCollectionsAPI(BasicDistributedZkTest.java:768)
at
org.apache.solr.cloud.BasicDistributedZkTest.doTest(BasicDistributedZkTest.java:361)
at
org.apache.solr.BaseDistributedSearchTestCase.testDistribSearch(BaseDistributedSearchTestCase.java:712)
{noformat}
> SolrCloud bugs when servlet context contains "/" or "_"
> -------------------------------------------------------
>
> Key: SOLR-4136
> URL: https://issues.apache.org/jira/browse/SOLR-4136
> Project: Solr
> Issue Type: Bug
> Components: SolrCloud
> Affects Versions: 4.0
> Reporter: Hoss Man
> Assignee: Hoss Man
> Attachments: SOLR-4136.patch
>
>
> SolrCloud does not work properly with non-trivial values for "hostContext"
> (ie: the servlet context path). In particular...
> * Using a hostContext containing a "/" (ie: a servlet context with a subdir
> path, semi-common among people who organize webapps hierarchically for lod
> blanacer rules) is explicitly forbidden in ZkController because of how the
> hostContext is used to build a ZK nodeName
> * Using a hostContext containing a "_" causes problems in
> OverseerCollectionProcessor where it assumes all "_" characters should be
> converted to "/" to reconstitute a URL from nodeName (NOTE: this code
> specifically has a TODO to fix this, and then has a subsequent TODO about
> assuming "http://" labeled "this sucks")
--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators
For more information on JIRA, see: http://www.atlassian.com/software/jira
---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]