2014-02-12 2 views
1

solr.UUIDField를 사용하여 uniqueKey 필드를 생성하려고합니다.SOLR uniqueKey with solr.UUIDField

<fieldType name="uuid" class="solr.UUIDField" indexed="true" /> 


<field name="uid" type="uuid" indexed="true" stored="true" default="NEW" /> 

<uniqueKey>uid</uniqueKey> 

하지만 어떤 이유로 작동하지 않습니다.

오류 메시지 :

{MSG = SolrCore 'DB'는 때문에 초기화 실패로 사용할 수 없습니다 : uniqueKey 필드 (널) 디폴트 값 (NEW)와 함께 구성 할 수 없습니다. 스키마 파일은 \ example-DIH \ solr \ db \ schema.xml, trace = org.apache.solr.common.SolrException : init 실패로 인해 SolrCore 'db'를 사용할 수 없습니다 : uniqueKey 필드 (null)를 구성 할 수 없습니다 기본값은 NEW입니다. 스키마 파일은. \ example-DIH \ solr \ db \ schema.xml org.apache.solr.core.CoreContainer.getCore (CoreContainer.java:818) at org.apache.solr.servlet.SolrDispatchFilter.doFilter (org.eclipse.jetty.servlet.ServletHandler $ CachedChain.doFilter (ServletHandler.java:1419) 에서에서 org.apache.solr.servlet.SolrDispatchFilter.doFilter (SolrDispatchFilter.java:197) 에서 SolrDispatchFilter.java:289) org.eclipse.jetty.servlet.ServletHandler.doHandle (ServletHandler.java:455) at org.eclipse.jetty.server.handler.ScopedHandler.handle (ScopedHandler.java:137) at org.eclipse.jetty.security. SecurityHandler.handle (SecurityHandler.java:557) at org.eclipse.jetty.server.session.SessionHandler.doHandle (SessionHandler.java:231) at org.eclipse.jetty.server.handler.ContextHandler.doHandle (ContextHandler.java:1075) at org.eclipse.jetty.servlet.ServletHandler.doScope (ServletHandler.java:384) at org.eclipse.jetty.server. session.SessionHandler.doScope (SessionHandler.java:193) at org.eclipse.jetty.server.handler.ContextHandler.doScope (ContextHandler.java:1009) at org.eclipse.jetty.server.handler.ScopedHandler.handle (ScopedHandler.java:135) at org.eclipse.jetty.server.handler.ContextHandlerCollection.handle (ContextHandlerCollection.java:255) at org.eclipse.jetty.server.handler.HandlerCollection.handle (HandlerCollection.java:154) at org.eclipse.jetty.server.handler.HandlerWrapper.handle (HandlerWrapper.java:116) at org.eclipse.jetty.server.Server.handle (Server.ja 버지니아 : 368) org.eclipse.jetty.server.AbstractHttpConnection.handleRequest (AbstractHttpConnection.java:489에서 ) org.eclipse.jetty.server.BlockingHttpConnection.handleRequest (BlockingHttpConnection.java:53에서 ) org.eclipse에서 . jetty.server.AbstractHttpConnection.headerComplete (AbstractHttpConnection.java:942) at org.eclipse.jetty.server.AbstractHttpConnection $ RequestHandler.headerComplete (AbstractHttpConnection.java:1004) at org.eclipse.jetty.http.HttpParser.parseNext (org.eclipse.jetty.http.HttpParser.parseAvailable (HttpParser.java:235) 에서 org.eclipse.jetty.server.BlockingHttpConnection.handle (BlockingHttpConnection.java:72) at org. eclipse.jetty.server.bio.SocketConnector $ ConnectorEndPoint.run (SocketConnector.ja) 버지니아 : 264) org.eclipse.jetty.util.thread.QueuedThreadPool.runJob (QueuedThreadPool.java:608) 에서 org.eclipse.jetty.util.thread.QueuedThreadPool $ 3.run (QueuedThreadPool.java:543에서) java.lang.Thread.run (알 수없는 소스) 발생 원인 : org.apache.solr.common.SolrException : uniqueKey 필드 (null)를 기본값 (NEW)으로 구성 할 수 없습니다. 스키마 파일은 \ example-DIH \ solr \ db \ schema.xml 에서 org.apache.solr.schema.IndexSchema.readSchema (IndexSchema.java:608) at org.apache.solr.schema.IndexSchema. (IndexSchema .java : 166) 에서 org.apache.solr.schema.IndexSchemaFactory.create (IndexSchemaFactory.java:55) at org.apache.solr.schema.(CoreContainer.java:592)의 에서 IndexSchemaFactory.buildIndexSchema at org.apache.solr.core.CoreContainer $ 1.call (CoreContainer.java:271) at org.apache.solr.core.CoreContainer $ 1.call (CoreContainer.java:263) at java.util.concurrent. FutureTask $ Sync.innerRun (알 수없는 소스) at java.util.concurrent.FutureTask.run (알 수없는 소스) at java.util.concurrent.Executors $ RunnableAdapter.call (알 수없는 소스) at java.util.concurrent.FutureTask $ Sync.innerRun (알 수없는 소스) at java.util.concurrent.FutureTask.run (알 수없는 소스) at java.ut il.concurrent.ThreadPoolExecutor $ Worker.runTask (알 수없는 소스) ... 더 많은 : org.apache.solr.common.SolrException : uniqueKey 필드 (NULL) org.apache.solr.schema.IndexSchema.readSchema (IndexSchema.java:536)에서 디폴트 값 (NEW) 구성 할 수

UPDATE :

레오가 대답에서 제안한 변경 사항을 작성한 후에 다음 오류 메시지가 수신되었습니다.

또한 dataimporthandler를 사용할 때 오류 메시지가 표시된다는 사실을 잊어 버렸습니다.

{msg=SolrCore 'db' is not available due to init failure: Error initializing QueryElevationComponent.,trace=org.apache.solr.common.SolrException: SolrCore 'db' is not available due to init failure: Error initializing QueryElevationComponent. 
at org.apache.solr.core.CoreContainer.getCore(CoreContainer.java:818) 
at org.apache.solr.servlet.SolrDispatchFilter.doFilter(SolrDispatchFilter.java:289) 
at org.apache.solr.servlet.SolrDispatchFilter.doFilter(SolrDispatchFilter.java:197) 
at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1419) 
at org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:455) 
at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:137) 
at org.eclipse.jetty.security.SecurityHandler.handle(SecurityHandler.java:557) 
at org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java:231) 
at org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1075) 
at org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:384) 
at org.eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java:193) 
at org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1009) 
at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:135) 
at org.eclipse.jetty.server.handler.ContextHandlerCollection.handle(ContextHandlerCollection.java:255) 
at org.eclipse.jetty.server.handler.HandlerCollection.handle(HandlerCollection.java:154) 
at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:116) 
at org.eclipse.jetty.server.Server.handle(Server.java:368) 
at org.eclipse.jetty.server.AbstractHttpConnection.handleRequest(AbstractHttpConnection.java:489) 
at org.eclipse.jetty.server.BlockingHttpConnection.handleRequest(BlockingHttpConnection.java:53) 
at org.eclipse.jetty.server.AbstractHttpConnection.headerComplete(AbstractHttpConnection.java:942) 
at org.eclipse.jetty.server.AbstractHttpConnection$RequestHandler.headerComplete(AbstractHttpConnection.java:1004) 
at org.eclipse.jetty.http.HttpParser.parseNext(HttpParser.java:640) 
at org.eclipse.jetty.http.HttpParser.parseAvailable(HttpParser.java:235) 
at org.eclipse.jetty.server.BlockingHttpConnection.handle(BlockingHttpConnection.java:72) 
at org.eclipse.jetty.server.bio.SocketConnector$ConnectorEndPoint.run(SocketConnector.java:264) 
at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:608) 
at org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:543) 
at java.lang.Thread.run(Unknown Source) 
Caused by: org.apache.solr.common.SolrException: Error initializing QueryElevationComponent. 
at org.apache.solr.core.SolrCore.<init>(SolrCore.java:834) 
at org.apache.solr.core.SolrCore.<init>(SolrCore.java:625) 
at org.apache.solr.core.CoreContainer.createFromLocal(CoreContainer.java:557) 
at org.apache.solr.core.CoreContainer.create(CoreContainer.java:592) 
at org.apache.solr.core.CoreContainer$1.call(CoreContainer.java:271) 
at org.apache.solr.core.CoreContainer$1.call(CoreContainer.java:263) 
at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source) 
at java.util.concurrent.FutureTask.run(Unknown Source) 
at java.util.concurrent.Executors$RunnableAdapter.call(Unknown Source) 
at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source) 
at java.util.concurrent.FutureTask.run(Unknown Source) 
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(Unknown Source) 
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) 
... 1 more 
Caused by: org.apache.solr.common.SolrException: Error initializing QueryElevationComponent. 
at org.apache.solr.handler.component.QueryElevationComponent.inform(QueryElevationComponent.java:242) 
at org.apache.solr.core.SolrResourceLoader.inform(SolrResourceLoader.java:631) 
at org.apache.solr.core.SolrCore.<init>(SolrCore.java:829) 
... 13 more 
Caused by: org.apache.solr.common.SolrException: Invalid UUID String: '1' 
at org.apache.solr.schema.UUIDField.toInternal(UUIDField.java:89) 
at org.apache.solr.schema.FieldType.readableToIndexed(FieldType.java:391) 
at org.apache.solr.handler.component.QueryElevationComponent$ElevationObj.<init>(QueryElevationComponent.java:138) 
at org.apache.solr.handler.component.QueryElevationComponent.loadElevationMap(QueryElevationComponent.java:311) 
at org.apache.solr.handler.component.QueryElevationComponent.inform(QueryElevationComponent.java:225) 

