spring-boot redis/elasticsearcht启动报错:availableProcessors is already set to [8], rejecting [8]

今天把一个springboot应用部署到服务器上,启动时报错:

Caused by: org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.elasticsearch.client.Client]: Factory method 'client' threw exception; nested exception is java.lang.IllegalStateException: availableProcessors is already set to [8], rejecting [8]
    at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:185)
    at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:582)
    ... 107 more
Caused by: java.lang.IllegalStateException: availableProcessors is already set to [8], rejecting [8]

问题也很奇怪,在我本机IDEA上没问题,部署到测试环境服务器也没问题,怎么一个UAT环境就有问题了呢?两个环境唯一不同的是UAT环境CPU数量比较多,为8核心。网上查了一圈,发现netty项目的github上有报告这个异常:
https://github.com/netty/netty/issues/6956
帖子里说这不是netty的bug,可能是先初始化了netty再初始化Esclient造成的,但感觉不是很有道理,要不然为什么其它环境没问题,偏偏都是8个cpu核心有问题呢?帖子里也给出了临时解决办法,就是加一个启动的jvm参数:

-Des.set.netty.runtime.available.processors=false
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值