1.下载软件

https://elasticsearch.cn/download/


#点击上面的网址 下载rpm包

yum install elasticsearch-7.6.1-x86_64.rpm -y #安装

vi /etc/elasticsearch/elasticsearch.yml #修改以下配置

network.host: 0.0.0.0
#修改监听端口为全局
discovery.seed_hosts: ["host1"]

systemctl restart elasticsearch.service #启动服务
测试访问

#能显示这个页面说明成功了

2.安装 elasticsearch-head等工具


#用Google浏览器的的应用商店搜索


#输入ip:9200访问

#安装advanced rest client


https://www.sojson.com/ #一个在线转换json 格式化的工具

安装Postman 软件
https://dl.pstmn.io/download/latest/win64 #下载
win7 如果无法安装 就更新KB2533623补丁

3.1、创建非结构化索引

创建空索引:

PUT /haoke 
{
    "settings": {
        "index": {
            "number_of_shards": "2",#分片数
            "number_of_replicas": "0"#副本数
        }
    }
}




#用elasticsearch-head看,已经有一个索引了

3.2删除索引

DELETE /haoke

{
    "acknowledged": true
}


#成功返回200 响应码()

#在打开elasticsearch-head 看,发现索引已经没有了

3.3 插入数据(插入数据之前先创建一个索引)

URL规则:
POST /{索引}/{类型}/{id}

POST http://50.1.1.111:9200/haoke

{
"id":1001,
"name":"张三",
"age":20,
"sex":"男"
}



#在切到查看工具能看到多出一条记录

不指定id插入数据:
POST 50.1.1.111:9200/haoke/user/

{
"id":1002,
"name":"张三",
"age":20,
"sex":"男"
}


#可以看到url里不加ID _id字段将自动生成

3.4 更新数据

PUT 50.1.1.111:9200/haoke/user/1001

{
"id":1001,
"name":"张三",
"age":21,
"sex":"女"
}


#看结果反馈,可以看到版本+1了

#看软件,能看到id为"1001"的性别确实变成了"女"

3.5 局部更新

POST 50.1.1.111:9200/haoke/user/1001/_update

{
    "doc": {
        "age": 23
    }
}


#看结果反馈,版本已经到第3版了。

#数据内容也确实被改变了

3.6 删除数据

DELETE 50.1.1.111:9200/haoke/user/1001
在Elasticsearch中,删除文档数据,只需要发起DELETE请求即可。(不需要json代码)

#需要注意的是,result表示已经删除,version也更加了。如果删除一条不存在的数据,会响应404:

说明:
删除一个文档也不会立即从磁盘上移除,它只是被标记成已删除。Elasticsearch将会在你之后添加更多索引的时候才会在后台进行删除内容的清理,因为


#数据依然不在

3.7 搜索数据

搜索数据之前先多插点数据

#上面是插入的数据,下面我要搜索 画圈的的数据
GET 50.1.1.111:9200/haoke/user/BsuAzXAB_G2CqNSlIVLu
#get 不需要其他参数

搜索全部数据

GET 50.1.1.111:9200/haoke/user/_search

#看结果反馈,有5条记录,且能看到原始数据

查询年龄等于20的记录

GET 50.1.1.111:9200/haoke/user/_search?q=age:20

#只找到了一条记录

3.8 DSL搜索

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

POST 50.1.1.111:9200/haoke/user/_search

{
    "query": {
            "match": {  #match只是查询的一种
            "age": 21
        }
    }
}


#找到一条记录,且年龄是21

DSL查询年龄大于21岁的男性用户

POST 50.1.1.111:9200/haoke/user/_search

{
    "query": {
        "bool": {
            "filter": {
                "range": {
                    "age": {
                        "gt": 21
                    }
                }
            },
            "must": {
                "match": {
                    "sex": "男"
                }
            }
        }
    }
}


#找到两条同时满足年大于21且性别为男性。、

高亮显示

POST 50.1.1.111:9200/haoke/user/_search

{
    "query": {
        "match": {
            "name": "张三 李四"
        }
    },
    "highlight": {
        "fields": {
            "name": {}
        }
    }
}

聚合
POST 50.1.1.111:9200/haoke/user/_search

{
    "aggs": {
        "all_interests": {
            "terms": {
                "field": "age"
            }
        }
    }
}


#看结果反馈,能看到每个年龄都有1个人