ElasticSearch笔记

1、ElasticSearch是什么

和Lucene一样,都是用来做全文检索(创建索引和搜索索引).只是lucene是全文检索工具包,而ES是全文搜索服务器,以基于索引的搜索代替数据库模糊查询,增强查询效率.

lucene不足:

  1. lucene只能在java中以java jar引入项目,其他语言就不行了.
  2. lucene使用非常复杂,写一大堆代码来实现创建索引和搜索索引.
  3. lucene不能集群(多个服务器部署同一个项目协调工作)环境使用
    lucene一般在小型项目使用(不要集群),像es,sorl等实在大型项目中使用.当然小型项目用他们也ok.

es补足

ES弥补了lucene不足,而且其他方面还做了加强:

  1. 不仅支持java环境
    es是服务器,它把原来lucene很复杂的操作封装成了Restful(http)接口
  2. 使用方式变得很简单
    进行了封装,只需发请求到服务器就OK
  3. 也能集群环境使用
    多个应用服务器(代码)使用的是同一个搜索服务器.
  4. ES本身也可以集群
    es支持集群

入门

一、安装es服务端

1)下载
https://www.elastic.co/downloads/elasticsearch

正常请求我们应该在linux或者Docker安装
在这里插入图片描述2) 安装
解压即可
可以修改内存配置
在这里插入图片描述

  1. 启动
    bin/elasticsearch.bat
    在这里插入图片描述
  2. 测试 -web端口
    http://localhost:9200
    查询状态

安装客户端

1)curl
windows不支持,需要在linux
2) 火狐的POSTER插件界面
3) kibana
官方推荐
4)前端head比较屌,可以直接看到shard和replica
5)postman

kibana客户端

1)下载

2)安装
解压即可
3)配置
配置服务器地址,编辑config/kibana.yml,设置elasticsearch.url的值为已启动的ES
4) 启动

在这里插入图片描述在这里插入图片描述
5) 测试
http://localhost:5601

在这里插入图片描述

ES集成ik分词器

DSL

什么是dsl
   由ES提供丰富且灵活的查询语言叫做DSL查询(Query DSL),它允许你构建更加复杂、强大的查询。DSL(Domain Specific Language特定领域语言)以JSON请求体的形式出现.

查询字符串模式:GET itsource/employee/_search?q=fullName:倪先华
DSL模式:
GET itsource/employee/_search
{
"query" : {
   "match" : {
   		"fullName" : "倪先华"
}
}

dsl查询–>高级查询+分页+排序+截取字段

GET test/employee/_search
{
  "query": {
    "match_all": {
      
    }
  },
  "sort": [
    {
      "age": {
        "order": "desc"
      }
    }
  ],
  "from": 0,
  "size": 2,
  "_source": ["name","age"]
}

支持哪些数据类型

① 基本字段类型
字符串、数字、日期、逻辑(boolean)

② 复杂数据类型
对象类型:object
数组类型:array
地理位置:geo_point,geo_shape

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值