Elasticsearch分布式搜索引擎

2022-03-24 15:56:30 浏览数 (1)

ElasticSearch简介

Elaticsearch,简称为es, es是一个开源的高扩展的分布式全文检索引擎,它可以近乎实时的存储、检索数据;本身扩展性很好,可以扩展到上百台服务器,处理PB级别的数据。es也使用Java开发并使用Lucene作为其核心来实现所有索引和搜索的功能,但是它的目的是通过简单的RESTful API来隐藏Lucene的复杂性,从而让全文搜索变得简单。

ElasticSearch安装与启动

安装ES服务

Window版的ElasticSearch的安装很简单,类似Window版的Tomcat,解压开即安装完毕,解压后的ElasticSearch的目录结构如下:

修改elasticsearch配置文件:config/elasticsearch.yml,增加以下两句命令:

代码语言:javascript复制
http.cors.enabled: true
http.cors.allow-origin: "*"

此步为允许elasticsearch跨越访问,如果不安装后面的elasticsearch-head是可以不修改,直接启动.

启动ES服务

9300是tcp通讯端口,集群间和TCPClient都执行该端口,9200是http协议的RESTful接口 。

通过浏览器访问ElasticSearch服务器,看到如下返回的json信息,代表服务启动成功:

注意:ElasticSearch是使用java开发的,且本版本的es需要的jdk版本要是1.8以上 安装ES的图形化界面插件 ElasticSearch不同于Solr自带图形化界面,我们可以通过安装ElasticSearch的head插件,完成图形化界面的效果,完成索引数据的查看。 elasticsearch-5-*以上版本安装head需要安装node和grunt 下载head插件点击这里

将elasticsearch-head-master压缩包解压到任意目录,但是要和elasticsearch的安装目录区别开

要运行head 需要下载nodejs点这里

将grunt安装为全局命令 ,Grunt是基于Node.js的项目构建工具 在cmd控制台中输入如下执行命令:

代码语言:javascript复制
npm install -g grunt-cli

进入elasticsearch-head-master目录启动head,在命令提示符下输入命令:

代码语言:javascript复制
>npm install
>grunt server

打开浏览器,输入 http://localhost:9100

ElasticSearch相关概念

索引 index

一个索引就是一个拥有几分相似特征的文档的集合。

类型 type

在一个索引中,你可以定义一种或多种类型。

字段Field

相当于是数据表的字段,对文档数据根据不同属性进行的分类标识

映射 mapping

mapping是处理数据的方式和规则方面做一些限制,如某个字段的数据类型、默认值、分析器、是否被索引等等,这些都是映射里面可以设置的,其它就是处理es里面数据的一些使用规则设置也叫做映射。

文档 document

一个文档是一个可被索引的基础信息单元。

接近实时 NRT

Elasticsearch是一个接近实时的搜索平台。这意味着,从索引一个文档直到这个文档能够被搜索到有一个轻微的延迟(通常是1秒以内)

集群 cluster

一个集群就是由一个或多个节点组织在一起,它们共同持有整个的数据,并一起提供索引和搜索功能。

节点 node

一个节点是集群中的一个服务器,作为集群的一部分,它存储数据,参与集群的索引和搜索功能。

分片和复制 shards&replicas

一个索引可以存储超出单个结点硬件限制的大量数据。

ElasticSearch的客户端操作

主要有三种方式可以作为elasticsearch服务的客户端: 第一种,elasticsearch-head插件 第二种,使用elasticsearch提供的Restful接口直接访问 第三种,使用elasticsearch提供的API进行访问

安装Postman工具

Postman中文版是postman这款强大网页调试工具的windows客户端,提供功能强大的Web API & HTTP 请求调试。软件功能非常强大,界面简洁明晰、操作方便快捷,设计得很人性化。Postman中文版能够发送任何类型的HTTP 请求 (GET, HEAD, POST, PUT…),且可以附带任何数量的参数。 Postman官网

使用Postman工具进行Restful接口访问

创建索引index和映射mapping 请求url:

{ 请求体

代码语言:javascript复制
{
    "mappings": {
        "article": {
            "properties": {
                "id": {
                    "type": "long",
                    "store": true,
                    "index":"not_analyzed"
                },
                "title": {
                    "type": "text",
                    "store": true,
                    "index":"analyzed",
                    "analyzer":"standard"
                },
                "content": {
                    "type": "text",
                    "store": true,
                    "index":"analyzed",
                    "analyzer":"standard"
                }
            }
        }
    }
}

删除索引index 请求url:

代码语言:javascript复制
DELETE		localhost:9200/blog1

创建文档document

请求url:

代码语言:javascript复制
POST    localhost:9200/blog1/article/1

请求体:

代码语言:javascript复制
{
    "id":1,
    "title":"ElasticSearch是一个基于Lucene的搜索服务器",
    "content":"它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口。Elasticsearch是用Java开发的,并作为Apache许可条款下的开放源码发布,是当前流行的企业级搜索引擎。设计用于云计算中,能够达到实时搜索,稳定,可靠,快速,安装使用方便。"
}

查询文档-根据id查询

代码语言:javascript复制
请求url: 

GET localhost:9200/blog1/article/1

查询文档-querystring查询

请求url:

代码语言:javascript复制
POST    localhost:9200/blog/article/_search

请求体

代码语言:javascript复制
{
    "query": {
        "query_string": {
            "default_field": "title",
            "query": "搜索"
        }
    }
}

0 人点赞