ElasticSearch组件与Kibana组件部署-集群

2022-08-18  本文已影响0人  CoderInsight

0,参考连接

1,【ElasticSearch】本地安装部署及集群搭建

2,ElasticSearch 安装 (单机单节点/伪集群)

3,开课吧

1,ES的单机部署与伪分布式部署

(1),解压

将ES安装包解压到/usr/local目录下

sudo tar -zxvf elasticsearch-6.7.0.tar.gz -C /usr/local

(2),创建的新的用户

注意:ES不能使用root用户来启动,必须使用普通用户来安装启动。

# 1,首先创建用户命令
adduser elasticsearch
# 2,修改用户密码为:elasticsearch
passwd elasticsearch
# 3,将ES所解压的目录授予此对应的用户
cd /usr/local
chown -R elasticsearch elasticsearch-6.7.0
chgrp -R elasticsearch elasticsearch-6.7.0

# 查看当前路径下的文件信息,看是否都是elasticsearch账户的
ll

(3),修改配置文件(elasticsearch.yml)

# 更改完当前主机的信息,供于我们在wbe界面中使用ip进行访问,其中Web界面的端口是 9200 
# 设置当前机器的主机名以及对应的ip,那么此时就可以使用主机名去进行访问了
node.name: master
network.host: 192.168.73.143
#### 假设是"一主二从" 的架构,他们之间通过不同的端口号进行区分
### master 的端口是 9200,slave 端口分别是 9201 和 9202

### 这里使用不同的文件名进行区分,那么此时就需要使用对解压之后的文件名进行重命名
## 首先修改 master 的 config/elasticsearch.yml 配置文件:
vi /usr/local/es_cluster/master/config/elasticsearch.yml:
# 设置es的名称
cluster.name: myes
node.name: master
node.master: true
network.host: 127.0.0.1

## 然后将 es 的压缩包解压两份,放到不同的目录中;分别命名为 slave01 和 slave02,代表两个从机。

## 配置slave01
vi /usr/local/es_cluster/slave01/config/elasticsearch.yml:

# 集群名称必须保持一致
cluster.name: myes
node.name: slave01
network.host: 127.0.0.1
http.port: 9201
discovery.zen.ping.unicast.hosts: ["127.0.0.1"]


## 配置slave02
vi /usr/local/es_cluster/slave02/config/elasticsearch.yml:

# 集群名称必须保持一致
cluster.name: myes
node.name: slave02
network.host: 127.0.0.1
http.port: 9202
discovery.zen.ping.unicast.hosts: ["127.0.0.1"]

(4),服务的启动

### 方式1:使用觉得路径的方式(单机部署演示)
/usr/local/elasticsearch-6.7.0/bin/elasticsearch -d

### 方式2:使用相对路径的方式(伪分布式部署方式演示)
cd /usr/local/es_cluster/master
bin/elasticsearch -d

(5),启动可能会出现的报错

由于现在使用普通用户来安装es服务,且es服务对服务器的资源要求比较多,包括内存大小,线程数等。所以我们需要给普通用户解开资源的束缚

解决启动问题一:普通用户打开文件的最大数限制

## 问题错误信息描述:
[2020-11-24T17:44:31,302][ERROR][o.e.b.Bootstrap          ] [mG4Kp9o] node validation exception
[2] bootstrap checks failed
[1]: max file descriptors [4096] for elasticsearch process is too low, increase to at least [65536]
[2]: max virtual memory areas vm.max_map_count [65530] is too low, increase to at least [262144]

ES因为需要大量的创建索引文件,需要大量的打开系统的文件,所以我们需要解除linux系统当中打开文件最大数目的限制,不然ES启动就会抛错

当我们配置三台机器组成的集群的时候,也是要解决这两问题的,所以都需要执行以下命令解除打开文件数据的限制

sudo vi /etc/security/limits.conf
# 追加以下内容(说明:这里简单粗暴的直接使用的*,当然也可以只指定给当前用户生效,可以根据实际情况进行调整)
* soft nofile 65536
* hard nofile 131072
* soft nproc 2048
* hard nproc 4096

解决启动问题二:普通用户启动线程数限制

## 三台机器执行以下命令打开文件最大数
# 编辑文件
sudo vi /etc/sysctl.conf

