【异常解决】springBoot单元测试es报错availableProcessors is already set to [8], rejecting [8] 已解决

文章讨论了在使用SpringBoot和Elasticsearch时遇到的IllegalStateException,原因是availableProcessors已设置。解决方案是在单元测试中通过添加静态代码块禁用处理器计数。
摘要由CSDN通过智能技术生成

1、异常详情:

Caused by: java.lang.IllegalStateException: availableProcessors is already set to [8], rejecting [8]
	at io.netty.util.NettyRuntime$AvailableProcessorsHolder.setAvailableProcessors(NettyRuntime.java:51)
	at io.netty.util.NettyRuntime.setAvailableProcessors(NettyRuntime.java:87)
	at org.elasticsearch.transport.netty4.Netty4Utils.setAvailableProcessors(Netty4Utils.java:83)
	at org.elasticsearch.transport.netty4.Netty4Transport.<init>(Netty4Transport.java:112)
	at org.elasticsearch.transport.Netty4Plugin.lambda$getTransports$0(Netty4Plugin.java:86)
	at org.elasticsearch.client.transport.TransportClient.buildTemplate(TransportClient.java:189)
	at org.elasticsearch.client.transport.TransportClient.<init>(TransportClient.java:283)
	at org.elasticsearch.transport.client.PreBuiltTransportClient.<init>(PreBuiltTransportClient.java:128)
	at org.elasticsearch.transport.client.PreBuiltTransportClient.<init>(PreBuiltTransportClient.java:114)
	at org.elasticsearch.transport.client.PreBuiltTransportClient.<init>(PreBuiltTransportClient.java:104)
	at org.springframework.data.elasticsearch.client.TransportClientFactoryBean.buildClient(TransportClientFactoryBean.java:85)
	at org.springframework.data.elasticsearch.client.TransportClientFactoryBean.afterPropertiesSet(TransportClientFactoryBean.java:80)
	at org.springframework.boot.autoconfigure.data.elasticsearch.ElasticsearchAutoConfiguration.elasticsearchClient(ElasticsearchAutoConfiguration.java:59)
	at org.springframework.boot.autoconfigure.data.elasticsearch.ElasticsearchAutoConfiguration$$EnhancerBySpringCGLIB$$11f6a01.CGLIB$elasticsearchClient$0(<generated>)
	at org.springframework.boot.autoconfigure.data.elasticsearch.ElasticsearchAutoConfiguration$$EnhancerBySpringCGLIB$$11f6a01$$FastClassBySpringCGLIB$$c5062c8c.invoke(<generated>)
	at org.springframework.cglib.proxy.MethodProxy.invokeSuper(MethodProxy.java:244)
	at org.springframework.context.annotation.ConfigurationClassEnhancer$BeanMethodInterceptor.intercept(ConfigurationClassEnhancer.java:363)
	at org.springframework.boot.autoconfigure.data.elasticsearch.ElasticsearchAutoConfiguration$$EnhancerBySpringCGLIB$$11f6a01.elasticsearchClient(<generated>)
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
	at java.lang.reflect.Method.invoke(Method.java:498)
	at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:154)
	... 188 more

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 [8], rejecting [8]
    at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:185)
    at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:622)

2、解决方案 :

1、在单元测试上面添加静态代码块,我的就是这样解决的

 static {

        System.setProperty("es.set.netty.runtime.available.processors", "false");

    }

@SpringBootTest(classes = ApiApplication.class)
@RunWith(SpringRunner.class)
@Slf4j
public class IcBcPayCallbackNotifyTest {

    static {

        System.setProperty("es.set.netty.runtime.available.processors", "false");

    }
    @Resource
    private OrderIcBcPayController orderIcBcPayController;
    @Mock
    private HttpServletRequest httpServletRequest;


    @Test
    public void payCallbackNotifyTest() throws Exception {
        HashMap<Object, Object> bizContent = new HashMap<>();
       }
}

  • 10
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
这个错误消息表明 Elasticsearch 的可用处理器数量已经被设置为 8,再次尝试将其设置为 8 时被拒绝了。这是由于 Elasticsearch 在初始化时只允许设置一次可用处理器数量,无法重复设置。 解决这个问题的方法是确保只有一处设置了可用处理器数量的地方,并且值是一致的。您可以按照以下步骤进行排查: 1. 检查您的代码,确保只有一处设置了可用处理器数量。可能是在不同的配置文件或代码段中重复设置了该属性。 2. 确保您的依赖库和 Elasticsearch 版本兼容。某些版本的 Elasticsearch 客户端可能对可用处理器数量的设置有限制或者不兼容。 3. 如果您在代码中使用了其他第三方库或者框架,尝试查找是否有类似于设置可用处理器数量的配置项,可能会与 Elasticsearch 的设置冲突。 为了解决这个问题,您可以尝试以下操作: 1. 将所有设置可用处理器数量的地方都移除,并确保只在一个地方进行设置。如果您使用的是 Spring Boot,可以考虑使用 `spring.data.elasticsearch.properties` 属性来集中配置 Elasticsearch 的相关属性。 2. 如果您没有特殊需求,可以尝试删除手动设置可用处理器数量的代码,让 Elasticsearch 使用默认值。 3. 如果您确实需要手动设置可用处理器数量,尝试将其设置为不同于 8 的值,例如 4 或 16,以避免冲突。 请注意,以上解决方案仅为参考,请根据具体情况进行调整。如果问题仍然存在,建议查阅 Elasticsearch 的官方文档或者咨询 Elasticsearch 社区获取更详细的帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值