深入浅出讲解 ElasticSearch的安装与使用【建议收藏】

深入浅出讲解 ElasticSearch的安装与使用【建议收藏】

大家好,又见面了,我是全栈君。

1、 ElasticSearch介绍

1.1 介绍

深入浅出讲解 ElasticSearch的安装与使用【建议收藏】

官网:https://www.elastic.co/cn/products/elasticsearch

Github:https://github.com/elastic/elasticsearch
总结:
1、elasticsearch是一个基于Lucene的高扩展的分布式搜索服务器,支持开箱即用。
2、elasticsearch隐藏了Lucene的复杂性,对外提供Restful 接口来操作索引、搜索。

突出优点:
1.扩展性好,可部署上百台服务器集群,处理PB级数据。
2.近实时的去索引数据、搜索数据。
es和solr选择哪个?
1.如果你公司现在用的solr可以满足需求就不要换了。
2.如果你公司准备进行全文检索项目的开发,建议优先考虑elasticsearch,因为像Github这样大规模的搜索都在用它。

1.2原理与应用

1.2.1索引结构

下图是ElasticSearch的索引结构,下边黑色部分是物理结构,上边橙色部分是逻辑结构,逻辑结构也是为了更好的去描述ElasticSearch的工作原理及去使用物理结构中的索引文件

深入浅出讲解 ElasticSearch的安装与使用【建议收藏】

逻辑结构部分是一个倒排索引表:
1、将要搜索的文档内容分词,所有不重复的词组成分词列表。
2、将搜索的文档最终以Document方式存储起来。
3、每个词和docment都有关联。
如下:

深入浅出讲解 ElasticSearch的安装与使用【建议收藏】

现在,如果我们想搜索 quick brown ,我们只需要查找包含每个词条的文档:

深入浅出讲解 ElasticSearch的安装与使用【建议收藏】

两个文档都匹配,但是第一个文档比第二个匹配度更高。如果我们使用仅计算匹配词条数量的简单 相似性算法 ,那么,我们可以说,对于我们查询的相关性来讲,第一个文档比第二个文档更佳。

2 ElasticaSearch安装

2.1 安装

安装配置:
1、新版本要求至少jdk1.8以上。
2、支持tar、zip、rpm等多种安装方式。
在windows下开发建议使用ZIP安装方式。
3、支持docker方式安装
参见:

https://www.elastic.co/guide/en/elasticsearch/reference/current/install-elasticsearch.html

下载ES: Elasticsearch 6.2.1:
https://www.elastic.co/downloads/past-releases

解压 elasticsearch-6.2.1.zip

深入浅出讲解 ElasticSearch的安装与使用【建议收藏】

bin:脚本目录,包括:启动、停止等可执行脚本
config:配置文件目录
data:索引目录,存放索引文件的地方
logs:日志目录
modules:模块目录,包括了es的功能模块
plugins :插件目录,es支持插件机制

2.2 配置文件

2.2.1 三个配置文件

ES的配置文件的地址根据安装形式的不同而不同:

使用zip、tar安装,配置文件的地址在安装目录的config下。
使用RPM安装,配置文件在/etc/elasticsearch下。
使用MSI安装,配置文件的地址在安装目录的config下,并且会自动将config目录地址写入环境变量ES_PATH_CONF。

我们使用的zip包安装,配置文件在ES安装目录的config下。
配置文件如下:

深入浅出讲解 ElasticSearch的安装与使用【建议收藏】

elasticsearch.yml :用于配置Elasticsearch运行参数

jvm.options :用于配置Elasticsearch JVM设置l

og4j2.properties:用于配置Elasticsearch日志

2.2.2 elasticsearch.yml

配置格式是YAML,可以采用如下两种方式:
方式1:层次方式
path: data: /var/lib/elasticsearch logs: /var/log/elasticsearch
方式2:属性方式
path.data: /var/lib/elasticsearch path.logs: /var/log/elasticsearch

例子如下

cluster.name: xuecheng   #配置elasticsearch的集群名称,默认是elasticsearch。建议修改成一个有意义的名称。
node.name: xc_node_1  #节点名,通常一台物理服务器就是一个节点,es会默认随机指定一个名字,建议指定一个有意义的名称,方便管理
network.host: 0.0.0.0  #绑定ip地址 ,这个位置改为127.0.0.1,否则报错
http.port: 9200  #暴露的http端口
transport.tcp.port: 9300  #内部端口
node.master: true  #主节点
node.data: true  #数据节点
discovery.zen.ping.unicast.hosts: ["0.0.0.0:9300", "0.0.0.0:9301", "0.0.0.0:9302"]  #设置集群中master节点的初始列表
discovery.zen.minimum_master_nodes: 1  #主结点数量的最少值 ,此值的公式为:(master_eligible_nodes / 2) + 1 ,比如:有3个符合要求的主结点,那么这里要设置为2。
bootstrap.memory_lock: false  #内存的锁定只给es用
node.max_local_storage_nodes: 1 #单机允许的最大存储结点数,通常单机启动一个结点建议设置为1,开发环境如果单机启动多个节点可设置大于1
path.data: D:\ElasticSearch\elasticsearch‐6.2.1\data  #索引目录
path.logs: D:\ElasticSearch\elasticsearch‐6.2.1\logs    #日志
http.cors.enabled: true #  跨域设置
http.cors.allow‐origin: “*” #设置跨域

