记录一下springboot(2.2.3.RELEASE)+elasticsearch6.2.2遇到的问题

首先项目引入相关依赖如下:

复制代码
<dependency>
   <groupId>org.elasticsearch</groupId>
   <artifactId>elasticsearch</artifactId>
   <version>6.2.2</version>
</dependency>
复制代码
<dependency>
   <groupId>org.springframework.data</groupId>
   <artifactId>spring-data-elasticsearch</artifactId>
   <version>3.1.0.RELEASE</version>
</dependency>

项目启动报错,异常信息如下:

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

at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:656) ~spring-beans-5.2.3.RELEASE.jar:5.2.3.RELEASE

at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:484) ~spring-beans-5.2.3.RELEASE.jar:5.2.3.RELEASE

at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1338) ~spring-beans-5.2.3.RELEASE.jar:5.2.3.RELEASE

at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1177) ~spring-beans-5.2.3.RELEASE.jar:5.2.3.RELEASE

at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:557) ~spring-beans-5.2.3.RELEASE.jar:5.2.3.RELEASE

at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:517) ~spring-beans-5.2.3.RELEASE.jar:5.2.3.RELEASE

at org.springframework.beans.factory.support.AbstractBeanFactory.lambdadoGetBean0(AbstractBeanFactory.java:323) ~spring-beans-5.2.3.RELEASE.jar:5.2.3.RELEASE

at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222) ~spring-beans-5.2.3.RELEASE.jar:5.2.3.RELEASE

at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:321) ~spring-beans-5.2.3.RELEASE.jar:5.2.3.RELEASE

at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:202) ~spring-beans-5.2.3.RELEASE.jar:5.2.3.RELEASE

at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:879) ~spring-beans-5.2.3.RELEASE.jar:5.2.3.RELEASE

at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:878) ~spring-context-5.2.3.RELEASE.jar:5.2.3.RELEASE

at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:550) ~spring-context-5.2.3.RELEASE.jar:5.2.3.RELEASE

at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:141) ~spring-boot-2.2.3.RELEASE.jar:2.2.3.RELEASE

at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:747) spring-boot-2.2.3.RELEASE.jar:2.2.3.RELEASE

at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:397) spring-boot-2.2.3.RELEASE.jar:2.2.3.RELEASE

at org.springframework.boot.SpringApplication.run(SpringApplication.java:315) spring-boot-2.2.3.RELEASE.jar:2.2.3.RELEASE

at org.springframework.boot.SpringApplication.run(SpringApplication.java:1226) spring-boot-2.2.3.RELEASE.jar:2.2.3.RELEASE

at org.springframework.boot.SpringApplication.run(SpringApplication.java:1215) spring-boot-2.2.3.RELEASE.jar:2.2.3.RELEASE

at com.gy.hsxt.wx.card.access.HsOutthirdsWxCardAccessApplication.main(HsOutthirdsWxCardAccessApplication.java:17) classes/:?

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

at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:185) ~spring-beans-5.2.3.RELEASE.jar:5.2.3.RELEASE

at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:651) ~spring-beans-5.2.3.RELEASE.jar:5.2.3.RELEASE

... 19 more

Caused by: java.lang.IllegalStateException: availableProcessors is already set to 4, rejecting 4

at io.netty.util.NettyRuntime$AvailableProcessorsHolder.setAvailableProcessors(NettyRuntime.java:51) ~netty-common-4.1.45.Final.jar:4.1.45.Final

at io.netty.util.NettyRuntime.setAvailableProcessors(NettyRuntime.java:87) ~netty-common-4.1.45.Final.jar:4.1.45.Final

at org.elasticsearch.transport.netty4.Netty4Utils.setAvailableProcessors(Netty4Utils.java:85) ~transport-netty4-client-6.2.2.jar:6.2.2

at org.elasticsearch.transport.netty4.Netty4Transport.<init>(Netty4Transport.java:113) ~transport-netty4-client-6.2.2.jar:6.2.2

at org.elasticsearch.transport.Netty4Plugin.lambdagetTransports0(Netty4Plugin.java:86) ~transport-netty4-client-6.2.2.jar:6.2.2

at org.elasticsearch.client.transport.TransportClient.buildTemplate(TransportClient.java:179) ~elasticsearch-6.2.2.jar:6.2.2

at org.elasticsearch.client.transport.TransportClient.<init>(TransportClient.java:273) ~elasticsearch-6.2.2.jar:6.2.2

