一、准备阶段

三台ubuntu系统机器

ip 计算机名
192.168.2.132 master
192.168.2.133 slave1
192.168.2.134 slave2

下载:

jdk-8u201-linux-x64.tar.gz
elasticsearch-6.1.3.tar.gz

二、配置JDK

2.1配置JAVA环境变量

解压jdk-8u201-linux-x64.tar.gz,并修改文件名,已方便配置环境变量

#解压JDK安装包
tar -zxvf jdk-8u201-linux-x64.tar.gz
#修改文件夹名称
mv jdk1.8.0_201 jdk
#写入系统环境变量中
vi /etc/profile
export JAVA_HOME=/opt/jdk
export PATH=$JAVA_HOME/bin:$PATH
#让系统环境变量生效
source /etc/profile

2.2检测JDK是否生效

java -version

三、修改系统配置

3.1修改limits.conf

增加连接数,不然ES无法启动

vi /etc/security/limits.conf

添加如下内容

注意:ubuntu系统不能写*,必须写root配置,否则不会生效

#Ubuntu系统
root soft nofile 65536
root hard nofile 131072
root soft nproc 65536
root hard nproc 524288
root soft memlock unlimited
root hard memlock unlimited
supermap soft memlock unlimited
supermap hard memlock unlimited
#----------------------------------------------
#其他系统
* soft nofile 65536
* hard nofile 131072
* soft nproc 65536
* hard nproc 524288
* soft memlock unlimited
* hard memlock unlimited

3.2修改sysctl.conf

增加连接数,不然ES无法启动

vi /etc/sysctl.conf
最后一行增加
vm.max_map_count=655360

运行命令

sysctl -p

使之生效

3.3重启电脑后,检查是否生效

ulimit -Sn 查看的是软限制
ulimit -Hn 查看的是硬限制
ulimit -a 查看完整信息

如果信息都变过来后,可以继续,在其他两台电脑上修改上述内容(配置JDK,修改系统环境变量操作)

四、添加新用户(三台机器上都要操作)

ES启动必须使用非Root用户启动,所以我们需要创建一个新用户用于启动

groupadd supermap
useradd -m supermap -g supermap -p supermap
passwd supermap

新添加完成后切换到新创建的用户

su supermap

五、安装ES

5.1 将ES压缩包放到/home/supermap 目录下并解压ES安装包,(三台机器上都要操作)

tar -zxvf elasticsearch-6.1.3.tar.gz

并创建存储ES的数据目录和日志目录

mkdir /home/supermap/elasticsearch-6.1.3/data
mkdir /home/supermap/elasticsearch-6.1.3/logs

5.2 修改ES配置文件 (下文只保留所需内容)

vi /home/supermap/elasticsearch-6.1.3/config/elasticsearch.yml
# ---------------------------------- Cluster -----------------------------------

cluster.name : my-cluster

# ------------------------------------ Node ------------------------------------

node.name : node-1

# ----------------------------------- Paths ------------------------------------

path.data: /home/supermap/elasticsearch-6.1.3/data

path.logs: /home/supermap/elasticsearch-6.1.3/logs

# ----------------------------------- Memory -----------------------------------

bootstrap.memory_lock: true

# ---------------------------------- Network -----------------------------------

network.host: 192.168.2.132

http.port: 9200

node.master: true

node.data: true

# --------------------------------- Discovery ----------------------------------

discovery.zen.ping.unicast.hosts: ["192.168.2.132", "192.168.2.133","192.168.2.134"]

discovery.zen.minimum_master_nodes: 2

# ---------------------------------- Gateway -----------------------------------

gateway.recover_after_nodes: 3

其他节点(其他两台机器)slave1和slave2可复制上述内容,并修改其他几个关键信息,其他同上述master一致。

node.name: node-2

node.master: true

node.data: true

network.host: 192.168.2.133
node.name: node-3

node.master: false

node.data: true

network.host: 192.168.2.134

5.3 启动ES集群

运行三个节点顺序无关,但是必须得用普通用户启动。

cd /home/supermap/elasticsearch-6.1.3/bin

./elasticsearch

