elasticsearch安装与配置介绍

基本概念

集群:一个或者多个elasticsearch节点组成的集合

索引:含有相同属性的文档集合,例如一个索引代表消费者数据,一个索引代表产品数据(相当于MySQL的database)

类型:索引可以定义一个或多个类型,通常定义有相同字段的文档作为一个类型,文档必须属于一个类型(相当于MySQL的table)

文档:文档是可以被索引的基本数据单位,例如一个用户的基本信息,一片文章的数据,他是整个es里最小的存储单位(相当于MySQL的每一行具体的记录)

单节点安装

elasticsearch是基于java开发的,所以安装之前需要先安装版本大于等于1.8的jdk

jdk安装: 下载---解压---配置环境变量

下载地址: https://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html,自己去这个地址下载,因为他会带一个认证参数AuthParam

wget https://download.oracle.com/otn-pub/java/jdk/8u201-b09/42970487e3af4f5aa5bca3f542482c60/jdk-8u201-linux-i586.tar.gz?AuthParam=1551253769_ff54ba4acb29cacf09d358ec0798e55d

tar -zxvf jdk-8u201-linux-x64.tar.gz\?AuthParam\=1551253769_ff54ba4acb29cacf09d358ec0798e55d 

配置环境变量

sudo vi ~/.bash_profile

source ~/.bash_profile

elasticsearch安装: 下载---解压---配置---启动

wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-6.6.2.tar.gz

tar -zxvf elasticsearch-6.6.2.tar.gz

sudo vi config/elasticsearch.yml

elasticsearch默认安装后设置的内存是1GB,我这里只是自己的一个乞丐版本的服务器,内存比较小,我就只给他分配256M(根据自己情况使用配置,如果内存不够的话,启动过程中会提示已杀死这类提示)

vi config/jvm.options

ps: 更多具体配置可以在elasticsearch官网查看

启动: elasticsearch可以接收用户输入的脚本并且执行,处于安全考虑,他不能root账户来启动,不然会报下图错误

所以我需要为elasticsearch新建一个系统运行账号

groupadd elasticsearch     //新建一个elasticsearch的用户组

useradd -g elasticsearch elasticsearch  //在elasticsearch用户组下面建立一个elasticsearch的用户

将elasticsearch目录的所有者给刚刚建立的账号

chown -R elasticsearch:elasticsearch elasticsearch-6.6.2/

然后切换到刚刚的账号启动elasticsearch

su elasticsearch

./elasticsearch-6.6.2/bin/elasticsearch

启动过程中可能会出现下面这类的错误提示

错误1: elasticsearch这个用户的最大打开线程数(3894)太低,至少增加到4096

解决:

1. 查看用户最大打开线程数

ulimit -a

2. 切换到root用户,编辑文件

vi /etc/security/limits.conf

在文件末尾加上下面配置

* 表示匹配所有用户, nproc 表示配置最大打开线程数

3. 退出从新登录后,再次查看,修改成功

错误2: 最大虚拟内存区域vm.max_map_count(65530)太低,至少增加到262144

解决:

在root账号下修改配置文件

vi /etc/sysctl.conf

在末尾添加配置,值大于等于实体的262144就可以

添加完成后执行下面命令

sysctl -p

然后可以查看到成功修改成你设置的数字

上面问题解决后,切换成elasticsearch账号,继续启动es,看到下图的样子证明就启动成功了

验证

浏览器输入ip地址,加上自己在配置文件中配置的端口,比如我这里的9201访问

我前面配置的host是0.0.0.0,所以可以用外网访问,不需要外网访问的话,就配置127.0.0.1或者对应的内网ip就行

安装head插件

安装好ES后,你就可以通过官网提供的相关命令开进行索引的创建,但是更多人还是习惯用界面直接操作.这个时候就可以用elasticsearch-head这个插件了.elasticsearch-head 是用于监控 ES 状态的客户端插件,包括数据可视化、执行增删改查操作等(我就简单暴露的把它理解成了像Navicat这类的工具).

git地址: https://github.com/mobz/elasticsearch-head

安装前准备

在上面地址说明中可以看到,安装他需要npm包管理工具,所以先在系统下安装一下node.js吧

nodejs下载地址: https://nodejs.org/en/download/

长期维护的版本可能不包含最新版本最新特性,但是比较稳定,所以这里就用稳定的版本吧.可以选择源码安装,就是可能坑有点多(被坑过一次的经历),我这里就直接下载'编译好的二进制文件',因为简单嘛