나는 다음 제거하려하지만 아무 것도 색인되지 않은 : 당신은 다음과 같은 구성을해야 할 수도 있습니다,

<searchComponent name="elevator" class="org.apache.solr.handler.component.QueryElevationComponent" > 
    <!-- pick a fieldType to analyze queries --> 
    <str name="queryFieldType">string</str> 
    <str name="config-file">elevate.xml</str> 
</searchComponent> 
+0

solr 3에서만 작동 할 수 있습니다. 사용중인 solr 버전은 무엇입니까? – leoh

+0

solr-4.6.0,이 버전에서 무엇을 사용해야합니까? – MikeAlike234

답변

4

David2342

을 SOLR 4.6의 UUID 필드를 구성하려면

<!--schema.xml--> 

<fieldType name="uuid" class="solr.UUIDField" indexed="true" /> 

<field name="id" type="uuid" indexed="true" stored="true" required="true" /> 

<uniqueKey>id</uniqueKey> 

<!--solrconfig.xml--> 
<updateRequestProcessorChain name="uuid"> 
    <processor class="solr.UUIDUpdateProcessorFactory"> 
     <str name="fieldName">id</str> 
    </processor> 
    <processor class="solr.RunUpdateProcessorFactory" /> 
</updateRequestProcessorChain> 


<requestHandler name="/update" class="solr.UpdateRequestHandler"> 
     <lst name="defaults"> 
     <str name="update.chain">uuid</str> 
     </lst> 
</requestHandler> 

다음은 나를 위해 작동하는 예제 구성에 대한 링크입니다 : https://gist.github.com/leoh/8967328

+0

고마워요! 나는 당신의 제안을 시도했다, 업데이트를 보아라. – MikeAlike234

+0

업데이트가 작동하지 않도록하십시오. – MikeAlike234

1

"init failure :"오류로 인해 elevate.xml 파일에서 uid를 수정해야합니다. 파일 높이기의 기본 경로는

일 수 있습니다. 파일 경로가 다를 수 있습니다.

elevate.xml 파일의 정확한 위치를 알고 싶다면 elevate.xml 파일을 첨부하십시오.

관련 문제