ElasticSearch和Kibana 5.X集群的安装



1、准备工作

1.1、下载安装包

Elastic官网下载安装包,ElasticSearch和Kibana版本必须一致!!!

本次安装的版本为5.3.2:

  • elasticsearch-5.3.2.tar.gz
  • kibana-5.3.2-linux-x86_64.tar.gz

1.2、系统的准备

  • ElasticSearch集群不能以root用户启动,所以需要准备一个非root用户。
  • 设置系统允许内存锁定
ulimit -l unlimited

2、ElasticSearch集群的安装

2.1、修改 config/elasticsearch.yml 文件


!!!!!!!注意: 配置文件中,冒号后面必须加空格!!!!!!!!!!!


  • 修改集群名称(防止以后出现集群重名,必须修改),和节点名称

  • 修改集群的数据存放目录和日志目录(注意权限问题,将相应目录的所属用户:组更改为集群启动的用户)

  • 内存相关设置,增加如下属性:

    • indices.memory.index_buffer_size: 25%
    • indices.memory.min_index_buffer_size: 512mb
    • bootstrap.memory_lock: true
  • 网络配置,增加如下属性(我们有5台机器,其中4台master和node都设为true,另外一台都为false作为负载均衡点):

    • transport.publish_host: 0.0.0.0
    • transport.bind_host: 0.0.0.0
    • http.host: 172.31.18.13 ------------- 更改为本机地址
    • network.bind_host: 0.0.0.0
    • network.publish_host: 0.0.0.0
    • transport.tcp.port: 9300
    • node.master: true ------------- 设置为master
    • node.data: true ------------- 设置为datanode
    • http.port: 9200
    • http.enabled: true
    • http.cors.enabled: true
    • http.cors.allow-origin: "*"
  • 配置集群自动发现节点

    • discovery.zen.ping.unicast.hosts: 集群的所有ip,用双引号包含,逗号隔开
    • discovery.zen.minimum_master_nodes: 集群最小master数量,值设置为 节点数/2 + 1
  • 线程池和脚本配置,添加以下参数:

    • script.painless.regex.enabled: true ----- 允许使用正则
    • thread_pool.index.size: 33 ----- 具体数值为CPU物理核的2倍
    • thread_pool.index.queue_size: 1000 ----- 具体数值大约为CPU物理核的60倍
  • 附:公司ElasticSearch集群的配置文件:elasticsearch.yml

2.2、修改 bin/elasticsearch 文件

在文件前面增加如下属性:

  • JAVA_HOME=/usr/local/jdk1.8.0_77 ----- jdk目录

  • ES_JAVA_OPTS="-Xms31g -Xmx31g" ----- 设置内存,总内存的一半和31之间取小的

  • JAVA_OPTS="$JAVA_OPTS -XX:+UseParNewGC"

  • JAVA_OPTS="$JAVA_OPTS -XX:+UseConcMarkSweepGC"

  • JAVA_OPTS="$JAVA_OPTS -XX:CMSInitiatingOccupancyFraction=75"

  • JAVA_OPTS="$JAVA_OPTS -XX:+UseCMSInitiatingOccupancyOnly"

2.3、将整个ElasticSearch目录复制到其它服务器

  • 将目录复制到其它服务器之后,修改每个机器的config/elasticsearch.yml中的节点名称、http.host、和服务器硬件配置有关的相关参数
  • 其中一台服务器的node.master和node.data都设置为false,作为负载均衡点,集群和外界通讯都通过这台机器,这台机器的硬件配置可以低一点

2.4、将启动加入到系统服务(可选,方便启动)

服务脚本为:

#!/bin/bash
# chkconfig: 2345 10 90
# description: Elasticsearch Service .... # 此处需要更改
ES_HOME=/opt/elasticsearch EXEC_PATH=$ES_HOME
EXEC=elasticsearch
DAEMON=$EXEC_PATH/bin/$EXEC
PID_FILE=$ES_HOME/pid/es.pid
ServiceName='Elasticsearch 5.0' . /etc/rc.d/init.d/functions if [ ! -x $DAEMON ] ; then
echo "ERROR: $DAEMON not found"
exit 1
fi stop()
{
echo "Stoping $ServiceName ..."
ps aux | grep "$DAEMON" | kill -9 `awk '{print $2}'` >/dev/null 2>&1
rm -f $PID_FILE
usleep 100
echo "Shutting down $ServiceName: [ successful ]"
} start()
{
echo "Starting $ServiceName ..."
$DAEMON > /dev/null &
pidof $EXEC > $PID_FILE
usleep 100
echo "Shutting down $ServiceName: [ successful ]"
}
restart()
{
stop
start
}
case "$1" in
start)
start
;;
stop)
stop
;;
restart)
restart
;;
status)
status -p $PID_FILE $DAEMON
;;
*)
echo "Usage: service $ServiceName {start|stop|restart|status}"
exit 1
esac
exit $?

2.5、启动集群

后台运行每台机器的 bin/elasticsearch 脚本

用浏览器访问负载均衡点的9200端口: http://172.31.18.15:9200/_cluster/health

{
"cluster_name": "datageek",
"status": "green",
"timed_out": false,
"number_of_nodes": 5,
"number_of_data_nodes": 4,
"active_primary_shards": 43,
"active_shards": 58,
"relocating_shards": 0,
"initializing_shards": 0,
"unassigned_shards": 0,
"delayed_unassigned_shards": 0,
"number_of_pending_tasks": 0,
"number_of_in_flight_fetch": 0,
"task_max_waiting_in_queue_millis": 0,
"active_shards_percent_as_number": 100
}

如果看到如上结果,各个nodes数量都对得上,就说明集群安装成功。

3、Kibana安装

