elasticsearch简单的安装以及集群配置详解
首先要确保有java8的环境,安装方法如下(centos)
wget --no-check-certificate --no-cookies --header "Cookie: oraclelicense=accept-securebackup-cookie" http://download.oracle.com/otn-pub/java/jdk/8u161-b12/2f38c3b165be4555a1fa6e98c45e0808/jdk-8u161-linux-x64.rpm
rpm -ivh jdk-8u161-linux-x64.rpm
https://www.baidu.com/link?url=cn60GecIBvDt9OvD_nQK9CR0TwbwxLM2DtpYNIptUGtNMG89ELhbPCNFg0xDlT205HcG88QVruw1Zgte5Nim620OPshtt3hKq1zACpJQ3WTCSwtKUO2sdnVzpUjrbuQ2&wd=&eqid=e3cf42960002cb16000000055bee8e9f 这个地址就是官网的jdk下载地址,
环境安装完毕,下载elesticsearch,这里如果需要其他版本直接改末尾的版本号就可以下载其他版本的
wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-5.5.2.zip
解压elasticsearch-5.5.2.zip
unzip elasticsearch-5.5..zip 2 mv elasticsearch-5.5.2 elasticsearch
如果没有unzip这个命令的话可以先运行
yum install unzip
elasticsearch不能直接用root账户运行,所以需要创建一个用户,而且需要将elasticsearch文件夹属主修改为新创建的这个用户,不然的话启动的时候会有一些权限引起的错误
因为这时候并不知道root的密码,所以先给root创建一个密码
passwd root
然后输入密码
接着创建用户并修改文件夹属主和属组
groupadd elasticsearch
useradd elasticsearch -g elasticsearch
passwd elasticsearch chown -R elasticsearch:elasticsearch elasticsearch
打开位于elasticsearch文件夹中/conifg目录下的 elasticsearch.yml配置文件修改配置
cluster.name: elas_cluster 集群的名字
node.name: node-q1 节点的名称
node.master: true
node.data: true
配置文件中给出了三种配置高性能集群拓扑结构的模式,如下:
1. 如果你想让节点从不选举为主节点,只用来存储数据,可作为负载器
node.master: false
node.data: true
2. 如果想让节点成为主节点,且不存储任何数据,并保有空闲资源,可作为协调器
node.master: true
node.data: false
3. 如果想让节点既不称为主节点,又不成为数据节点,那么可将他作为搜索器,从节点中获取数据,生成搜索结果等
node.master: false
node.data: false
默认情况是两个都是true,如果没几台服务器的话就用默认的就可以了。
network.host: 192.168.0.1 绑定的ip,设置为0.0.0.0后可以用外网访问
network.publish_host: 192.168.0.1 指定elasticsearch节点对外的监听地址,就是外网地址,搭建集群的时候最好指定一下,否则可能集群没办法启动,默认应该是去监听内网地址的
node.attr.rack: r2 给节点添加额外属性,这个暂时没发现什么用处
path.data: /path/to/data 数据保存的目录
path.logs: /path/to/logs 日志保存的目录
bootstrap.memory_lock: true 禁止内存交换,最好设置为false,不然非常影响性能,如果因为这个启动的时候报错,可以去修改limits.conf,配置下面有说
http.port:9200 路由地址端口
transport.tcp.port:9300 TCP协议转发地址端口,像java使用这个端口去操作
注:ES默认的HTTP监听端口是9200,如果当前被占用,则在9200~9300范围内递增;另外TCP的默认监听端口是9300,如果当前被占用,则再9300~9400范围内递增。所以单机少量节点,不配置具体端口的话,也是可以运行的。
discovery.zen.ping.unicast.hosts: ["192.168.36.130", "192.168.36.132:9300"] 单播的地址,配置集群中其他节点的ip,新加入的节点通过这些ip同步到集群,这里的端口应该使用transport.tcp.port端口
discovery.zen.minimum_master_nodes: 2 master节点是选取出来的,一个集群只能有一个,以上node.master: true配置是说该节点具有被选举的权利,而现在这个配置就是告诉 Elasticsearch 当没有足够 master 候选节点的时候,就不要进行 master 节点选举,等 master 候选节点足够了才进行选举。(因为你是一台台去启动服务器的) 这样是为了防止集群中同时存在两个master,这个数值应该配置为 ( master 候选节点个数 / 2) + 1。所以要高可用的话至少三台以上有被选举权。
gateway.recover_after_nodes: 2 通俗来说就是等集群有几个节点启动起来了再来选举master,分配分片数据什么的,这里配得不好可能有的问题就是启动的时候可能会多耗点性能
index.number_of_shards: 5 设置索引的分片数,默认为5 分片的意思就是一整个索引文档,分成5个部分去保存
index.number_of_replicas: 1 设置索引的副本数,默认为1 1个副本相当于一个备份
配置一下
敲命令
sysctl -w vm.max_map_count=655360
这时候可能会因为服务器内存原因遇到一个错误 Cannot allocate memory
在elasticsearch目录下执行 vim config/jvm.options
修改内存
-Xms256m
-Xmx256m
(根据自己服务器内存设置)
一切就绪后启动
切换到elasticsearch用户,否则root用户下启动会抛异常
su elasticsearch
elasticsearch目录下bin中运行 ./elasticsearch
启动的时候发现报错,而且可能一次又一次,一次好几个错,错误这里就不说了,主要都是因为账户权限,内存线程什么引起的,网上的解决方法很多,随便贴几个链接
https://blog.csdn.net/gongpulin/article/details/78568595
https://blog.csdn.net/u013083576/article/details/78499884
单个成功访问ip地址加端口后,端口是http.port端口

