最全ElasticSearch入门(五)SpringBoot2,tomcat架构解析文档

最后总结

搞定算法,面试字节再不怕,有需要文章中分享的这些二叉树、链表、字符串、栈和队列等等各大面试高频知识点及解析

最后再分享一份终极手撕架构的大礼包(学习笔记):分布式+微服务+开源框架+性能优化

image

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

*/

@Override

public boolean deleteIndex(String index) {

AcknowledgedResponse response = null;

try {

if (this.existsIndex(index)) {

response = client.indices().delete(new DeleteIndexRequest(index), RequestOptions.DEFAULT);

} else {

return true;//索引不存在

}

} catch (Exception e) {

log.error(“ElasticSearch 删除索引异常:{}”, e.getMessage());

return false;

}

return response.isAcknowledged();

}

/**

  • 创建文档

  • id相同则更新、不同则创建,数据格式(字段)不同则空,字段为追加模式

  • @param index 索引

  • @param data 数据

  • @param dataType 格式类型 例:XContentType.JSON

  • @param id 唯一标识 put /index/1

  • @return

*/

@Override

public int insertDocument(String index, Object data, XContentType dataType, String id) {

IndexRequest request = new IndexRequest(index);

request.id(id);

String dataString = JSONObject.toJSONString(data);

request.source(dataString, dataType);

IndexResponse response = null;

try {

response = client.index(request, RequestOptions.DEFAULT);

} catch (Exception e) {

log.error(“ElasticSearch 创建文档异常:{}”, e.getMessage());

}

return response != null ? response.status().getStatus() : 400;

}

/**

  • 获取文档

  • @param index

  • @param id

  • @param mappingClass

  • @param

  • @return

*/

@Override

public T getDocument(String index, String id, Class mappingClass) {

GetResponse getResponse = null;

try {

if (this.existsIndex(index)) {

GetRequest getRequest = new GetRequest(index, id);

getResponse = client.get(getRequest, RequestOptions.DEFAULT);

String sourceAsString = getResponse.getSourceAsString();

if (sourceAsString == null || sourceAsString.isEmpty()) {

return null;

}

/**Jackson日期时间序列化问题:

  • Cannot construct instance of java.time.LocalDateTime (no Creators, like default constructor, exist): no String-argument constructor/factory method to deserialize from String value (‘2020-06-04 15:07:54’)

*/

// ObjectMapper objectMapper = new ObjectMapper();

// objectMapper.disable(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS);

// objectMapper.registerModule(new JavaTimeModule());

// T result = objectMapper.readValue(sourceAsString, mappingClass);

T result = JSON.parseObject(sourceAsString, mappingClass);

return result;

}

} catch (Exception e) {

log.error(“ElasticSearch 获取文档异常:{}”, e.getMessage());

}

return null;

}

/**

  • 更新文档信息

  • @param index

  • @param data

  • @param dataType

  • @param id

  • @return

*/

@Override

public int updateDocument(String index, Object data, XContentType dataType, String id) {

UpdateResponse updateResponse = null;

try {

if (this.existsIndex(index)) {

UpdateRequest updateRequest = new UpdateRequest(index, id);

String dataString = JSONObject.toJSONString(data);

updateRequest.doc(dataString, dataType);

updateResponse = client.update(updateRequest, RequestOptions.DEFAULT);

}

} catch (Exception e) {

log.error(“ElasticSearch 更新文档异常:{}”, e.getMessage());

}

return updateResponse != null ? updateResponse.status().getStatus() : 400;

}

/**

  • 删除文档

  • @param index

  • @param id

  • @return

*/

@Override

public int deleteDocument(String index, String id) {

DeleteResponse deleteResponse = null;

try {

if (this.existsIndex(index)) {

DeleteRequest deleteRequest = new DeleteRequest(index, id);

deleteResponse = client.delete(deleteRequest, RequestOptions.DEFAULT);

}

} catch (Exception e) {

log.error(“ElasticSearch 删除文档异常:{}”, e.getMessage());

}

return deleteResponse != null ? deleteResponse.status().getStatus() : 400;

}

/**

  • 批量操作文档信息

  • 备注:暂局限入参list,可扩展其他<?>

  • @param index

  • @param list 标识相同则覆盖,否则新增

  • @param dataType

  • @return

*/

@Override

public boolean batchInsertDocument(String index, List<?> list, XContentType dataType) {

BulkRequest bulkRequest = new BulkRequest();

for (Object obj : list) {

// 自动生成id

bulkRequest.add(new IndexRequest(index).source(JSON.toJSONString(obj), dataType));

}

BulkResponse bulk = null;

try {

bulk = client.bulk(bulkRequest, RequestOptions.DEFAULT);

} catch (Exception e) {

log.error(“ElasticSearch批量操作文档信息异常:{}”, e.getMessage());

}

return bulk != null && !bulk.hasFailures();

}

/**

  • 查询数据

  • 备注:可拓展深入精准查询、范围查询、模糊查询、匹配所有等

  • @param index

  • @return

*/

@Override

public List<Map<String, Object>> searchDocument(String index) {

SearchRequest searchRequest = new SearchRequest(index);

SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();

MatchAllQueryBuilder termQueryBuilder = QueryBuilders.matchAllQuery();

sourceBuilder.query(termQueryBuilder);

// sourceBuilder.timeout(new TimeValue(60, TimeUnit.SECONDS));

searchRequest.source(sourceBuilder);

SearchResponse search;

try {

search = client.search(searchRequest, RequestOptions.DEFAULT);

} catch (Exception e) {

log.error(“ElasticSearch 查询数据异常:{}”, e.getMessage());

return null;

}

SearchHit[] hits = search.getHits().getHits();

List<Map<String, Object>> mapList = new ArrayList<>();

for (SearchHit hit : hits) {

mapList.add(hit.getSourceAsMap());

}

return mapList;

}

private void close(RestHighLevelClient client) {

try {

client.close();

} catch (IOException e) {

log.error(“ElasticSearch 关闭异常:{}”, e.getMessage());

}

}

}

Note: 使用FastJson替换了SpringBoot的默认Json解析器Jackson,参考

Source Code

Github

References

更多:Java进阶核心知识集

包含:JVM,JAVA集合,网络,JAVA多线程并发,JAVA基础,Spring原理,微服务,Zookeeper,Kafka,RabbitMQ,Hbase,MongoDB,Cassandra,设计模式,负载均衡,数据库,一致性哈希,JAVA算法,数据结构,加密算法,分布式缓存等等

image

高效学习视频

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

知识集

包含:JVM,JAVA集合,网络,JAVA多线程并发,JAVA基础,Spring原理,微服务,Zookeeper,Kafka,RabbitMQ,Hbase,MongoDB,Cassandra,设计模式,负载均衡,数据库,一致性哈希,JAVA算法,数据结构,加密算法,分布式缓存等等

[外链图片转存中…(img-UkOKp4v4-1715554016486)]

高效学习视频

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

  • 25
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值