(一)es 概述与安装
一、基本概念介绍
1. es 核心术语
- 核心概念
ES -> 数据库
索引index -> 表
文档 document -> 行(记录)
字段 fields -> 列
早期版本有类型Type(后期7.X以后为_doc)
Type -> 表的逻辑类型
映射mapping 相当于mysql的表结构
近实时NRT near real time (搜索1秒以内)
节点node 可以集群
shard replica 数据分片
- 倒排索引

根据分词得到的值去标记位置
2:2:<2,4> 代表 第一个2 代表文档id 第二个2带表出现的频率,尖括号中的代表位置,第二个词与第四个词。
二、es的安装
1. 下载
百度搜索 es 或者点击
2. 上传解压移动
- 上传到linux 中
- 解压
tar -zxvf elasticsearch-7.4.2-linux-x86_64.tar.gz
- 移动到 usr/local下(这个根据个人习惯)
mv elasticsearch-7.4.2 /usr/local/
3. 配置
- 进入es目录
bin:可执行文件在里面,运行es的命令就在这个里面,包含了一些脚本文件等
config:配置文件目录
JDK:java环境
lib:依赖的jar,类库
logs:日志文件
modules:es相关的模块
plugins:可以自己开发的插件
data:这个目录没有,自己新建一下,后面要用 -> mkdir data,这个作为索引目录
- 修改核心配置文件-elasticearch.yml
修改项目名 cluster.name: myestest、node.name: myestest
# ---------------------------------- Cluster -----------------------------------
#
# Use a descriptive name for your cluster:
#
cluster.name: myestest
#
# ------------------------------------ Node ------------------------------------
#
# Use a descriptive name for the node:
#
node.name: myestest
#
# Add custom attributes to the node:
#
#node.attr.rack: r1
保存data地址 与log地址 /usr/local/elasticsearch-7.4.2/
#
# ----------------------------------- Paths ------------------------------------
#
# Path to directory where to store the data (separate multiple locations by comma):
#
path.data: /usr/local/elasticsearch-7.4.2/data
#
# Path to log files:
#
path.logs: /usr/local/elasticsearch-7.4.2/logs
#
网络对外可访问 端口可改
network.host: 0.0.0.0
# ---------------------------------- Network -----------------------------------
#
# Set the bind address to a specific IP (IPv4 or IPv6):
#
#network.host: 192.168.0.1
#
# Set a custom port for HTTP:
#
#http.port: 9200
#
# For more information, consult the network module documentation.
#
集群节点 目前是单台,先配置一个 cluster.initial_master_nodes: ["myestest"]
# --------------------------------- Discovery ----------------------------------
#
# Pass an initial list of hosts to perform discovery when this node is started:
# The default list of hosts is ["127.0.0.1", "[::1]"]
#
#discovery.seed_hosts: ["host1", "host2"]
#
# Bootstrap the cluster using an initial set of master-eligible nodes:
#
#cluster.initial_master_nodes: ["node-1", "node-2"]
#
# For more information, consult the discovery and cluster formation module documentation.
- 根据自己机器配置修改JVM参数 config/jvm.options
-Xms1g
-Xmx1g
- 添加用户
- ES不允许使用root操作es,需要添加用户,操作如下:
useradd esuser # 新增用户
chown -R esuser:esuser /usr/local/elasticsearch-7.4.2 # 给用户赋权
su esuser # 切换当前用户
whoami # 查看当前用户
- 切换完进入bin目录下
./elasticsearch
- 报错1
future versions of Elasticsearch will require Java 11; your Java version from [/home/jdk/jdk1.8.0_191/jre] does not meet this requirement
这是因为es自带jdk 与我们安装的jdk不一致,环境变量冲突了,但是是向下兼容的,所以对于我现在安装的 es7.4版本是可以用jdk1.8的。所以可以不用管这个。
- 报错二

