2017-05-23 2 views
0

私はsolrJを使用してsolrデータ[solr cloud 6.5 - 3 machines]を挿入/照会しています。以前の私はSolrClientを作成するためのコードの下に使用 -solrJでの動物園の設定スロー読み込みタイムアウト例外

HttpSolrClient server; 
server = new HttpSolrClient.Builder("").build(); 
server.setSoTimeout(20000); 
server.setConnectionTimeout(20000); 
server.setDefaultMaxConnectionsPerHost(200); 
server.setMaxTotalConnections(200); 
server.setFollowRedirects(false); 
server.setAllowCompression(true); 

を今私はこのSolrのクラウド上の3飼育係・サーバを構成しました。 Solrのクライアントを作成するためのコードはなった -

CloudSolrClient server; 
String serverURL="zkapp1,zkapp2,zkapp3"; 
ArrayList zkHosts = newrrayList(Arrays.asList(serverURL.split(","))); 
server = new CloudSolrClient.Builder().withZkHost(zkHosts).build(); 
server.setSoTimeout(20000); 
server.setZkConnectTimeout(20000); 
server.setDefaultCollection("testSolr"); 

私は私が前に存在した他のプロパティ[DefaultMaxConnectionsPerHost、MaxTotalConnections、FollowRedirects、AllowCompression]を指定する必要がありますかどこかを知りたいです。

[いくつかの成功のヒット後(読み取り/書き込み)]例外以下のいくつかの時間が観測された後、なぜなら、これらの設定で飼育係を構成する方法を案内してください -

org.apache.solr.client.solrj.SolrServerException: Timeout occured while waiting response from server at: http://solr6CLoudMachine:8983/solr/testSolr 
at org.apache.solr.client.solrj.impl.HttpSolrClient.executeMethod(HttpSolrClient.java:621) 
at org.apache.solr.client.solrj.impl.HttpSolrClient.request(HttpSolrClient.java:279) 
at org.apache.solr.client.solrj.impl.HttpSolrClient.request(HttpSolrClient.java:268) 
at org.apache.solr.client.solrj.SolrRequest.process(SolrRequest.java:149) 
at org.apache.solr.client.solrj.SolrClient.commit(SolrClient.java:484) 
at org.apache.solr.client.solrj.SolrClient.commit(SolrClient.java:463) 
at com.til.damcore.repository.DAMCoreSolrManager.insertContent(DAMCoreSolrManager.java:288) 
at com.til.damcore.services.CMSContentUploadServiceSolrOnly.uploadCMSContent(CMSContentUploadServiceSolrOnly.java:227) 
at com.til.damapi.service.InsertContentService.insertSolrOnlyContent(InsertContentService.java:136) 
at com.til.damapi.controller.insert.InsertionController.insertDataSolr6(InsertionController.java:175) 
at sun.reflect.GeneratedMethodAccessor155.invoke(Unknown Source) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
at java.lang.reflect.Method.invoke(Method.java:497) 
at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:222) 
at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:137) 
at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:110) 
at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:814) 
at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:737) 
at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:85) 
at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:959) 
at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:893) 
at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:969) 
at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:871) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:647) 
at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:845) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:728) 
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305) 
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:121) 
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) 
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243) 
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:222) 
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123) 
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472) 
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:171) 
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:99) 
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:953) 
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118) 
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:408) 
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1023) 
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:589) 
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:312) 
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) 
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) 
at java.lang.Thread.run(Thread.java:745) 
    Caused by: java.net.SocketTimeoutException: Read timed out 
at java.net.SocketInputStream.socketRead0(Native Method) 
at java.net.SocketInputStream.socketRead(SocketInputStream.java:116) 
at java.net.SocketInputStream.read(SocketInputStream.java:170) 
at java.net.SocketInputStream.read(SocketInputStream.java:141) 
at org.apache.http.impl.io.AbstractSessionInputBuffer.fillBuffer(AbstractSessionInputBuffer.java:160) 
at org.apache.http.impl.io.SocketInputBuffer.fillBuffer(SocketInputBuffer.java:84) 
at org.apache.http.impl.io.AbstractSessionInputBuffer.readLine(AbstractSessionInputBuffer.java:273) 
at org.apache.http.impl.conn.DefaultHttpResponseParser.parseHead(DefaultHttpResponseParser.java:140) 
at org.apache.http.impl.conn.DefaultHttpResponseParser.parseHead(DefaultHttpResponseParser.java:57) 
at org.apache.http.impl.io.AbstractMessageParser.parse(AbstractMessageParser.java:261) 
at org.apache.http.impl.AbstractHttpClientConnection.receiveResponseHeader(AbstractHttpClientConnection.java:283) 
at org.apache.http.impl.conn.DefaultClientConnection.receiveResponseHeader(DefaultClientConnection.java:251) 
at org.apache.http.impl.conn.ManagedClientConnectionImpl.receiveResponseHeader(ManagedClientConnectionImpl.java:197) 
at org.apache.http.protocol.HttpRequestExecutor.doReceiveResponse(HttpRequestExecutor.java:272) 
at org.apache.http.protocol.HttpRequestExecutor.execute(HttpRequestExecutor.java:124) 
at org.apache.http.impl.client.DefaultRequestDirector.tryExecute(DefaultRequestDirector.java:685) 
at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:487) 
at org.apache.http.impl.client.AbstractHttpClient.doExecute(AbstractHttpClient.java:882) 
at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:82) 
at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:55) 
at org.apache.solr.client.solrj.impl.HttpSolrClient.executeMethod(HttpSolrClient.java:515) 
... 45 more 

は誰もがお勧め生産されているものを提案してくださいすることができ動物園の設定?

私は完全に詰まっています。

ご協力いただきまして誠にありがとうございます。

おかげで、

Vibhav

答えて

0

あなたはSolrCloudと一緒にSolrJを使用している場合は、飼育係は、Solrのインスタンスがあり、あなたの例外を見て、あなたが接続する必要がSolrのインスタンスの名前またはIPを返します。 solr6CLoudMachine

最初に確認する必要があるのは、SolrJクライアントを実行しているホストからsolr6CLoudMachineにアクセスできるかどうかです。例えば

、まずあなたがシェルからsolr6CLoudMachineのIPアドレスを解決することができます参照してみてください:

ping solr6CLoudMachine 

次にあなたがポートに到達できるかどうか試してみてください。

curl http://solr6CLoudMachine:8983/solr/ 

そして再び、ことを考えますあなたはSolrClouldクラスターに直面していますが、到達するSolrインスタンスが複数ある可能性は非常に高いです。

したがって、SolrJクライアントを実行しているホストから、ターゲットコレクションが配置されているすべてのSolrインスタンスにアクセスできるはずです。

+0

HI @freedev:応答ありがとうございます。私はすでにpingがソースマシンから正常に動作していることを確認しました。この例外は、成功したヒットの後に発生します。私の悪い、私はこの問題については言及していませんでした。 –

関連する問題