Springboot整合Elasticsearch实现全文检索时:启动报错Caused by: java.lang.IllegalStateException: availableProcessors

Springboot整合Elasticsearch实现全文检索时:启动报错Caused by: java.lang.IllegalStateException: availableProcessors is already set to [8], rejecting [8]

简述:

我最近在研究使用Elasticsearch实现全文检索时,遇到一个逻辑问题,我是利用logstash通过mysql数据库定时去更新es索引库的,这样就存在一个问题,我是通过mysql去同步索引库,所以数据只需要第一时间存到数据库,一定时间后logstash会自动更新,所以dao的接口只需要继承JPA的JpaRepository即可实现数据库的增删改查,但是这时就存在一个问题,写es查询接口的时候,dao层需要继承ElasticsearchRepository才可以从es服务器获得数据,这样就必须写两个dao,但是两个dao中的
在这里插入图片描述实体类就存在了问题,一个需要加@Document(indexName = “shop_product”, type = “doc”)用于规定es的索引+类型,另一个就是常规的,我没有尝试用一个实体类直接加@Document注解,我是又拷贝了一份只保留了@Document注解进行es映射,另一个就是常规的jpa映射,这样就完成了额,然后启动项目。。。

然后就报错了!!!

Caused by: java.lang.IllegalStateException: availableProcessors is already set to [8], rejecting [8]

然后我搜索解答,最终的解决方式是:在springboot启动类的main方法加如下代码

@EnableScheduling
@SpringBootApplication
@MapperScan("com.sxd.swapping.dao.mybatis")
public class SwappingApplication {

    public static void main(String[] args) {
        /**
         * Springboot整合Elasticsearch 在项目启动前设置一下的属性,防止报错
         * 解决netty冲突后初始化client时还会抛出异常
         * java.lang.IllegalStateException: availableProcessors is already set to [4], rejecting [4]
         */
        System.setProperty("es.set.netty.runtime.available.processors", "false");
        SpringApplication.run(SwappingApplication.class, args);
    }
}

再启动就完成了!!!

发布了21 篇原创文章 · 获赞 10 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/weixin_44167913/article/details/101378518