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": "搜索"
}
}
}