前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Elasticsearch分布式搜索引擎

Elasticsearch分布式搜索引擎

作者头像
暴躁的程序猿
发布2022-03-24 15:56:30
3450
发布2022-03-24 15:56:30
举报
文章被收录于专栏:阿飞的学习记录

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": "搜索"
        }
    }
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/02/13 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • ElasticSearch简介
  • ElasticSearch相关概念
  • ElasticSearch的客户端操作
相关产品与服务
Elasticsearch Service
腾讯云 Elasticsearch Service(ES)是云端全托管海量数据检索分析服务,拥有高性能自研内核,集成X-Pack。ES 支持通过自治索引、存算分离、集群巡检等特性轻松管理集群,也支持免运维、自动弹性、按需使用的 Serverless 模式。使用 ES 您可以高效构建信息检索、日志分析、运维监控等服务,它独特的向量检索还可助您构建基于语义、图像的AI深度应用。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档