ERROR: [1] bootstrap checks failed
[1]: max virtual memory areas vm.max_map_count [65530] is too low, increase to at least [262144]
[2020-10-21T15:09:26,905][INFO ][o.e.n.Node ] [VM-0-9-centos] stopping ...
[2020-10-21T15:09:27,058][INFO ][o.e.n.Node ] [VM-0-9-centos] stopped
[2020-10-21T15:09:27,058][INFO ][o.e.n.Node ] [VM-0-9-centos] closing ...
[2020-10-21T15:09:27,092][INFO ][o.e.n.Node ] [VM-0-9-centos] closed
[2020-10-21T15:09:27,098][INFO ][o.e.x.m.p.NativeController] [VM-0-9-centos] Native controller process has stopped - no new native processes can be started
这个就需要增加额外的配置(切换用户到root下),修改 /etc/security/limits.conf
# 修改配置文件 limits.conf
vim /etc/security/limits.conf
# 增加如下配置
* soft nofile 65536
* hard nofile 131072
* soft nproc 2048
* hard nproc 4096
修改 sysctl.conf 配置文件
# 编辑配置
vim /etc/sysctl.conf
# 增加配置
vm.max_map_count=262145
# 增加完了刷新一下配置,使其生效。
sysctl -p
- 重启搞定访问 9200 端口搞定
# 前台启动 Ctrl+c就退出了
./elasticsearch
# 后台启动 关闭使用kill 杀进程的方式
./elasticsearch -d
- 杀进程
[esuser@VM-0-9-centos logs]$ jps
15304 Elasticsearch
15773 Jps
[esuser@VM-0-9-centos logs]$ kill -9 15304
4. 安装插件
- elasticsearch-head 可以去git官网,也可以百度云
链接: https://pan.baidu.com/s/1U6sKvxOG0BfmK5SMd8GY3w
提取码: 7vh5
- 若链接有跨域问题可以在yml配置文件中增加下面配置
# 开启跨域
http.cors.enabled: true
# 允许所有域名访问
http.cors.allow-origin: "*"
# 头部标识
http.cors.allow-headers: Authorization
- 下载后安装crt文件
将文件夹elasticsearch-head-master\crx中 es-head.crx文件拖到浏览器里就可以安装插件了。
若报错参考:https://www.cnblogs.com/wzx1blog/p/13066693.html
- 官方文档
https://www.elastic.co/guide/en/elasticsearch/reference/7.x/index.html
(一)es 概述与安装的更多相关文章
- ElasticSearch入坑指南之概述及安装
---恢复内容开始--- ElasticSearch入坑指南之概述及安装 了解ElasticSearch ElasticSearch(简称ES)基于Lucene的分布式全文检索引擎.使用ES可以实现近 ...
- OpenVAS漏洞扫描基础教程之OpenVAS概述及安装及配置OpenVAS服务
OpenVAS漏洞扫描基础教程之OpenVAS概述及安装及配置OpenVAS服务 1. OpenVAS基础知识 OpenVAS(Open Vulnerability Assessment Sys ...
- ES 入门之一 安装ElasticSearcha
安装ElasticSearcha 学习ES也有快一个月了,但是学习的时候一直没有总结.以前没有总结是因为感觉不会的很多,现在对ES有一点了解了.索性就从头从安装到使用ES做一个详细的总结,也分享给其他 ...
- C++框架_之Qt的开始部分_概述_安装_创建项目_快捷键等一系列注意细节
C++框架_之Qt的开始部分_概述_安装_创建项目_快捷键等一系列注意细节 1.Qt概述 1.1 什么是Qt Qt是一个跨平台的C++图形用户界面应用程序框架.它为应用程序开发者提供建立艺术级图形界面 ...
- Flask 学习(一)概述及安装
Flask 概述及安装 Flask 简介 Flask是一个使用 Python 编写的轻量级 Web 应用框架.其 WSGI 工具箱采用 Werkzeug ,模板引擎则使用 Jinja2 . 官方网址 ...
- 批量搞机(二):分布式ELK平台、Elasticsearch介绍、Elasticsearch集群安装、ES 插件的安装与使用
一.分布式ELK平台 ELK的介绍: ELK 是什么? Sina.饿了么.携程.华为.美团.freewheel.畅捷通 .新浪微博.大讲台.魅族.IBM...... 这些公司都在使用 ELK!ELK! ...
- 【转】Struts1.x系列教程(4):标签库概述与安装
转载地址:http://www.blogjava.net/nokiaguy/archive/2009/01/archive/2009/01/archive/2009/01/archive/2009/0 ...
- MongoDB笔记(一)MongoDB概述和安装
概述 关键词:关系数据库.非关系数据库 关系数据库: 关系数据库,是建立在关系数据库模型基础上的数据库,借助于集合代数等概念和方法来处理数据库中的数据.目前主流的关系数据库有oracle.SQL.ac ...
- Nginx概述和安装(1)
一.Nginx概述 Nginx ("engine x") 是一个高性能的 HTTP 和 反向代理 服务器,也是一个 IMAP/POP3/SMTP 代理服务器. Nginx 是由 I ...
随机推荐
- Redis配置及攻击利用
Redis配置及攻击利用 Redis及其安全配置 Redis介绍 redis默认会绑定在 0.0.0.0:6379,如果没有进行采用相关的策略,比如添加防火墙规则避免其他非信任来源 ip 访问等,这样 ...
- 题解 english
传送门 好题 肝完这题感觉头巨痛 首先\(n \leqslant 1000\)的部分可以\(n^2\)单调队列,有30pts 然后考场上魔改了下单调栈,让它能顺便维护出以\(1~i-1\)为左端点的区 ...
- new和delete关键字
new关键字创建出来的对象位于什么地方?很明显嘛,new关键字创建出来的对象一定位于堆空间,这种说法一定正确吗?本篇博客帮你揭开其神秘的面纱. 被忽略的事实new/delete的本质是C++预定义的操 ...
- Spring源码解析之ConfigurationClassPostProcessor(三)
在上一章笔者介绍了ConfigurationClassParser.doProcessConfigurationClass(...)方法,在这个方法里调用了processImports(...)方法处 ...
- Linkerd 2.10(Step by Step)—配置代理并发
Linkerd 2.10 系列 快速上手 Linkerd v2 Service Mesh(服务网格) 腾讯云 K8S 集群实战 Service Mesh-Linkerd2 & Traefik2 ...
- 用CUDA写出比Numpy更快的规约求和函数
技术背景 在前面的几篇博客中我们介绍了在Python中使用Numba来写CUDA程序的一些基本操作和方法,并且展示了GPU加速的实际效果.在可并行化的算法中,比如计算两个矢量的加和,或者是在分子动力学 ...
- 手撕LRU缓存了解一下
面试官:来了,老弟,LRU缓存实现一下? 我:直接LinkedHashMap就好了. 面试官:不要用现有的实现,自己实现一个. 我:..... 面试官:回去等消息吧.... 大家好,我是程序员学长,今 ...
- linux grep命令使用详解
grep是我们最常用的命令之一,但是正真用的熟的不多,把基础命令记牢固,能帮我们节约很多时间 grep的option -A 1 表示找到所有匹配行,并显示所有匹配行后的一行 在错误日志查找时还是很有用 ...
- 基于Linux系统下Apache服务器的安装部署
企业中常用的web服务,用来提供http://(超文本传输协议). web系统是客户端/服务器模式的,所以应该有服务器和客户端里两个部分.常用的服务器程序时Apache,常用的客户端程序是浏览器.ww ...
- Mybatis-Plus - 条件构造器 QueryWrapper 的使用
目录 前言 查询示例 基础代码 QueryWrapper 的基本使用 QueryWrapper 的lambada写法 LambadaQueryWrapper 的使用 LambdaQueryChainW ...