# 添加以下内容
vm.max_map_count=655360
fs.file-max=655360

# 执行以下命令生效
sudo sysctl -p

注意:以上两个问题修改完成之后,一定要重新连接linux生效。关闭secureCRT或者XShell工具,然后重新打开工具连接linux即可

## 重新连接之后执行以下命令,出现这个结果即可准备启动ES了
[hadoop@node01 ~]$ ulimit -Hn
131072

[hadoop@node01 ~]$ ulimit -Sn
65536

[hadoop@node01 ~]$ ulimit -Hu
4096

[hadoop@node01 ~]$ ulimit -Su
4096

(6),测试部署

这个时候我们访问下接口:
curl -XGET 主机名或者是ip:9200
或者浏览器打开 主机名或者是ip:9200,就会看到下面的输出:

[hadoop@node01 elasticsearch-6.7.0]$ curl -XGET node01:9200
{
  "name" : "node01",
  "cluster_name" : "myes",
  "cluster_uuid" : "6we5OHUFSn6WsUH7h4ip1g",
  "version" : {
    "number" : "6.7.0",
    "build_flavor" : "default",
    "build_type" : "tar",
    "build_hash" : "8453f77",
    "build_date" : "2019-03-21T15:32:29.844721Z",
    "build_snapshot" : false,
    "lucene_version" : "7.7.0",
    "minimum_wire_compatibility_version" : "5.6.0",
    "minimum_index_compatibility_version" : "5.0.0"
  },
  "tagline" : "You Know, for Search"
}

2,ES的集群部署

区别仅仅是在配置文件中,另外只需要在一个节点中配置好,然后同步到其他节点中,再简单改一下即可。

第一步:解压、创建新用户

此时可以参考之前单节点的部署,根据实际情况继续信用的添加

注意:在当前环境中每台机器中都存在 hadoop 用户,所以当前直接使用这个用户进行安装。

第二步:处理每个机器中可能出现的报错

此时可以参照之前的单节点的部署中的排错

第三步:修改配置文件

修改elasticsearch.yml

### 使用root用户创建,然后再去修改对应的用户
## 进入 elasticsearch 的解压目录的配置文件目录
cd /usr/local/elasticsearch-6.7.0/config/
## 创建文件夹
mkdir -p /usr/local/elasticsearch-6.7.0/logs/
mkdir -p /usr/local/elasticsearch-6.7.0/datas/

## 此时可以直接对 elasticSearch 整个目录的权限和用户进行设置
chown -R hadoop:hadoop /usr/local/elasticsearch-6.7.0/
## 验证更改结果
ll 
## 如果没有改过来,可以再根据实际情况对指定的文件夹进进行修改
chown -R hadoop:hadoop /usr/local/elasticsearch-6.7.0/logs/
chown -R hadoop:hadoop /usr/local/elasticsearch-6.7.0/datas/

## 修改配置文件(当然也可以先不修改直接分发的其他节点中,然后直接从文档中拷贝过去,主要的修改工作是在当前文档中进行修改)
vim elasticsearch.yml
## 添加以下内容
cluster.name: myes
node.name: node01
path.data: /usr/local/elasticsearch-6.7.0/datas
path.logs: /usr/local/elasticsearch-6.7.0/logs
network.host: 192.168.73.147
http.port: 9200
transport.tcp.port: 9300
discovery.zen.ping.unicast.hosts: ["node01", "node02", "node03"]
bootstrap.system_call_filter: false
bootstrap.memory_lock: false
http.cors.enabled: true
http.cors.allow-origin: "*"

修改jvm.option

## 修改jvm.option配置文件,调整jvm堆内存大小
# node01使用 elasticsearch 用户执行以下命令调整jvm堆内存大小,每个人根据自己服务器的内存大小来进行调整

## 进入配置文件所在的目录
cd /usr/local/elasticsearch-6.7.0/config
# 修改文件
vim jvm.options
# 追加以下内容
-Xms2g
-Xmx2g

第四步:将安装包分发到其他服务器上面

### node01使用es用户将安装包分发到其他服务器上面去
## 进入安装父目录
cd /usr/local/
## 拷贝到其他两个节点
scp -r elasticsearch-6.7.0/ node02:$PWD
scp -r elasticsearch-6.7.0/ node03:$PWD