2.2.3 jvm.options

设置最小及最大的JVM堆内存大小:
在jvm.options中设置 -Xms和-Xmx:
1) 两个值设置为相等
2) 将 Xmx 设置为不超过物理内存的一半

2.2.4 log4j2.properties

日志文件设置,ES使用log4j,注意日志级别的配置。

2.3 启动ES

进入bin目录,在cmd下运行:elasticsearch.bat

深入浅出讲解 ElasticSearch的安装与使用【建议收藏】

浏览器输入:http://localhost:9200
显示结果如下(配置不同内容则不同)说明ES启动成功:

深入浅出讲解 ElasticSearch的安装与使用【建议收藏】

2.4 head插件安装

head插件是ES的一个可视化管理插件,用来监视ES的状态,并通过head客户端和ES服务进行交互,比如创建映射、创建索引等,head的项目地址在https://github.com/mobz/elasticsearch-head 。
从ES6.0开始,head插件支持使得node.js运行。
1、安装node.js
2、下载head并运行

git clone git://github.com/mobz/elasticsearch-head.git
cd elasticsearch-head
npm install
npm run start open
HTTP://本地主机:9100 /

3、运行结果
 

深入浅出讲解 ElasticSearch的安装与使用【建议收藏】

最后

如果这篇文章对您有所帮助,或者有所启发的话,帮忙扫描下发二维码关注一下,您的支持是我坚持写作最大的动力。求一键三连:点赞、转发、在看

深入浅出讲解 ElasticSearch的安装与使用【建议收藏】

 

回复 ElasticSearch  获取 分布式搜索引擎elasticsearch 视频教程

送你100T视频教程习资源免费下载!

PHP操作Elasticsearch

PHP 使用 ElasticSearch 做搜索

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/111473.html原文链接:https://javaforall.net

(0)
上一篇 2022年2月19日 下午11:00
下一篇 2022年2月20日 上午6:00


相关推荐

  • c++ fill 二维数组初始化_C++如何给二维数组初始化

    c++ fill 二维数组初始化_C++如何给二维数组初始化C 给二维数组初始化的方法 首先定义两个整型变量 并给二维数组初始化不同的数值 然后用二重循环 输出数组中的各个数值 最后用大括号括起来的数字直接赋值 本文操作环境 Windows7 系统 Dev C 5 2 0 3 版本 DellG3 电脑 相关学习推荐 C 语言教程视频 C 给二维数组初始化的方法 1 首先 定义两个整型变量 控制二维数组的输出 2 接着 给二维数组 n 3 4 初始化不同

    2026年3月17日
    2
  • gb50174-2017数据中心机房等级标准_计算机机房设计标准GB50174

    gb50174-2017数据中心机房等级标准_计算机机房设计标准GB501742.0.1数据中心datacenter为集中放置的电子信息设备提供运行环境的建筑场所,可以是一栋或几栋建筑物,也可以是一栋建筑物的一部分,包括主机房、辅助区、支持区和行政管理区等。2.0.2灾备数据中心businessrecoverydatacenter用于灾难发生时,接替生产系统运行,进行数据处理和支持关键业务功能继续运作的场所,包括限制区、普通区和专用区。2.0.3主机房c…

    2022年10月2日
    6
  • 架构设计(1)-谈谈架构

    架构设计(1)-谈谈架构1、什么是架构和架构本质在软件行业,对于什么是架构,都有很多的争论,每个人都有自己的理解。此君说的架构和彼君理解的架构未必是一回事。因此我们在讨论架构之前,我们先讨论架构的概念定义,概念是人认识这个世界的基础,并用来沟通的手段,如果对架构概念理解不一样,那沟通起来自然不顺畅。Linux有架构,MySQL有架构,JVM也有架构,使用Java开…

    2022年7月11日
    32
  • 正交向量与子空间

    正交向量与子空间关于向量正交 orthogonalit 我们都已不陌生 正交是垂直的另一种说法 两个向量正交意味着这两个向量的夹角为 90 度 如果要判断两个向量是否正交 只需对向量作点乘 dotproduct 相加 即内积 等于 0 就是正交的 如 xTy 0 则 x 和 y 是正交的 如果 x 是零向量 y 任意或者 y 是零向量 x 任意 那么这两个向量是正交的 即零向量与任何向量都正交 将正交从向量推广到子空间

    2026年3月16日
    1
  • 计算机操作系统学习笔记「建议收藏」

    计算机操作系统学习笔记「建议收藏」第1章计算机系统概述 1.1操作系统的基本概念 1.1.1操作系统的概念 操作系统是计算机系统中最基本的系统软件。 操作系统(OperatingSystem,OS)是指控制和管理整个计算机系统的硬件与软件资源,合理地组织、调度计算机的工作与资源的分配,进而为用户和其他软件提供方便接口与环境的程序集合。 1.1.2操心系统的特征 操作系统的基本特征包括:并发、共享、虚拟和异步。并发和共享是操作系统两个最基本的特征,两者之间互为存在的条件。​ 1.并发(C

    2022年6月7日
    32
  • spring-boot-start 找pom配置链接地址

    spring-boot-start 找pom配置链接地址spring-boot-start 找pom配置链接地址

    2022年4月24日
    68

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号