ElasticSearch Java API连接报错NoNodeAvailableException解决方案
2021/6/2 20:22:44
本文主要是介绍ElasticSearch Java API连接报错NoNodeAvailableException解决方案,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
如下代码:
public static void creatIndex(){ // 1、获取客户端对象,设置连接的集群名称 Settings settings= Settings.builder().put("cluster.name","elasticsearch").build(); client=new PreBuiltTransportClient(settings); // 2、连接集群 try { client.addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName("hadoop-001"), 9300)); System.out.println(client.toString()); } catch (UnknownHostException e) { e.printStackTrace(); } //1.创建索引(indices指数) client.admin().indices().prepareCreate("blog").get(); //2.关闭连接 client.close(); }
运行报错:
NoNodeAvailableException
查看日志如下:
java.lang.IllegalStateException: Received message from unsupported version: [5.2.2] minimal compatible version is: [5.6.0]
可知是版本太低,至少要5.6.0以上版本才行
修改后的pom.xml文件如下:
再次运行,成功!!!!!!
其他原因:
1.查看
cluster.name,是否是你服务器上在elasticsearch.yml上配置的
2.查看
port:9300
val client = TransportClient.builder().settings(settings).build()
.addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName("******"), 9300))
3.查看
服务器的防火墙,是否关了。
4.查看
如果设置client.transport.sniff为true,则表示客户端去嗅探整个cluster的状态,把集群中其它机器的ip地址加到客户端中
这篇关于ElasticSearch Java API连接报错NoNodeAvailableException解决方案的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-10-05小米13T Pro系统合集:性能与摄影的极致融合,值得你升级的系统ROM
- 2024-10-01基于Python+Vue开发的医院门诊预约挂号系统
- 2024-10-01基于Python+Vue开发的旅游景区管理系统
- 2024-10-01RestfulAPI入门指南:打造简单易懂的API接口
- 2024-10-01初学者指南:了解和使用Server Action
- 2024-10-01Server Component入门指南:搭建与配置详解
- 2024-10-01React 中使用 useRequest 实现数据请求
- 2024-10-01使用 golang 将ETH账户的资产平均分散到其他账户
- 2024-10-01JWT用户校验课程:从入门到实践
- 2024-10-01Server Component课程入门指南