## 当拷贝到其他两个节点中了之后,需要统一修改elasticsearch-6.7.0文件的所有者
chown -R hadoop:hadoop /usr/local/elasticsearch-6.7.0/

第五步:node02与node03修改es配置文件

node02与node03也需要修改es配置文件

node02使用hadoop用户执行以下命令修改es配置文件

### node02使用hadoop
## 进入配置文件目录
cd /usr/local/elasticsearch-6.7.0/config/

## 修改配置文件
vim elasticsearch.yml

## 添加以下配置(实际上就是修改部分内容)
cluster.name: myes
node.name: node02
path.data: /usr/local/elasticsearch-6.7.0/datas
path.logs: /usr/local/elasticsearch-6.7.0/logs
network.host: 192.168.73.149
http.port: 9200
transport.tcp.port: 9300
discovery.zen.ping.unicast.hosts: ["node01", "node02", "node03"]
bootstrap.system_call_filter: false
bootstrap.memory_lock: false
http.cors.enabled: true
http.cors.allow-origin: "*"
## node03使用hadoop
## 进入配置文件目录
cd /usr/local/elasticsearch-6.7.0/config/

## 修改配置文件
vim elasticsearch.yml

## 添加以下配置(实际上就是修改部分内容)
cluster.name: myes
node.name: node03
path.data: /usr/local/elasticsearch-6.7.0/datas
path.logs: /usr/local/elasticsearch-6.7.0/logs
network.host: 192.168.73.150
http.port: 9200
discovery.zen.ping.unicast.hosts: ["node01", "node02", "node03"]
bootstrap.system_call_filter: false
bootstrap.memory_lock: false
http.cors.enabled: true
http.cors.allow-origin: "*"

第六步:服务启动、测试部署

### 服务启动
/usr/local/elasticsearch-6.7.0/bin/elasticsearch -d

# 直接使用浏览器访问
http://192.168.73.160:9200/_cat/nodes?pretty
# 这里只是做了演示,但是实际就是会有信息输出
192.168.73.160 6 94  5 0.40 0.25 0.17 mdi * node02
192.168.73.159 6 91 11 0.43 0.20 0.16 mdi - node01
192.168.73.161 6 94  5 0.40 0.25 0.17 mdi * node03


### 这个时候我们访问下接口来测试部署:
curl -XGET node01:9200
或者浏览器打开 node01:9200,就会看到下面的输出:
[hadoop@node01 elasticsearch-6.7.0]$ curl -XGET node01:9200
{
  "name" : "node01",
  "cluster_name" : "myes",
  "cluster_uuid" : "6we5OHUFSn6WsUH7h4ip1g",
  "version" : {
    "number" : "6.7.0",
    "build_flavor" : "default",
    "build_type" : "tar",
    "build_hash" : "8453f77",
    "build_date" : "2019-03-21T15:32:29.844721Z",
    "build_snapshot" : false,
    "lucene_version" : "7.7.0",
    "minimum_wire_compatibility_version" : "5.6.0",
    "minimum_index_compatibility_version" : "5.0.0"
  },
  "tagline" : "You Know, for Search"
}

## 启动报错问题1:
[hadoop@node03 elasticsearch-6.7.0]$ bin/elasticsearch -d
[hadoop@node03 elasticsearch-6.7.0]$ Java HotSpot(TM) 64-Bit Server VM warning: Cannot open file logs/gc.log due to Permission denied