或者后台方式运行,如果以后台方式运行,将来查看进程命令:ps aux | grep elasticsearch

./elasticsearch -d

5.4 访问ES

可以使用IP地址加9200端口进行访问

当其他机器集群启动起来后,可以使用2种方法查看集群的健康度

方法一:curl 'http://IP:9200/_cat/health?v'

epoch      timestamp cluster    status node.total node.data shards pri relo init unassign pending_tasks max_task_wait_time active_shards_percent
1573459172 15:59:32 my-cluster green 3 3 0 0 0 0 0 0 - 100.0%

方法二:浏览器访问http://IP:9200/_cat/health?v

epoch      timestamp cluster    status node.total node.data shards pri relo init unassign pending_tasks max_task_wait_time active_shards_percent
1573459526 16:05:26 my-cluster green 3 3 0 0 0 0 0 0 - 100.0%

六、常见错误

6.1 uncaught exception in thread [main] org.elasticsearch.bootstrap.StartupException: java.lang.RuntimeException: can not run elasticsearch as root

不能以root用户启动

6.2 ERROR: bootstrap checks failed memory locking requested for elasticsearch process but memory is not locked

内存锁定失败,切换到root用户,修改limits.conf配置文件,vim /etc/security/limits.conf
添加* soft memlock unlimited / * hard memlock unlimited
(ubutnu需要写root soft memlock unlimited / root hard memlock unlimited)
临时取消:ulimit -l unlimited

6.3 max virtual memory areas vm.max_map_count [65530] is too low, increase to at least [262144]

最大虚拟内存太小,切换到root用户下,修改配置文件sysctl.conf

sudo vim /etc/sysctl.conf
添加下面配置: vm.max_map_count=655360
并执行命令: sysctl -p

6.4 max file descriptors [4096] for elasticsearch process is too low, increase to at least [65536]

按照上述所说的准备里修改limits.conf配置文件, 修改之后查询,ulimit -a

如果没有变化,需要修改/etc/pam.d/su,将session required pam_limits.so
注释打开,保存,重启就会生效
临时修改,ulimit -n 65536
ulimit -Sn 查看的是软限制
ulimit -Hn 查看的是硬限制
ulimit -a 查看完整信息

6.5 java.lang.UnsupportedOperationException: seccomp unavailable: requires kernel 3.5+ with CONFIG_SECCOMP and CONFIG_SECCOMP_FILTER compiled in

内核太低的缘故,可以升级linux内核(可忽略)

6.6 ERROR: bootstrap checks failed system call filters failed to install; check the logs and fix your configuration or disable system call filters at your own risk

修改elasticsearch-6.1.3/config/elasticsearch.yml ,增加

bootstrap.system_call_filter: false

6.7跨域访问问题

修改config\elasticsearch.yml,新增加如下配置,重启ES即可

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