集群健康查看 ip加端口加上/_cluster/health

如果需要安装ik分词器的,可以在 https://github.com/medcl/elasticsearch-analysis-ik/releases 找到对应的版本 elasticsearch-analysis-ik-x.x.x.zip 下载解压,最后将解压后的文件拷贝到 elasticsearch文件夹的 /plugin/ 文件夹中,启动es就ok了
elasticsearch简单的安装以及集群配置详解的更多相关文章
- Apache + Tomcat集群配置详解 (1)
一.软件准备 Apache 2.2 : http://httpd.apache.org/download.cgi,下载msi安装程序,选择no ssl版本 Tomcat 6.0 : http://to ...
- 使用apache和nginx代理实现tomcat负载均衡及集群配置详解
实验环境: 1.nginx的代理功能 nginx proxy: eth0: 192.168.8.48 vmnet2 eth1: 192.168.10.10 tomcat server1: vmnet2 ...
- ElasticSearch入门 第二篇:集群配置
这是ElasticSearch 2.4 版本系列的第二篇: ElasticSearch入门 第一篇:Windows下安装ElasticSearch ElasticSearch入门 第二篇:集群配置 E ...
- rocketMq安装及集群配置
网上关于rocketMq安装.集群配置的文章有很多,作为一个初学者,跟着网上的各种教程安装遇到了各种坑,可谓是一路坎坷.本文记录下rocketMq安装的完整过程.希望对你有一点帮助 安装rocketM ...
- [转帖]Application Request Route实现IIS Server Farms集群负载详解
Application Request Route实现IIS Server Farms集群负载详解 https://www.cnblogs.com/knowledgesea/p/5099893.ht ...
- MySQL集群搭建详解
概述 MySQL Cluster 是MySQL 适合于分布式计算环境的高实用.可拓展.高性能.高冗余版本,其研发设计的初衷就是要满足许多行业里的最严酷应用要求,这些应用中经常要求数据库运行的可靠性要达 ...
- Solr系列二:solr-部署详解(solr两种部署模式介绍、独立服务器模式详解、SolrCloud分布式集群模式详解)
一.solr两种部署模式介绍 Standalone Server 独立服务器模式:适用于数据规模不大的场景 SolrCloud 分布式集群模式:适用于数据规模大,高可靠.高可用.高并发的场景 二.独 ...
- Elasticsearch 安装与集群配置
一.软件版本 操作系统:CentOS-6.5-x86_64 ES版本:5.0 主机:192.168.63.246 主机: 192.168.63.242 二.部署环境规划: 1. 需求:jdk版本: ...
- rabibtMQ安装及集群配置-linux
安装RabbitMQ RabbitMQ是流行的开源消息队列系统,用erlang语言开发,故首先需要安装erlang依赖及erlang. 安装erlang依赖的基本环境,通过yum方式进行安装: yum ...
随机推荐
- Python学习---PyCharm的使用学习
1.1. IDEA的使用 PyCharm2017下载 链接:https://pan.baidu.com/s/1HPR9FtVV5BCvd3uTdOetxw 密码:ok0q 激活IDEA2017(方案一 ...
- 深圳云栖大会人工智能专场:探索视频+AI,玩转智能视频应用
摘要: 在人工智能时代,AI技术是如何在各行业和领域真正的发挥应用和商业价值,带来产业变革才是关键.在3月28日深圳云栖大会的人工智能专场中,阿里云视频服务技术专家邹娟将带领大家探索熟悉的视频场景中, ...
- LVS跨网段DR模式并使用ldirectord实现RS高可用性
DR模型的工作过程: Client向VIP发起请求,请求被路由器接收到,转发给不同网段的Director的VIP,Director再通过私有网络转给RS服务器,RS服务器处理请求并通过自身配置的VIP ...
- Centos 7 iptables配置
systemctl status firewalld.service #检测是否开启了firewall systemctl stop firewalld.service #关闭firewall syt ...
- 关于Class类的getResource().getPath()方法
程序中配置文件如果放置在classes文件夹,那么我们就可以使用Class类的getResource().getPath()方法获取文件路径. 例如: String path = DBUtil.cla ...
- python接口测试:自动保存cookies
接口测试中遇到上一个请求返回响应包含cookie(如下图登录请求的响应结果).需将cookies保存下来,后续请求自动带入,否则会提示未登录. python requests的cookie类型是< ...
- 粒子群优化算法PSO及matlab实现
算法学习自:MATLAB与机器学习教学视频 1.粒子群优化算法概述 粒子群优化(PSO, particle swarm optimization)算法是计算智能领域,除了蚁群算法,鱼群算法之外的一种群 ...
- 【[HNOI2012]矿场搭建】
抄题解真开心 我真是越来越菜了 这是点双的板子题,于是求出所有点双,之后讨论 如果点双里之有一个割点,那么如果这个割点炸了,这个点双就出不去了,于是我们得在这个点双内部除了这个割点位置放一个 如果有两 ...
- POJ3690 Constellations
嘟嘟嘟 哈希 刚开始我一直在想二维哈希,但发现如果还是按行列枚举的话会破坏子矩阵的性质.也就是说,这个哈希只能维护一维的子区间的哈希值. 所以我就开了个二维数组\(has_{i, j}\)表示原矩阵\ ...
- 基于 Docker 搭建 MySQL 主从复制
本篇博文相对简单,因为是初次使用Docker,MySQL的主从复制之前也在Centos环境下搭建过,但是也忘的也差不多了,因此本次尝试在Docker中搭建. 根据网上教程走还是踩了一些坑,不过所幸最终 ...