Exception in thread "main" org.elasticsearch.bootstrap.BootstrapException: java.nio.file.AccessDeniedException: /usr/local/elasticsearch-6.7.0/config/elasticsearch.keystore
Likely root cause: java.nio.file.AccessDeniedException: /usr/local/elasticsearch-6.7.0/config/elasticsearch.keystore
    at sun.nio.fs.UnixException.translateToIOException(UnixException.java:84)
    at sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:102)
    at sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:107)
    at sun.nio.fs.UnixFileSystemProvider.newByteChannel(UnixFileSystemProvider.java:214)
    at java.nio.file.Files.newByteChannel(Files.java:361)
    at java.nio.file.Files.newByteChannel(Files.java:407)
    at org.apache.lucene.store.SimpleFSDirectory.openInput(SimpleFSDirectory.java:77)
    at org.elasticsearch.common.settings.KeyStoreWrapper.load(KeyStoreWrapper.java:215)
    at org.elasticsearch.bootstrap.Bootstrap.loadSecureSettings(Bootstrap.java:230)
    at org.elasticsearch.bootstrap.Bootstrap.init(Bootstrap.java:295)
    at org.elasticsearch.bootstrap.Elasticsearch.init(Elasticsearch.java:159)
    at org.elasticsearch.bootstrap.Elasticsearch.execute(Elasticsearch.java:150)
    at org.elasticsearch.cli.EnvironmentAwareCommand.execute(EnvironmentAwareCommand.java:86)
    at org.elasticsearch.cli.Command.mainWithoutErrorHandling(Command.java:124)
    at org.elasticsearch.cli.Command.main(Command.java:90)
    at org.elasticsearch.bootstrap.Elasticsearch.main(Elasticsearch.java:116)
    at org.elasticsearch.bootstrap.Elasticsearch.main(Elasticsearch.java:93)
Refer to the log for complete error details.

###  解决方案:
## 即重新设置当前文件夹的所属用户和所属组
[hadoop@node02 ~]$ sudo chown -R hadoop:hadoop /usr/local/elasticsearch-6.7.0/
[sudo] password for hadoop: 

vi startES.sh
# 追加以下内容
#!/bin/bash
for num in {1..3}
do
    if [ $num -lt 4 ]; then
      echo "node0${num} ES Cluster starting:"    
      ssh node0${num} "source /etc/profile;/usr/local/elasticsearch-6.7.0/bin/elasticsearch -d"
      echo "==================="
    fi
done

## node01节点脚本
vi stopESCluster.sh
# 追加以下内容
#!/bin/sh
for host in node02 node03
do
    ElasticsearchPIDS=$(ps ax | grep -i 'Elasticsearch' | grep -v grep | awk '{print $1}')
    for pid in $ElasticsearchPIDS
    do
      if [ -z "$pid" ]; then
        echo "No redis server to stop"
      else
        kill -s TERM $pid
      fi
    done

    ssh $host "sh ./bin/stopESCluster.sh"
done



## 其他节点下也存放一份脚本,但是内容中没有ssh的语句
## 存放脚本的路径: /home/hadoop/bin
vi stopESCluster.sh
# 追加以下内容
#!/bin/sh
for host in node02 node03
do
    ElasticsearchPIDS=$(ps ax | grep -i 'Elasticsearch' | grep -v grep | awk '{print $1}')
    for pid in $ElasticsearchPIDS
    do
      if [ -z "$pid" ]; then
        echo "No redis server to stop"
      else
        kill -s TERM $pid
      fi
    done

done

补充:配置文件作用说明

#集群名称
cluster.name: myes

#节点名称,集群中保持唯一
node.name: node01

#绑定远程地址,为了安全通常是指定具体的地址,这里仅仅是测试,放开允许所有远程来源访问
network.host: 0.0.0.0

#开放http接口,默认就是9200
http.port: 9200

#集群节点之间(集群协商、指令传输等)通信的端口
transport.tcp.port: 9300

#允许前端跨域访问
http.cors.enabled: true

#设置允许的跨域的来源,*表示允许所有跨域来源
http.cors.allow-origin: "*"

#设置发现集群节点主机列表
discovery.seed_hosts: ["192.168.15.151:9300","192.168.15.155:9300","192.168.15.156:9300"]

#初始化集群的master节点的候选列表,列表中的节点都可能竞选成为master节点
cluster.initial_master_nodes: ["192.168.15.151:9300","192.168.15.155:9300","192.168.15.156:9300"]
#配置 ES 的集群名称,默认值是 ES,建议改成与所存数据相关的名称,ES 会自动发现在同一网段下的集群名称相同的节点。
cluster.name:elasticsearch

#集群中的节点名,在同一个集群中不能重复。节点的名称一旦设置,就不能再改变了。当然,也可以设置成服务器的主机名称,例如 node.name:${HOSTNAME}。
node.name: "node1"

#指定该节点是否有资格被选举成为 Master 节点,默认是 True,如果被设置为 True,则只是有资格成为 Master 节点,具体能否成为 Master 节点,需要通过选举产生。
noed.master:true

