Springboot整合Elasticsearch 报错availableProcessors is already set to [4], rejecting [4]

ゝ一世哀愁。 2021-11-29 18:14 322阅读 0赞

1、异常信息:

  1. Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'elasticsearchClient' defined in class path resource [org/springframework/boot/autoconfigure/data/elasticsearch/ElasticsearchAutoConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.elasticsearch.client.transport.TransportClient]: Factory method 'elasticsearchClient' threw exception; nested exception is java.lang.IllegalStateException: availableProcessors is already set to [4], rejecting [4]
  2. at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:627)
  3. at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:456)
  4. at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1321)
  5. at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1160)
  6. at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:555)
  7. at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:515)
  8. at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:320)
  9. at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222)
  10. at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:318)
  11. at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:199)
  12. at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:277)
  13. at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1247)
  14. at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1167)
  15. at org.springframework.beans.factory.support.ConstructorResolver.resolveAutowiredArgument(ConstructorResolver.java:857)
  16. at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:760)
  17. ... 71 more
  18. Caused by: org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.elasticsearch.client.transport.TransportClient]: Factory method 'elasticsearchClient' threw exception; nested exception is java.lang.IllegalStateException: availableProcessors is already set to [4], rejecting [4]
  19. at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:185)
  20. at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:622)
  21. ... 85 more
  22. Caused by: java.lang.IllegalStateException: availableProcessors is already set to [4], rejecting [4]
  23. at io.netty.util.NettyRuntime$AvailableProcessorsHolder.setAvailableProcessors(NettyRuntime.java:51)
  24. at io.netty.util.NettyRuntime.setAvailableProcessors(NettyRuntime.java:87)
  25. at org.elasticsearch.transport.netty4.Netty4Utils.setAvailableProcessors(Netty4Utils.java:83)
  26. at org.elasticsearch.transport.netty4.Netty4Transport.<init>(Netty4Transport.java:112)
  27. at org.elasticsearch.transport.Netty4Plugin.lambda$getTransports$0(Netty4Plugin.java:86)
  28. at org.elasticsearch.client.transport.TransportClient.buildTemplate(TransportClient.java:189)
  29. at org.elasticsearch.client.transport.TransportClient.<init>(TransportClient.java:283)
  30. at org.elasticsearch.transport.client.PreBuiltTransportClient.<init>(PreBuiltTransportClient.java:128)
  31. at org.elasticsearch.transport.client.PreBuiltTransportClient.<init>(PreBuiltTransportClient.java:114)
  32. at org.elasticsearch.transport.client.PreBuiltTransportClient.<init>(PreBuiltTransportClient.java:104)
  33. at org.springframework.data.elasticsearch.client.TransportClientFactoryBean.buildClient(TransportClientFactoryBean.java:85)
  34. at org.springframework.data.elasticsearch.client.TransportClientFactoryBean.afterPropertiesSet(TransportClientFactoryBean.java:80)
  35. at org.springframework.boot.autoconfigure.data.elasticsearch.ElasticsearchAutoConfiguration.elasticsearchClient(ElasticsearchAutoConfiguration.java:60)
  36. at org.springframework.boot.autoconfigure.data.elasticsearch.ElasticsearchAutoConfiguration$$EnhancerBySpringCGLIB$$1dab9073.CGLIB$elasticsearchClient$0(<generated>)
  37. at org.springframework.boot.autoconfigure.data.elasticsearch.ElasticsearchAutoConfiguration$$EnhancerBySpringCGLIB$$1dab9073$$FastClassBySpringCGLIB$$5f6ed40d.invoke(<generated>)
  38. at org.springframework.cglib.proxy.MethodProxy.invokeSuper(MethodProxy.java:244)
  39. at org.springframework.context.annotation.ConfigurationClassEnhancer$BeanMethodInterceptor.intercept(ConfigurationClassEnhancer.java:363)
  40. at org.springframework.boot.autoconfigure.data.elasticsearch.ElasticsearchAutoConfiguration$$EnhancerBySpringCGLIB$$1dab9073.elasticsearchClient(<generated>)
  41. at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
  42. at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
  43. at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
  44. at java.lang.reflect.Method.invoke(Method.java:498)
  45. at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:154)
  46. ... 86 more
  47. 22-Jul-2019 11:02:36.069 SEVERE [localhost-startStop-1]

2、pom.xml(部分截图)

  1. <parent>
  2. <groupId>org.springframework.boot</groupId>
  3. <artifactId>spring-boot-starter-parent</artifactId>
  4. <version>2.1.4.RELEASE</version>
  5. <relativePath/> <!-- lookup parent from repository -->
  6. </parent>
  7. <dependency>
  8. <groupId>org.springframework.boot</groupId>
  9. <artifactId>spring-boot-starter-data-elasticsearch</artifactId>
  10. </dependency>
  11. <dependency>
  12. <groupId>redis.clients</groupId>
  13. <artifactId>jedis</artifactId>
  14. <version>2.9.0</version>
  15. </dependency>

附(链接):github上在netty项目下大佬回复的解决办法 (谷歌翻译了下)

" class="reference-link">20190722165344602.png

ps:后面看了下github上他的资料(jasontedor),发现他是Elasticsearch 项目的参与者之一;

网上的大部分方法是:

在springboot的启动类中的main方法里加上 System.setProperty(“es.set.netty.runtime.available.processors”,”false”);

  1. public static void main(String[] args) {
  2. /**
  3. * 防止netty的bug
  4. * java.lang.IllegalStateException: availableProcessors is already set to [4], rejecting [4]
  5. */
  6. //加上下面这段话
  7. System.setProperty("es.set.netty.runtime.available.processors","false");
  8. SpringApplication.run(TestApplication.class, args);
  9. }

但是并没有解决我的问题,我的问题是本地能正常运行,并无异常,但是放在服务器上运行tomcat就会启动失败,并报上述错误;

后将代码段:System.setProperty(“es.set.netty.runtime.available.processors”,”false”;挪到静态代码块中;

如下:

  1. static{
  2. System.setProperty("es.set.netty.runtime.available.processors", "false");
  3. }
  4. public static void main(String[] args) {
  5. /**
  6. * 防止netty的bug
  7. * java.lang.IllegalStateException: availableProcessors is already set to [4], rejecting [4]
  8. */
  9. //System.setProperty("es.set.netty.runtime.available.processors","false");
  10. SpringApplication.run(TestApplication.class, args);
  11. }

目前本地及服务器均正常运行。

发表评论

表情:
评论列表 (有 0 条评论,322人围观)

还没有评论,来说两句吧...

相关阅读