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>
solr 3에서만 작동 할 수 있습니다. 사용중인 solr 버전은 무엇입니까? – leoh
solr-4.6.0,이 버전에서 무엇을 사용해야합니까? – MikeAlike234