Elasticsearch(ES)的基本使用

1. 概述

之前聊了一下 Elasticsearch 的安装,今天我们来说说 Elasticsearch 的基本使用。

2. Elasticsearch索引的使用

索引(index)相当于是mysql中的表。

2.1 创建索引

1)Head插件方式

选择 索引 页签,点击【新建索引】按钮,输入索引名称、分片数、副本数,点击【OK】

image

之所以集群健康值呈现黄色,是因为目前是用单服务器跑的Elasticsearch,而副本是要存储在不同的服务器上的,之后会聊一下 Elasticsearch 集群的搭建。

image

2)RESTFUL接口方式

PUT http://192.168.1.11:9200/index_user

参数:

{
    "settings":{
        "index":{
            "number_of_shards":5,  // 分片数
            "number_of_replicas":0 // 副本数
        }
    }
}

2.2 查看集群健康状况

RESTFUL接口方式

GET http://192.168.1.11:9200/_cluster/health

响应:

{
    "cluster_name": "zhuifengren-es",
    "status": "yellow",
    "timed_out": false,
    "number_of_nodes": 1,
    "number_of_data_nodes": 1,
    "active_primary_shards": 6,
    "active_shards": 6,
    "relocating_shards": 0,
    "initializing_shards": 0,
    "unassigned_shards": 5,
    "delayed_unassigned_shards": 0,
    "number_of_pending_tasks": 0,
    "number_of_in_flight_fetch": 0,
    "task_max_waiting_in_queue_millis": 0,
    "active_shards_percent_as_number": 54.54545454545454
}

2.3 删除索引

1)Head插件方式

在 概览 页签,找到需要删除的索引,选择 动作 —> 删除...

image

2)RESTFUL接口方式

DELETE http://192.168.1.11:9200/index_user

2.4 查看集群整体信息

RESTFUL接口方式

GET http://192.168.1.11:9200/_cat/indices?v

响应:

health status index            uuid                   pri rep docs.count docs.deleted store.size pri.store.size
green  open   .geoip_databases pE4IpIAeSA2AiJzdDdviYA   1   0         42           64     65.1mb         65.1mb
green  open   index_user       2z4cELBeQeijTagp86ShbQ   5   0          0            0        1kb            1kb

3. Elasticsearch映射的使用

映射(mapping)相当于是mysql中的表结构定义。

3.1 Elasticsearch中的主要数据类型

文本类型:text,keyword

整型:long,integer,short,byte

浮点型:double,float

布尔型:boolean

日期型:date

对象型:object

3.2 创建索引并创建映射

RESTFUL接口方式

PUT http://192.168.1.11:9200/index_user

参数:

{
    "settings":{
        "index":{
            "number_of_shards":5,
            "number_of_replicas":0
        }
    },
    "mappings" : {
        "properties":{
            "name":{
                "type":"text",    // 数据类型
                "index":true      // 是否索引
            },
            "loginName":{
                "type":"keyword",
                "index":false
            },
            "age":{
                "type":"integer",
                "index":false
            }
        }
    }
}

3.3 在已有的索引上维护mapping

RESTFUL接口方式

POST http://192.168.1.11:9200/index_user/_mapping

参数:

{
    "properties":{
        "nickname":{
            "type":"keyword",
            "index":false
        }
    }
}

注意:mapping中的属性,只能添加,不能修改。如果属性设置需要变更,需要删除索引重建。

3.4 查看索引的分词效果

RESTFUL接口方式

GET http://192.168.1.11:9200/index_user/_analyze

参数:

{
    "field": "name",
    "text": "lisa brown"
}

4. Elasticsearch文档的使用

文档(document)相当于是mysql中的数据行。

4.1 新增文档

RESTFUL接口方式

POST http://192.168.1.11:9200/index_user/_doc/1

注:url中最后的1是文档在Elasticsearch中的ID,与业务ID无关,如果不写,则会自动生成一个随机字符串作为文档的ID

参数:

{
    "name":"zhang san",
    "loginName":"zs",
    "age":30
}

如果没有手动创建 映射(mapping),则新增文档后,Elasticsearch会根据文档的字段类型自动创建 映射(mapping)。

4.2 删除文档

RESTFUL接口方式

DELETE http://192.168.1.11:9200/index_user/_doc/1

4.3 修改文档

RESTFUL接口方式

1)只修改部分字段

POST http://192.168.1.11:9200/index_user/_doc/1/_update

参数:

{
    "doc":{
        "name":"zhangsan2",
        "age":33
    }
}

2)全部替换

PUT http://192.168.1.11:9200/index_user/_doc/1

参数:

{
    "name":"zhangsan",
    "loginName":"zs",
    "age":31
}

4.4 查询文档

RESTFUL接口方式

1)依据文档ID查询

GET http://192.168.1.11:9200/index_user/_doc/1

响应数据:

{
    "_index": "index_user",
    "_type": "_doc",
    "_id": "1",
    "_version": 5,
    "_seq_no": 7,
    "_primary_term": 1,
    "found": true,
    "_source": {
        "name": "zhangsan",
        "loginName": "zs",
        "age": 31
    }
}

2)查询所有

GET http://192.168.1.11:9200/index_user/_doc/_search

响应数据:

{
    "took": 2,
    "timed_out": false,
    "_shards": {
        "total": 5,
        "successful": 5,
        "skipped": 0,
        "failed": 0
    },
    "hits": {
        "total": {
            "value": 2,
            "relation": "eq"
        },
        "max_score": 1.0,
        "hits": [
            {
                "_index": "index_user",
                "_type": "_doc",
                "_id": "_TVW-XsBNDgg-BBCeUvY",
                "_score": 1.0,
                "_source": {
                    "name": "lisi",
                    "loginName": "ls",
                    "age": 31
                }
            },
            {
                "_index": "index_user",
                "_type": "_doc",
                "_id": "1",
                "_score": 1.0,
                "_source": {
                    "name": "zhangsan",
                    "loginName": "zs",
                    "age": 31
                }
            }
        ]
    }
}

3)查询时自定义结果集

GET http://192.168.1.11:9200/index_user/_doc/1?_source=name,age

GET http://192.168.1.11:9200/index_user/_doc/_search?_source=name,age

5. 综述

今天简单聊了一下 Elasticsearch 的基本使用,希望能对大家的工作有所帮助。

欢迎大家帮忙点赞、评论、加关注 :)

关注追风人聊Java,每天更新Java干货。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342

推荐阅读更多精彩内容