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);
}
}
再启动就完成了!!!