Java操作ElasticSearch(基础篇)

Wesley13
• 阅读 787

1.前言

     看本文前需要先对ElasticSearch有一定了解(比如什么是index 什么是type)

     本人推荐直接使用ElasticSearch Java API来操作..本人最开始是用springboot spring-data-elasticsearch-starter 来作为orm的..操作是方便了很多.支持类spring-data-jpa的接口化查询..但是弊端太多.

     1.更新非常慢.

     2.文档非常少.

     3.封装太多,不利于学习原生ElasticSearch

     4.对于Springboot maven modules 项目来说..当更新ElasticSearch要更换parent的springboot 版本..

     用spring-data-elasticsearch的话少了第四点.

2.开始搞事

     1.加入依赖..(本例是基于Springboot + Maven..)

      

org.elasticsearch elasticsearch 5.5.0

org.elasticsearch.client transport 5.5.0 org.elasticsearch.client x-pack-transport 5.5.0

版本需要与你的ElasticSearch版本相同

ElasticsearchConfiguratio

package cn.youyinian.server;

import org.elasticsearch.client.transport.TransportClient; import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.transport.InetSocketTransportAddress; import org.elasticsearch.xpack.client.PreBuiltXPackTransportClient; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.DisposableBean; import org.springframework.beans.factory.FactoryBean; import org.springframework.beans.factory.InitializingBean; import org.springframework.beans.factory.annotation.Value; import org.springframework.context.annotation.Configuration;

import java.net.InetAddress; import java.net.UnknownHostException;

@Configuration public class ElasticsearchConfiguration implements FactoryBean, InitializingBean, DisposableBean { private static final Logger logger = LoggerFactory.getLogger(ElasticsearchConfiguration.class); //由于项目从2.2.4配置的升级到 5.5.3版本 原配置文件不想动还是指定原来配置参数 @Value("${spring.data.elasticsearch.cluster-nodes}") private String clusterNodes ;

@Value("${spring.data.elasticsearch.cluster-name}")
private String clusterName;

private TransportClient client;

@Override

public void destroy() throws Exception { try { logger.info("Closing elasticSearch client"); if (client != null) { client.close(); } } catch (final Exception e) { logger.error("Error closing ElasticSearch client: ", e); } }

@Override

public TransportClient getObject() throws Exception { return client; }

@Override

public Class getObjectType() { return TransportClient.class; }

@Override

public boolean isSingleton() { return false; }

@Override

public void afterPropertiesSet() throws Exception { buildClient(); }

protected void buildClient()  {
    try {
        PreBuiltXPackTransportClient preBuiltXPackTransportClient = new PreBuiltXPackTransportClient(settings());
        if (!"".equals(clusterNodes)){
            for (String nodes:clusterNodes.split(",")) {
                String InetSocket \[\] = nodes.split(":");
                String  Address = InetSocket\[0\];
                Integer  port = Integer.valueOf(InetSocket\[1\]);
                preBuiltXPackTransportClient.addTransportAddress(new

InetSocketTransportAddress(InetAddress.getByName(Address),port )); } client = preBuiltXPackTransportClient; } } catch (UnknownHostException e) { logger.error(e.getMessage()); } } /** * 初始化默认的client */ private Settings settings(){ Settings settings = Settings.builder() .put("cluster.name",clusterName) .put("xpack.security.transport.ssl.enabled", false) .put("xpack.security.user", "elastic:changeme") //xpack user配置 .put("client.transport.sniff", true).build(); return settings; } }

3.操作ElasticSearch

官方Java API 文档

本例是使用json字符串来插入

先注入client对象

public final TransportClient client;

public TopicAuthSearchRemoteController(TransportClient client) { this.client = client; }

//加入索引

IndexResponse response = client.prepareIndex("index_topic", "topic_auth") .setSource(topicAuthJson, XContentType.JSON) .get();

//搜索 - 根据实体搜索

SearchResponse response = client.prepareSearch("index_topic")

.setTypes("topic_auth") .setQuery(QueryBuilders.termQuery("id", topicAuthId)) .get();

//删除索引

DeleteResponse deleteResponse = client.prepareDelete("index_topic", "topic_auth", id).get(); //重点:这里的id并不是实体的id..而是ElasticSearch每条记录都有的 _id 可以通过String id = response.getHits().getAt(0).getId(); 或者用API中得Delete by Queries

4.注意

你可以在过程中发现没有保存但是操作也没有成功. 因为ElasticSearch Java API TransportClient是异步的. 每一个请求都是一条线程. 并没有在主线程捕捉到Error. 所以应该在方法外面加个Try Catch... 如:

try { if(StringUtils.isEmpty(topicAuthJson)) { logger.info(topicAuthJson); IndexResponse response = client.prepareIndex("index_topic", "topic_auth") .setSource(topicAuthJson, XContentType.JSON) .get(); }else { logger.error("object add to index cannot be null"); } }catch (Exception e) { logger.error("error", e); }

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
待兔 待兔
4个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Karen110 Karen110
3年前
​一篇文章总结一下Python库中关于时间的常见操作
前言本次来总结一下关于Python时间的相关操作,有一个有趣的问题。如果你的业务用不到时间相关的操作,你的业务基本上会一直用不到。但是如果你的业务一旦用到了时间操作,你就会发现,淦,到处都是时间操作。。。所以思来想去,还是总结一下吧,本次会采用类型注解方式。time包importtime时间戳从1970年1月1日00:00:00标准时区诞生到现在
Wesley13 Wesley13
3年前
Java日期时间API系列31
  时间戳是指格林威治时间1970年01月01日00时00分00秒起至现在的总毫秒数,是所有时间的基础,其他时间可以通过时间戳转换得到。Java中本来已经有相关获取时间戳的方法,Java8后增加新的类Instant等专用于处理时间戳问题。 1获取时间戳的方法和性能对比1.1获取时间戳方法Java8以前
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
3年前
Docker 部署SpringBoot项目不香吗?
  公众号改版后文章乱序推荐,希望你可以点击上方“Java进阶架构师”,点击右上角,将我们设为★“星标”!这样才不会错过每日进阶架构文章呀。  !(http://dingyue.ws.126.net/2020/0920/b00fbfc7j00qgy5xy002kd200qo00hsg00it00cj.jpg)  2
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
为什么mysql不推荐使用雪花ID作为主键
作者:毛辰飞背景在mysql中设计表的时候,mysql官方推荐不要使用uuid或者不连续不重复的雪花id(long形且唯一),而是推荐连续自增的主键id,官方的推荐是auto_increment,那么为什么不建议采用uuid,使用uuid究
Python进阶者 Python进阶者
10个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这