为了账号安全,请及时绑定邮箱和手机立即绑定

【九月打卡】第8天 手把手带你快速搞定分布式搜索引擎ES

标签:
架构

课程名称Java架构师-技术专家
课程章节: 第10周 手把手带你快速搞定分布式搜索引擎ES
课程讲师: 慕课讲师团队

课程内容

索引的mappings映射

索引分词概念

index:默认true,设置为false的话,那么这个字段就不会被索引(不被索引是查询不到的)

创建索引的同时创建 mappings

PUT /index_str
{
  "settings": {
    "index": {
      "number_of_shards": "2",
      "number_of_replicas": "0"
    }
  },
  "mappings": {
    "properties": {
      "realname": {
        "type": "text",/*字符串,会被分词,会创建倒排索引*/
        "index": true  
      },
      "username": {
        "type": "keyword",/*字符串,不会被分词,也不会被倒排索引;是一种精确匹配的搜索,比如说订单状态,用户的QQ号、手机号*/
        "index": false
      }
    }
  }
}

查看分词效果

GET /index_str/_analyze
{
    "field":"realname",
    "text":"I am good"
}

尝试修改(报错,如果属性已存在,则不做操作)

GET /index_str/_analyze
{
    "field":"realname",
    "text":"I am good"
}

为已存在的索引创建或添加 mappings

POST /index_str/_mapping
{
    "properties":{
         "id": {
        	"type": "long"
        },
        "age": {
        	"type": "integer"
        },
        "nickname": {
            "type": "keyword"
        },
        "money1": {
            "type": "float"
        },
        "money2": {
            "type": "double"
        },
        "sex": {
            "type": "byte"
        },
        "score": {
            "type": "short"
        },
        "is_teenager": {
            "type": "boolean"
        },
        "birthday": {
            "type": "date"
        },
        "relationship": {
            "type": "object"
        }
    }
}

注意:某个属性一旦被建立,就不能修改了,但是可以新增额外属性

主要数据类型

  • text、keyword
  • long、interger、short、byte
  • double、float
  • boolean
  • date
  • object
  • 数组不能混,类型一致
  • text:文字类需要被分词被倒排索引的内容,比如商品名称、商品详情、商品介绍,使用text。
  • keyword:不会被分词,不会被倒排索引,直接匹配搜索,比如订单状态、微信号、手机号、用户qq,这些精确匹配,无需分词

文档的基本操作

添加文档与自动映射

POST /my_doc/_doc/1 -> {索引名}/_doc/{索引ID}(是指索引在es中的id,而不是这条记录的id,比如记录的id从数据库来是1001,并不是这个。如果不写,则自动生成一个字符串。建议和数据id保持一致>{
    "id": 1001,
    "name": "imooc-1",
    "desc": "imooc is very good, 慕课网非常牛!",
    "create_date": "2019-12-24"
}

{
    "id": 1002,
    "name": "imooc-2",
    "desc": "imooc is fashion, 慕课网非常时尚!",
    "create_date": "2019-12-25"
}

{
    "id": 1003,
    "name": "imooc-3",
    "desc": "imooc is niubility, 慕课网很好很强大!",
    "create_date": "2019-12-26"
}

{
    "id": 1004,
    "name": "imooc-4",
    "desc": "imooc is good~!",
    "create_date": "2019-12-27"
}

{
    "id": 1005,
    "name": "imooc-5",
    "desc": "慕课网 is 强大!",
    "create_date": "2019-12-28"
}

{
    "id": 1006,
    "name": "imooc-6",
    "desc": "慕课是一个强大网站!",
    "create_date": "2019-12-29"
}

{
    "id": 1007,
    "name": "imooc-7",
    "desc": "慕课网是很牛网站!",
    "create_date": "2019-12-30"
}

{
    "id": 1008,
    "name": "imooc-8",
    "desc": "慕课网是很好看!",
    "create_date": "2019-12-31"
}

{
    "id": 1009,
    "name": "imooc-9",
    "desc": "在慕课网学习很久!",
    "create_date": "2020-01-01"
}
  • 注:如果索引没有手动建立mappings,那么当插入文档数据的时候,会根据文档类型自动设置属性类型。这个就是es的动态映射,帮我们在index索引库中去建立数据结构的相关配置信息。
  • “fields”:{“type”:”keyword”} 对一个字段设置多种索引模式,使用text类型做全文检索,也可以使用keyword类型做聚合和排序
  • “ignore_above”:256 设置字段索引和存储的长度最大值,超过则被忽略

删除文档

DELETE /my_doc/_doc/1

修改文档

  • 局部
POST /my_doc/_doc/1/_update
{
    "doc":{
        "name":"wkq"
    }
}
  • 全量替换
PUT /my_doc/_doc/1
{
    "id":1001,
    "name":"imooc-1",
    "desc":"imooc is very good,慕课网非常牛!",
    "create_date":"2022-03-26"
}

每次修改后,version 会更改

文档的基本查询

  • 常规查询
GET /index_demo/_doc/1
GET /index_demo/_doc/_search
  • 查询结构
{
  "_index": "my_doc",
  "_type": "_doc",
  "_id": "2",
  "_score": "1.0",
  "_version": "9",
  "_source": {
    "id": "1002",
    "name": "desc",
    "desc": "imooc is fashion",
    "create_time": "2022-03-26"
  }
}
  • 定制结果集
GET /index_demo/_doc/1?_source=id,name
GET /index_demo/_doc/_search?_source=id,name
  • 判断文档是否存在
HEAD /index_demo/_doc/1

元数据

  • _index:文档数据所属的那个索引,理解为数据库的某张表即可。
  • _type:文档数据属于那个类型,新版本使用_doc。
  • _id:文档数据的唯一标识,类似数据库中某张表的主键。可以自动生成或者手动指定
  • _score:查询相关度,是否契合用户匹配,分数越高用户的搜索体验越高
  • _version:版本号。
  • _source:文档数据,json格式
  • _seq_no: 文档版本号,作用同 _version(相当于学生编号,每个班级的班主任为学生分配编号,效率要比学校教务处分配来的更加高效,管理起来更加方便)
  • _primary_term: 文档所在位置(相当于班级)

课程收获

今天学习了 ES 的相关操作。
图片描述

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
JAVA开发工程师
手记
粉丝
6
获赞与收藏
11

关注作者,订阅最新文章

阅读免费教程

  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消