wget https://nodejs.org/dist/v10.15.3/node-v10.15.3-linux-x64.tar.xz     //下载

xz -d node-v10.15.3-linux-x64.tar.xz            //解压xz格式

tar -xf node-v10.15.3-linux-x64.tar        //最终解压

进入里面的bin目录就可以看到已经编译好的node和npm了,直接使用就好.

分别给他们设置个软连方便全局使用node和npm命令

ln -s /opt/soft/node-v10.15.3-linux-x64/bin/node /usr/local/bin/

ln -s /opt/soft/node-v10.15.3-linux-x64/bin/npm /usr/local/bin/

开始安装head

git clone git://github.com/mobz/elasticsearch-head.git

cd elasticsearch-head

npm install    //知道node的应该明白这一步其实就是在下载安装相关的依赖扩展

如果在安装图中的扩展的时候报错了,就直接忽略他,执行下面命令

npm install phantomjs-prebuilt@2.1.16 --ignore-scripts         //执行这个命令前,先把node_modules/目录下已经有的扩展全部删除了

到这里先不要忙去执行 'npm run start' 运行,先修改一下配置文件吧

sudo vi Gruntfile.js

上面配置文件中可以修改head插件监听的端口.默认是9100,我改成9101

sudo vi _site/app.js

上面配置文件中可以修改head访问es的端口,这里改的端口需要和你es的一致

最开始我在配置es的时候,配置了两个允许跨域的选项就是为了这里head能够访问es

npm run start  //启动

启动之前保证es是启动的状态, 如果不想占用终端,就在es启动命令中添加一个 '-d'参数, 然后浏览器输入http://localhost:9101访问就可以,如果是云服务器,就用对应的ip地址替换localhost

ps: 在这个插件中我们就能界面化es的操作,还是比较方便的,但是也正因为方便,而且这个拥有各种删除什么的权限,只能在开发阶段的时候用,生产环境一定要关闭他

elasticsearch集群搭建

集群中包含三台服务器,内网ip分别是

172.27.0.17(master)----主服务器,这也是上面步骤安装的服务器

172.27.0.11(slave1)-----从服务器1

172.27.0.6 (slave2)-----从服务器2

按照前面的步骤分配在两台从服务器中安装ES,注意下图中是和主节点配置不一样的地方

cluster.name: 集群名字必须一致

node.name: 从服务器节点名字(两个从节点分别为slave1个slave2)

node.master: 是否为主节点

discovery.zen.ping.unicast.hosts: 节点向指定的主机发送单播请求,可以理解成寻找他的主节点,数组的形式证明可以多个,这里只有一个

三台es服务器以及head插件都分别配置好并且启动后,直接访问head所在服务器以及监听的端口,就能看到es集群了

IK分词插件的安装

详细地址: https://github.com/medcl/elasticsearch-analysis-ik,上面有具体的安装步骤

版本选择

上图是版本的选择,我这里安装的es版本是6.6.2,多以直接选择ik的master版本

安装

他提供了两种安装方式,第一种是去 https://github.com/medcl/elasticsearch-analysis-ik/releases这个地址下载对应的版本,然后在你自己的es目录下的扩展插件目录下,解压出来就可以,第二种方式是直接用es安装插件的运行命令,下面分别试一试

ps: 两种安装方式都记得切换到为es服务创建的账号下进行操作,比如我这里切换到 elasticsearch 这个账号

1. 下载的方式安装

进入es的plugins目录,创建ik目录,下载ik分词插件,解压

wge https://github.com/medcl/elasticsearch-analysis-ik/releases/download/v6.6.2/elasticsearch-analysis-ik-6.6.2.zip

停止掉es服务重新启动,在启动的日志中,就可以看到是否加载了ik插件

2.  命令的方式安装

这种安装方式需要需要es版本大于等于5.5.1,刚刚的安装方式我是在集群的master节点安装的,接下来我切换到slave1节点安装

查看es运行状态,如果运行中,直接停止

切换到es服务账号,在es的bin目录下执行安装命令

./elasticsearch-plugin install https://github.com/medcl/elasticsearch-analysis-ik/releases/download/v6.6.2/elasticsearch-analysis-ik-6.6.2.zip

测试分词器的分词计划

1. 默认的standard

2. 刚刚安装的ik分词器

可以看到,默认的standard是把每个字都单独分开了,而ik_smart是只能的分解成了一些词语,显然后者比较适用

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,001评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,210评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,874评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,001评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,022评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,005评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,929评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,742评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,193评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,427评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,583评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,305评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,911评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,564评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,731评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,581评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,478评论 2 352