elasticsearch head安装与 spring集成elasticsearch常见问题整理

一. elasticsearch head安装常见问题


1.用head插件请求失败

{
"error": "Content-Type header [application/x-www-form-urlencoded] is not supported",
"status": 406
}

解决方法:编辑 head 插件的 vendor.js 文件,将 application/x-www-form-urlencoded 改为 application/json;charset=UTF-8 (6886行和7574行)

global: true,
type: "GET",
//contentType: "application/x-www-form-urlencoded",
contentType: "application/json;charset=UTF-8"
processData: true,
async: true,

二. spring 集成 elasticsearch 常见问题

1.failed to get local cluster state for {#transport#-1}
解决方法:设置 client.transport.sniff 为 false

    <elasticsearch:transport-client id="client" cluster-nodes="XXXXXXXX:XX"
                                    cluster-name="elasticsearch-name" client-transport-sniff="false" />

    <bean name="elasticsearchTemplate"
          class="org.springframework.data.elasticsearch.core.ElasticsearchTemplate">
        <constructor-arg name="client" ref="client" />
    </bean>

原因:设置client.transport.sniff为true是用来嗅探整个集群的状态,会把集群中的其他节点的ip地址自动添加到客户端中,这样做就不用手动的去设置集群中所有节点的IP地址。如果ES服务器监听使用的是内网服务器IP而访问使用的外网时。这时会导致无法连接到ES服务器。

2.NodeDisconnectedException[[][XXXXXXX][cluster:monitor/nodes/liveness] disconnected]
[elasticsearch[Ariann][generic][T#2]] [INFO ] org.elasticsearch.client.transport - [Ariann] failed to get node info for {#transport#-1}{XXXXX}XXXXX}, disconnecting…

elasticsearch log
java.lang.IllegalStateException: Received message from unsupported version: [2.0.0] minimal compatible version is: [5.6.0]
at org.elasticsearch.transport.TcpTransport.ensureVersionCompatibility(TcpTransport.java:1475) ~[elasticsearch-6.4.1.jar:6.4.1]
at org.elasticsearch.transport.TcpTransport.messageReceived(TcpTransport.java:1421) ~[elasticsearch-6.4.1.jar:6.4.1]
at org.elasticsearch.transport.netty4.Netty4MessageChannelHandler.channelRead(Netty4MessageChannelHandler.java:64) ~[transport-netty4-6.4.1.jar:6.4.1]
at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:362) [netty-transport-4.1.16.Final.jar:4.1.16.Final]
at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:348) [netty-transport-4.1.16.Final.jar:4.1.16.Final]
at io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:340) [netty-transport-4.1.16.Final.jar:4.1.16.Final]
at io.netty.handler.codec.ByteToMessageDecoder.fireChannelRead(ByteToMessageDecoder.java:310) [netty-codec-4.1.16.Final.jar:4.1.16.Final]
at io.netty.handler.codec.ByteToMessageDecoder.fireChannelRead(ByteToMessageDecoder.java:297) [netty-codec-4.1.16.Final.jar:4.1.16.Final]

解决方法:更改elasticsearch版本
原因:从不支持的版本接收到的消息:[2.0.0]最小兼容版本是:[5.6.0]

 <!-- elasticsearch -->
    <dependency>
      <groupId>org.elasticsearch</groupId>
      <artifactId>elasticsearch</artifactId>
      <version>6.4.1</version>
    </dependency>

    <dependency>
      <groupId>org.elasticsearch.client</groupId>
      <artifactId>transport</artifactId>
      <version>6.4.1</version>
    </dependency>

    <dependency>
      <groupId>org.elasticsearch.client</groupId>
      <artifactId>elasticsearch-rest-high-level-client</artifactId>
      <version>6.4.1</version>
    </dependency>
    
    <dependency>
      <groupId>org.springframework.data</groupId>
      <artifactId>spring-data-elasticsearch</artifactId>
      <version>3.1.3.RELEASE</version>
    </dependency>
  1. org.springframework.util.Assert.isTrue(ZLjava/util/function/Supplier
    原因:包冲突
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Cloud集成Elasticsearch可以通过使用Spring Data Elasticsearch来实现。Spring Data ElasticsearchSpring Data项目的一部分,它提供了与Elasticsearch交互的API和工具。 要使用Spring Data Elasticsearch,需要在项目中添加以下依赖: ``` <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-elasticsearch</artifactId> </dependency> ``` 然后,需要配置Elasticsearch的连接信息,可以在application.properties文件中添加以下配置: ``` spring.data.elasticsearch.cluster-name=myClusterName spring.data.elasticsearch.cluster-nodes=localhost:930 ``` 接下来,就可以使用Spring Data Elasticsearch提供的API来操作Elasticsearch了。例如,可以定义一个Elasticsearch的Repository接口,用于操作索引: ``` public interface BookRepository extends ElasticsearchRepository<Book, String> { List<Book> findByTitle(String title); } ``` 在这个例子中,Book是一个实体类,它对应了Elasticsearch中的一个文档。findByTitle方法是一个自定义查询方法,用于根据书名查询书籍。 最后,可以在Spring Boot应用中注入BookRepository,然后使用它来操作Elasticsearch: ``` @Autowired private BookRepository bookRepository; public void saveBook(Book book) { bookRepository.save(book); } public List<Book> searchBooks(String title) { return bookRepository.findByTitle(title); } ``` 这样,就可以在Spring Cloud应用中集成Elasticsearch了。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值