ElasticaSearch的简介及安装

1 ElasticSearch介绍

1.1 介绍

在这里插入图片描述
官方网址: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的工作原理及去使用物理结构中的索引文件。
在这里插入图片描述
逻辑结构部分是一个倒排索引表:
1、将要搜索的文档内容分词,所有不重复的词组成分词列表。
2、将搜索的文档最终以Document方式存储起来。
3、每个词和docment都有关联
如下:
在这里插入图片描述
现在,如果我们想搜索 quick brown ,我们只需要查找包含每个词条的文档:
在这里插入图片描述
两个文档都匹配,但是第一个文档比第二个匹配度更高。如果我们使用仅计算匹配词条数量的简单 相似性算法 ,那么,我们可以说,对于我们查询的相关性来讲,第一个文档比第二个文档更佳。

1.2.3 RESTful应用方法

  • 如何使用es?
    Elasticsearch提供 RESTful Api接口进行索引、搜索,并且支持多种客户端。
    在这里插入图片描述
    下图是es在项目中的应用方式:
    在这里插入图片描述
    1)用户在前端搜索关键字
    2)项目前端通过http方式请求项目服务端
    3)项目服务端通过Http RESTful方式请求ES集群进行搜索
    4)ES集群从索引库检索数据

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
在这里插入图片描述
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.yml : 用于配置Elasticsearch运行参数
  • jvm.options : 用于配置Elasticsearch JVM设置
  • log4j2.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
本项目采用方式2,例子如下:

cluster.name: wenwen
node.name: es_node_1
network.host: 0.0.0.0
http.port: 9200
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"]
discovery.zen.minimum_master_nodes: 1
node.ingest: true
bootstrap.memory_lock: false
node.max_local_storage_nodes: 2

path.data: F:\elasticsearch\elasticsearch-6.2.1\data
path.logs: F:\elasticsearch\elasticsearch-6.2.1\logs

http.cors.enabled: true
http.cors.allow-origin: /.*/

注意path.data和path.logs路径配置正确。
常用的配置项如下:

  • cluster.name:
    配置elasticsearch的集群名称,默认是elasticsearch。建议修改成一个有意义的名称。
  • node.name:
    节点名,通常一台物理服务器就是一个节点,es会默认随机指定一个名字,建议指定一个有意义的名称,方便管理一个或多个节点组成一个cluster集群,集群是一个逻辑的概念,节点是物理概念,后边章节会详细介绍。
  • path.conf:
    -设置配置文件的存储路径,tar或zip包安装默认在es根目录下的config文件夹,rpm安装默认在/etc/
  • elasticsearch path.data:
    设置索引数据的存储路径,默认是es根目录下的data文件夹,可以设置多个存储路径,用逗号隔开。
  • path.logs:
    设置日志文件的存储路径,默认是es根目录下的logs文件夹 path.plugins: 设置插件的存放路径,默认是es根目录下的plugins文件夹
  • bootstrap.memory_lock: true
    -设置为true可以锁住ES使用的内存,避免内存与swap分区交换数据。
  • network.host:
    设置绑定主机的ip地址,设置为0.0.0.0表示绑定任何ip,允许外网访问,生产环境建议设置为具体的ip。
  • http.port: 9200
    设置对外服务的http端口,默认为9200。
  • transport.tcp.port: 9300
    集群结点之间通信端口
  • node.master:
    -指定该节点是否有资格被选举成为master结点,默认是true,如果原来的master宕机会重新选举新的master。
  • node.data:
    指定该节点是否存储索引数据,默认为true。
  • discovery.zen.ping.unicast.hosts: [“host1:port”, “host2:port”, “…”]
    设置集群中master节点的初始列表。
  • discovery.zen.ping.timeout: 3s
    设置ES自动发现节点连接超时的时间,默认为3秒,如果网络延迟高可设置大些。
  • discovery.zen.minimum_master_nodes:
    主结点数量的最少值 ,此值的公式为:(master_eligible_nodes / 2) + 1 ,比如:有3个符合要求的主结点,那么这里要设置为2。
  • node.max_local_storage_nodes:
    单机允许的最大存储结点数,通常单机启动一个结点建议设置为1,开发环境如果单机启动多个节点可设置大于1.

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
在这里插入图片描述
浏览器输入:http://localhost:9200
显示结果如下(配置不同内容则不同)说明ES启动成功:

name	"es_node_1"
cluster_name	"wenwen"
cluster_uuid	"Z3EooLXsTaaCvxq8zqMH3Q"
version	
number	"6.2.1"
build_hash	"7299dc3"
build_date	"2018-02-07T19:34:26.990113Z"
build_snapshot	false
lucene_version	"7.2.1"
minimum_wire_compatibility_version	"5.6.0"
minimum_index_compatibility_version	"5.0.0"
tagline	"You Know, for Search"

head插件安装和IK分词器就不写了,头疼…

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值