3.1、修改配置文件

  • 修改config/kibana.yml文件,增加如下三个属性(冒号后面要加空格):

    • script.painless.regex.enabled: true
    • server.host: "0.0.0.0"
    • elasticsearch.url: "http://172.31.18.15:9200" ----- elasticsearch集群的负载均衡点的ip和端口
  • 修改bin/kibana文件,在首行增加 JAVA_HOME=/usr/local/jdk1.8.0_77

3.2、启动Kibana

后台运行bin/kibana脚本,在浏览器访问kibana机器的5601端口,看到页面说明Kibana安装成功。

ElasticSearch和Kibana 5.X集群的安装的更多相关文章

  1. elasticsearch + kibana + x-pack + logstash_集群部署安装

    elasticsearch 部分总体描述: 1.elasticsearch 的概念及特点.概念:elasticsearch 是一个基于 lucene 的搜索服务器.lucene 是全文搜索的一个框架. ...

  2. 部署elasticsearch(三节点)集群+filebeat+kibana

    用途 ▷ 通过各个beat实时收集日志.传输至elasticsearch集群 ▷ 通过kibana展示日志 实验架构 名称:IP地址:CPU:内存 kibana&cerebro:192.168 ...

  3. ElasticSearch 5学习(7)——分布式集群学习分享2

    前面主要学习了ElasticSearch分布式集群的存储过程中集群.节点和分片的知识(ElasticSearch 5学习(6)--分布式集群学习分享1),下面主要分享应对故障的一些实践. 应对故障 前 ...

  4. ElasticSearch 5学习(6)——分布式集群学习分享1

    在使用中我们把文档存入ElasticSearch,但是如果能够了解ElasticSearch内部是如何存储的,将会对我们学习ElasticSearch有很清晰的认识.本文中的所使用的ElasticSe ...

  5. ELK之 elasticsearch ES集群 head安装

    最近项目用到 jenkins  ELK  也在一次重新学习了一次  jenkins 不用说了 玩得就是  插件   +  base---shell ,  ELK  这几年最流得log收集平台,当然不止 ...

  6. elasticsearch基于RBAC认证和集群之间的TLS通讯

    elasticsearch基于RBAC认证和集群之间的TLS通讯 一.背景 二.需要解决的问题 三.给es增加用户名和密码访问 1.修改config/elasticsearch.yml 2.访问es集 ...

  7. ElasticSearch入门 第二篇:集群配置

    这是ElasticSearch 2.4 版本系列的第二篇: ElasticSearch入门 第一篇:Windows下安装ElasticSearch ElasticSearch入门 第二篇:集群配置 E ...

  8. ElasticSearch 深入理解 三:集群部署设计

    ElasticSearch 深入理解 三:集群部署设计 ElasticSearch从名字中也可以知道,它的Elastic跟Search是同等重要的,甚至以Elastic为主要导向. Elastic即可 ...

  9. hadoop HA集群的安装

    1.hadoop集群规化 ip 主机名 安装软件 角色 运行进程 10.124.147.22 hadoop1 jdk.zookeeper.hadoop namenode/zookeeper/jobhi ...

随机推荐

  1. 【HTML】谈谈html的meta标签

    一.定义&用法 <meta> 元素可提供有关页面的元信息(meta-information),比如针对搜索引擎和更新频度的描述和关键词. <meta> 标签位于文档的头 ...

  2. 现代C++新四大名著及C++学习杂谈

    现代C++新四大名著及C++学习杂谈 翻开自己的博客,在2012年8月我曾经写过如下一篇博客, <<C++学习的方法以及四大名著>> http://www.cnblogs.co ...

  3. 一台机器启动多个tomcat简单配置

    一台机器启动多个Tomcat只需要解决Tomcat端口冲突的问题. 相关配置:打开 Tomcat 目录下 conf \ server.xml 共修改三处端口,分别是: <Server port= ...

  4. html、js、django处理日期问题

    在html中使用日期控件,利用ngmodel将输入的值传到js里: <input type="date" ng-model="timeOps.test.a_time ...

  5. Vue组件基础用法

    前面的话 组件(Component)是Vue.js最强大的功能之一.组件可以扩展HTML元素,封装可重用的代码.根据项目需求,抽象出一些组件,每个组件里包含了展现.功能和样式.每个页面,根据自己所需, ...

  6. [js高手之路]es6系列教程 - 解构详解

    解构通俗点说,就是通过一种特定格式,快捷的读取对象/数组中的数据的方法, es6之前,我们通过对象名称[键] 读取数据 var User = { 'name' : 'ghostwu', 'age' : ...

  7. Mysql自动填充测试数据

    前言 最近写了两个小脚本,一个应用于Mysql的自动填充测试数据,另外一个是bash写的定期删除日志文件,两个脚本如何使用,在GitHub上面都有所说明,这里不再赘述,这里主要是想聊一下Mysql的存 ...

  8. SecureCRT 常用命令大全

    常用命令:一.ls 只列出文件名 (相当于dir,dir也可以使用) -A:列出所有文件,包含隐藏文件. -l:列表形式,包含文件的绝大部分属性. -R:递归显示. --help:此命令的帮助. 二. ...

  9. 自适应Simpson积分

    自适应Simpson积分 作用 如标题所示,这玩意就是当你不会微积分的时候来求积分的. 总所周知,积分的定义就是函数的某一段与坐标轴之间的面积. 那么,自适应Simpson积分就是一种可以再某些精度下 ...

  10. tcpdump抓包分析详解

    說實在的,對於 tcpdump 這個軟體來說,你甚至可以說這個軟體其實就是個駭客軟體, 因為他不但可以分析封包的流向,連封包的內容也可以進行『監聽』, 如果你使用的傳輸資料是明碼的話,不得了,在 ro ...