(转发请注明出处:http://www.cnblogs.com/zhangyongli2011/ 如发现有错,请留言,谢谢)

Elasticsearch6.x集群部署的更多相关文章

  1. elasticsearch6.x集群环境部署

    elasticsearch集群部署安装jdk chmod 755 jdk-8u161-linux-x64.tar.gztar -zxvf jdk-8u161-linux-x64.tar.gzcp jd ...

  2. Linux中Elasticsearch集群部署

    1.下载安装包elasticsearch-6.3.1  安装包自己下载,网上很多 2.安装位置在cd /usr/local/elasticsearch/目录下 3.因为ES使用root权限运行会报错, ...

  3. Elasticsearch系列---生产集群部署(下)

    概要 本篇继续讲解Elasticsearch集群部署的细节问题 集群重启问题 如果我们的Elasticsearch集群做了一些离线的维护操作时,如扩容磁盘,升级版本等,需要对集群进行启动,节点数较多时 ...

  4. elasticSearch数据库、skywalking集群部署

    Centos6上面安装elasticsearc数据库的集群 安装的是6.3.2版本,安装之前首先要先安装jdk1.8版本 安装之前首先需要关闭防火墙 Centos6 sudo service ipta ...

  5. 基于Centos7xELK+Kafka集群部署方案

    本次集群部署使用ELK版本统一为6.8.10,kafka为2.12-2.51 均可在官网下载 elasticsearch下载地址:https://www.elastic.co/cn/downloads ...

  6. Quartz.net持久化与集群部署开发详解

    序言 我前边有几篇文章有介绍过quartz的基本使用语法与类库.但是他的执行计划都是被写在本地的xml文件中.无法做集群部署,我让它看起来脆弱不堪,那是我的罪过. 但是quart.net是经过许多大项 ...

  7. Openfire 集群部署和负载均衡方案

    Openfire 集群部署和负载均衡方案 一.   概述 Openfire是在即时通讯中广泛使用的XMPP协议通讯服务器,本方案采用Openfire的Hazelcast插件进行集群部署,采用Hapro ...

  8. 基于Tomcat的Solr3.5集群部署

    基于Tomcat的Solr3.5集群部署 一.准备工作 1.1 保证SOLR库文件版本相同 保证SOLR的lib文件版本,slf4j-log4j12-1.6.1.jar slf4j-jdk14-1.6 ...

  9. jstorm集群部署

    jstorm集群部署下载 Install JStorm Take jstorm-0.9.6.zip as an example unzip jstorm-0.9.6.1.zip vi ~/.bashr ...

随机推荐

  1. ADB命令无法导出文件到物理机上处理办法

    因为想查看一下脚本生成的sqlite文件.就想导出文件,,结果导出adb pull命令一直报错.使用su也是错误的..最后发现adb pull 不能再adb的命令状态下执行.需要退出adb命令.然后直 ...

  2. TouchListener PK OnTouchEvent + 多点触碰

    1.基于监听的TouchListener 代码示例: 实现效果图: 实现代码: main.xml <RelativeLayout xmlns:android="http://schem ...

  3. A-02 梯度下降法

    目录 梯度下降法 一.梯度下降法详解 1.1 梯度 1.2 梯度下降法和梯度上升法 1.3 梯度下降 1.4 相关概念 1.4.1 步长 1.4.2 假设函数 1.4.3 目标函数 二.梯度下降法流程 ...

  4. jquery经常用到的代码段

    1.1jquery实现手风琴效果 <script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js"&g ...

  5. C#中的等值判断1

    目录 简介 值类型和引用类型的相等比较 和相等比较相关的函数 string 和 System.Uri 的等值比较 泛型接口 IEquatable<T> 自定义比较方法 举例 总结 简介 最 ...

  6. 用 Python 爬取网易严选妹子内衣信息,探究妹纸们的偏好

    网易商品评论爬取 分析网页 评论分析 进入到网易精选官网,搜索“文胸”后,先随便点进一个商品. 在商品页面,打开 Chrome 的控制台,切换至 Network 页,再把商品页Python入门到精通学 ...

  7. Numpy中的三个常用正态分布相关的函数,randn,standard_normal, normal的区别

    这三个函数都可以返回随机正态分布(高斯Gaussian 分布)的数组,都可以从numpy.random中导出 先看三个函数的参数方式: randn: randn(d0, d1, ..., dn), 返 ...

  8. 【Spring Cloud】客户端负载均衡组件——Ribbon(三)

    一.负载均衡 负载均衡技术是提高系统可用性.缓解网络压力和处理能力扩容的重要手段之一. 负载均衡可以分为服务器负载均衡和客户端负载均衡,服务器负载均衡由服务器实现,客户端只需正常访问:客户端负载均衡技 ...

  9. GDAL集成对KML文件的支持

    目录 1. 正文 1.1. 编译LibKML 1.1.1. 第三方库支持 1.1.2. 编译错误 1.2. 配置GDAL 1.3. 链接问题 2. 参考 1. 正文 GDAL可以支持将KML作为矢量文 ...

  10. 10.Linux用户权限

    1.权限基本概述 1. 什么是权限? 我们可以把它理解为操作系统对用户能够执行的功能所设立的限制,主要用于约束用户能对系统所做的操作,以及内容访问的范围,或者说,权限是指某个特定的用户具有特定的系统资 ...