#指定该节点是否存储索引数据,默认为 True。数据的增、删、改、查都是在 Data 节点完成的。
node.data:true

#设置都索引分片个数,默认是 5 片。也可以在创建索引时设置该值,具体设置为多大都值要根据数据量的大小来定。如果数据量不大,则设置成 1 时效率最高。
index.number_of_shards:5

#设置默认的索引副本个数,默认为 1 个。副本数越多,集群的可用性越好,但是写索引时需要同步的数据越多。
index.number_of_replicas:1

#设置配置文件的存储路径,默认是 ES 目录下的 Conf 文件夹。建议使用默认值。
path.conf:/path/to/conf

#设置索引数据多存储路径,默认是 ES 根目录下的 Data 文件夹。切记不要使用默认值,因为若 ES 进行了升级,则有可能数据全部丢失。 可以用半角逗号隔开设置的多个存储路径,在多硬盘的服务器上设置多个存储路径是很有必要的。
path.data:/path/to/data1,/path/to/data2

#设置日志文件的存储路径,默认是 ES 根目录下的 Logs,建议修改到其他地方。
path.logs:/path/to/logs

#设置第三方插件的存放路径,默认是 ES 根目录下的 Plugins 文件夹。
path.plugins:/path/to/plugins

#设置为 True 时可锁住内存。因为当 JVM 开始 Swap 时,ES 的效率会降低,所以要保证它不 Swap。
bootstrap.mlockall:true

#设置本节点绑定的 IP 地址,IP 地址类型是 IPv4 或 IPv6,默认为 0.0.0.0。
network.bind_host:192.168.0.1

#设置其他节点和该节点交互的 IP 地址,如果不设置,则会进行自我判断。
network.publish_host:192.168.0.1

#用于同时设置 bind_host 和 publish_host 这两个参数。
network.host:192.168.0.1

#设置对外服务的 HTTP 端口,默认为 9200。ES 的节点需要配置两个端口号,一个对外提供服务的端口号,一个是集群内部使用的端口号。 http.port 设置的是对外提供服务的端口号。注意,如果在一个服务器上配置多个节点,则切记对端口号进行区分。
http.port:9200

#设置集群内部的节点间交互的 TCP 端口,默认是 9300。注意,如果在一个服务器配置多个节点,则切记对端口号进行区分。
transport.tcp.port:9300

#设置在节点间传输数据时是否压缩,默认为 False,不压缩。
transport.tcp.compress:true

#设置在选举 Master 节点时需要参与的最少的候选主节点数,默认为 1。如果使用默认值,则当网络不稳定时有可能会出现脑裂。 合理的数值为(master_eligible_nodes/2)+1,其中 master_eligible_nodes 表示集群中的候选主节点数。
discovery.zen.minimum_master_nodes:1

#设置在集群中自动发现其他节点时 Ping 连接的超时时间,默认为 3 秒。 在较差的网络环境下需要设置得大一点,防止因误判该节点的存活状态而导致分片的转移。
discovery.zen.ping.timeout:3s

3,安装elasticsearch-head插件

由于es服务启动之后,访问界面比较丑陋,为了更好的查看索引库当中的信息,我们可以通过安装elasticsearch-head这个插件来实现,这个插件可以更方便快捷的看到es的管理界面

(1),安装 node.js

第一步:下载安装包

node01机器执行以下命令下载安装包,然后进行解压
cd 
## 方式1:在线下载的方式
wget https://npm.taobao.org/mirrors/node/v8.1.0/node-v8.1.0-linux-x64.tar.gz
## 方式2:使用离线安装包的方式
tar -zxf node-v8.1.0-linux-x64.tar.gz -C /usr/local/

第二步:创建软连接

## node01执行以下命令创建软连接
## 也可以直接切换到root用户进行操作
sudo ln -s /kkb/install/node-v8.1.0-linux-x64/lib/node_modules/npm/bin/npm-cli.js /usr/local/bin/npm

sudo ln -s /kkb/install/node-v8.1.0-linux-x64/bin/node /usr/local/bin/node

第三步:修改环境变量

## node01服务器添加环境变量
## 编辑文件
sudo vim /etc/profile
# 追加以下内容
export NODE_HOME=/usr/local/node-v8.1.0-linux-x64
export PATH=:$PATH:$NODE_HOME/bin