at org.elasticsearch.transport.client.PreBuiltTransportClient.<init>(PreBuiltTransportClient.java:128) ~transport-6.2.2.jar:6.2.2

at org.elasticsearch.transport.client.PreBuiltTransportClient.<init>(PreBuiltTransportClient.java:114) ~transport-6.2.2.jar:6.2.2

at org.elasticsearch.transport.client.PreBuiltTransportClient.<init>(PreBuiltTransportClient.java:104) ~transport-6.2.2.jar:6.2.2

at org.springframework.data.elasticsearch.client.TransportClientFactoryBean.buildClient(TransportClientFactoryBean.java:85) ~spring-data-elasticsearch-3.1.0.RELEASE.jar:3.1.0.RELEASE

at org.springframework.data.elasticsearch.client.TransportClientFactoryBean.afterPropertiesSet(TransportClientFactoryBean.java:80) ~spring-data-elasticsearch-3.1.0.RELEASE.jar:3.1.0.RELEASE

at org.springframework.boot.autoconfigure.data.elasticsearch.ElasticsearchAutoConfiguration.elasticsearchClient(ElasticsearchAutoConfiguration.java:59) ~spring-boot-autoconfigure-2.2.3.RELEASE.jar:2.2.3.RELEASE

at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~?:1.8.0_181

at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~?:1.8.0_181

at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~?:1.8.0_181

at java.lang.reflect.Method.invoke(Method.java:498) ~?:1.8.0_181

at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:154) ~spring-beans-5.2.3.RELEASE.jar:5.2.3.RELEASE

at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:651) ~spring-beans-5.2.3.RELEASE.jar:5.2.3.RELEASE

... 19 more

解决方法:新建一个ElasticSearchConfig类初始化elasticsearchTemplate

复制代码
@Configuration
@EnableElasticsearchRepositories(basePackages = "com.gy.hsxt.geoaddress.access.repository")
public class ElasticSearchConfig {
   
    /**
     * 创建模板
     * @return
     */
    @Bean
    public ElasticsearchOperations elasticsearchTemplate() {

        System.setProperty("es.set.netty.runtime.available.processors", "false");
        String clusterNodes="192.168.12.50";
        String clusterName="elasticsearch";

        TransportClient client=null;

        try {
            Settings settings = Settings.builder()
                    .put("cluster.name", clusterName)
                    .put("client.transport.sniff", false)
                    .build();
            client =new PreBuiltTransportClient(settings);
            //地址转换
            if(StringUtils.isNotBlank(clusterNodes)){
                for (String clusterNode : StringUtils.split(clusterNodes, ",")) {
                    String ip = StringUtils.substringBeforeLast(clusterNode, ":");
                    String port = StringUtils.substringAfterLast(clusterNode, ":");
                    client.addTransportAddress(new TransportAddress(InetAddress.getByName(ip), Integer.valueOf(port)));
                }
            }
        } catch (Exception e) {
        }

        return new ElasticsearchTemplate(client);
    }

    /**
     * 防止netty的bug
     * java.lang.IllegalStateException: availableProcessors is already set to [4], rejecting [4]
     */
    @PostConstruct
    void init() {
        System.setProperty("es.set.netty.runtime.available.processors", "false");
    }
相关推荐
devilnumber1 小时前
Java 二分查找(二分算法)详解 + 实战运用 + 核心坑点
java·开发语言·算法
仍然.1 小时前
SpringBoot快速上手
java·spring boot·后端
ch.ju1 小时前
Java程序设计(第3版)第四章——重载和覆盖的区别
java·开发语言
浮尘笔记1 小时前
Go实现大文件异步流式采集引擎
开发语言·后端·golang
霸道流氓气质1 小时前
Spring Boot 大数据量 Excel 导入导出功能实现指南
spring boot·后端·excel
仍然.1 小时前
Spring MVC(1)---介绍Spring MVC 和 请求数据
java·spring·mvc
DianSan_ERP1 小时前
架构师视角:电商大促高并发下的订单API限流与防漏单架构演进
java·运维·网络·安全·微服务·架构·自动化
云烟成雨TD1 小时前
Agent Scope Java 2.x 系列【6】消息层
java·人工智能·agent
云烟成雨TD1 小时前
Spring AI Alibaba 1.x 系列【74】Agentic RAG 与混合 RAG
java·人工智能·spring
小刘|1 小时前
Spring AI 结构化输出 + 大模型参数全解(含千问调优)
java·后端·spring