## 修改完环境变量使用source生效
source /etc/profile

第四步:验证安装成功

## node01执行以下命令验证安装生效

node -v
npm -v

(2),安装elasticsearch-head插件

第一步:上传压缩包到/soft路径下去

## 将我们的压缩包 elasticsearch-head-compile-after.tar.gz 上传到node01机器的/soft路径下面去

第二步:解压安装包

## node01执行以下命令解压安装包

cd /soft/
tar -zxvf elasticsearch-head-compile-after.tar.gz -C /usr/local

第三步、node01机器修改Gruntfile.js

## 修改Gruntfile.js这个文件

cd /usr/local/elasticsearch-head

vim Gruntfile.js

## 找到以下代码:
hostname: '192.168.52.100',
## 将其修改为当前的主机的ip地址
connect: {
             server: {
                options: {
                   hostname: '192.168.73.147',
                   port: 9100,
                   base: '.',
                   keepalive: true
                 }
             }
         }

第四步、node01机器修改app.js

第一台机器修改app.js

cd /usr/local/elasticsearch-head/_site

vim app.js 
                      
## 注意:如果直接使用我提供的文件,可以直接搜nodeo1,然后将其更改为对应情况下的主机名
更改前:http://localhost:9200
更改后:http://node01:9200

第五步:node01机器启动head服务

## node01启动elasticsearch-head插件
cd /usr/local/elasticsearch-head/node_modules/grunt/bin/

## 进程后台启动命令
# 注意此时是将日志文件直接丢到黑洞文件中,不会保存日志,如果需要查看你
nohup ./grunt server >/dev/null 2>&1 &

## 如何停止:elasticsearch-head进程
执行以下命令找到elasticsearch-head的插件进程,然后使用kill -9 杀死进程即可
# 查看网络信息的组件
sudo yum install net-tools   
# 查看对应端口占用的用户进程 PID
netstat -nltp | grep 9100
# 杀死进程
kill -9 8328

第六步:访问elasticsearch-head界面

## 打开Google Chrome访问 
http://192.168.73.147:9100/

4、node01服务器安装Kibana

kibana的基本介绍

Kibana是一个开源的分析和可视化平台,设计用于和Elasticsearch一起工作。

你用Kibana来搜索,查看,并和存储在Elasticsearch索引中的数据进行交互。

你可以轻松地执行高级数据分析,并且以各种图标、表格和地图的形式可视化数据。

Kibana使得理解大量数据变得很容易。它简单的、基于浏览器的界面使你能够快速创建和共享动态仪表板,实时显示Elasticsearch查询的变化。

接着使用我们的hadoop用户在node01服务器上面来实现我们的kibana的安装部署

第一步:下载资源上传服务器并解压

## node01服务器使用root用户执行以下命令来下载安装包并解压
cd /soft
## 部署方式1:在线下载,然后去解压即可
wget https://artifacts.elastic.co/downloads/kibana/kibana-6.7.0-linux-x86_64.tar.gz

## 部署方式2:直接使用已经下载好的进行部署
tar -zxf kibana-6.7.0-linux-x86_64.tar.gz -C /usr/local

## 解压完毕之后修改文件的所属用户
chown -R hadoop:hadoop /usr/local/kibana-6.7.0-linux-x86_64

第二步:修改配置文件

## node01服务器使用es用户执行以下命令来修改配置文件
# 进入目录,进行修改
cd /usr/local/kibana-6.7.0-linux-x86_64/config/
vi kibana.yml

## 配置内容如下:
server.host: "node01"
elasticsearch.hosts: ["http://node01:9200"]

第三步:启动服务

## node01服务器使用es用户执行以下命令启动kibana服务
cd /usr/local/kibana-6.7.0-linux-x86_64
nohup bin/kibana >/dev/null 2>&1 &

## 如何停止kibana进程:停止kibana服务进程
# 查看进程号
# 方式1:查看进程的方式
ps -ef | grep node
# 方式2:查看端口占用的方式
netstat -nltp | grep 5601

# 然后使用kill -9杀死进程即可

第四步:浏览器访问

## 浏览器地址访问kibana服务
http://node01:5601
上一篇 下一篇

猜你喜欢

热点阅读