zoukankan      html  css  js  c++  java
  • Elasticsearch环境准备(一)

    一、ELKStack简介

    中文指南:https://www.gitbook.com/book/chenryn/elk-stack-guide-cn/details

    ELK Stack包含:ElasticSearch、Logstash、Kibana

    ElasticSearch是一个搜索引擎,用来搜索、分析、存储日志。它是分布式的,也就是说可以横向扩容,可以自动发现,索引自动分片,总之很强大。

    文档介绍: https://www.elastic.co/guide/cn/elasticsearch/guide/current/index.html

    Logstash用来采集日志,把日志解析为json格式交给ElasticSearch。

    kibana 也是一个开源和免费的工具,Kibana可以为 Logstash 和 ElasticSearch 提供的日志分析友好的 Web 界面,可以帮助您汇总、分析和搜索重要数据日志。

    Beats在这里是一个轻量级日志采集器,其实Beats家族有5个成员

    早期的ELK架构中使用Logstash收集、解析日志,但是Logstash对内存、cpu、io等资源消耗比较高。相比 Logstash,Beats所占系统的CPU和内存几乎可以忽略不计

    x-pack对Elastic Stack提供了安全、警报、监控、报表、图表于一身的扩展包,是收费的。

    2、ELK架构:

     

    二、Elasticsearch部署

    2.1、安装JDK

    2.1.1 yum安装JDK
    [root@linux-node1 ~]# yum install -y java
    [root@linux-node1 ~]# java -version
    openjdk version "1.8.0_151"
    OpenJDK Runtime Environment (build 1.8.0_151-b12)
    OpenJDK 64-Bit Server VM (build 25.151-b12, mixed mode)
    
    2.1.2 源码安装JDK
    下载
    [root@linux-node1 ~]# wget http://download.oracle.com/otn-pub/java/jdk/8u151-b12/e758a0de34e24606bca991d704f6dcbf/jdk-8u151-linux-x64.tar.gz
    配置Java环境
    [root@linux-node1 ~]# tar zxf jdk-8u151-linux-x64.tar.gz -C /usr/local/
    [root@linux-node1 ~]#  ln –s /usr/local/jdk1.8.0_91 /usr/local/jdk
    
    [root@linux-node1 ~]# vim /etc/profile
    export JAVA_HOME=/usr/local/jdk
    export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
    export PATH=$PATH:$JAVA_HOME/bin
    [root@linux-node1 ~]# source /etc/profile
    [root@linux-node1 ~]# java -version
    
    注:linux-node2节点上也安装JDK
    

    2.2、安装Elasticsearch

    (安装版本为为elasticsearch6.X)

    (1)源码安装elasticsearch:

    (1)源码安装elasticsearch:
    安装elasticsearch
    [root@linux-node1 ~]# wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-6.0.0.rpm
    [root@linux-node1 ~]# yum install -y elasticsearch-6.0.0.rpm 
    配置elasticsearch,linux-node2配置一个相同的节点,通过组播进行通信,会通过cluster进行查找,如果无法通过组播查询,修改成单播即可。
    [root@linux-node1 ~]# vim /etc/elasticsearch/elasticsearch.yml
    cluster.name:elk-cluster  #集群名称
    node.name:elk-node1        #节点名称,一个集群之内节点的名称不能重复
    path.data:/data/elkdata      #数据路径
    path.logs:/data/logs              #日志路径
    #bootstrap.memory_lock:true      #锁住es内存,保证内存不分配至交换分区,这里暂时不配置。注释掉
    network.host:192.168.56.11       #网络监听地址
    http.port:9200                    #用户访问查看的端口,9300是组件访问使用
    discovery.zen,ping.unicast.hosts:["10.0.0.22","10.0.0.23"] #单播(配置一台即可,生产可以使用组播方式)
    [root@linux-node1 ~]# mkdir /data/{elkdata,logs}
    [root@linux-node1 ~]# chown elasticsearch.elasticsearch /data -R
    [root@linux-node1 ~]# systemctl start elasticsearch.service
    [root@linux-node1 ~]# netstat -tulnp |grep java
    tcp6       0      0 192.168.56.11:9200      :::*                    LISTEN      26866/java          
    tcp6       0      0 192.168.56.11:9300      :::*                    LISTEN      26866/java          
    
    将配置文件拷贝到linux-node2
    [root@linux-node1 ~]# scp /etc/elasticsearch/elasticsearch.yml 192.168.56.12:/etc/elasticsearch/
    [root@linux-node2 ~]# vim /etc/elasticsearch/elasticsearch.yml
    修改:
    node.name=elk-node2
    network.host=192.168.56.12
    [root@linux-node2 ~]# mkdir /data/{elkdata,logs}
    [root@linux-node2 ~]# chown elasticsearch.elasticsearch /data -R
    [root@linux-node2 ~]# systemctl start elasticsearch.service
    [root@linux-node2 ~]# netstat -tulnp |grep java
    tcp6       0      0 10.0.0.22:9200      :::*                    LISTEN      16346/java          
    tcp6       0      0 10.0.0.23:9300      :::*                    LISTEN      16346/java          
    

    (2)yum安装elasticsearch

    1.下载并安装GPG key
    [root@linux-node1 ~]# rpm --import https://artifacts.elastic.co/GPG-KEY-elasticsearch
    
    2.添加yum仓库
    [root@linux-node1 ~]# vim /etc/yum.repos.d/es.repo 
    [elasticsearch-6.x]
    name=Elasticsearch repository for 6.x packages
    baseurl=https://artifacts.elastic.co/packages/6.x/yum
    gpgcheck=1
    gpgkey=https://artifacts.elastic.co/GPG-KEY-elasticsearch
    enabled=1
    autorefresh=1
    type=rpm-md
    
    3.安装elasticsearch
    [root@hadoop-node1 ~]# yum install -y elasticsearch
    

    三、Elasticsearch的集群配置和监控

    3.1 可以使用命令来查看elasticsearch的状态内容

    [root@linux-node1 ~]# curl http://10.0.0.22:9200/_cluster/health?pretty=true
    {
      "cluster_name" : "elk-cluster",
      "status" : "green",
      "timed_out" : false,
      "number_of_nodes" : 2,
      "number_of_data_nodes" : 2,
      "active_primary_shards" : 0,
      "active_shards" : 0,
      "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.0
    }
    

    3.2 检查集群的健康状态

    curl http://10.0.0.22:9200/_cluster/health?pretty 健康检查
    curl http://10.0.0.23:9200/_cluster/state?pretty    集群详细信息

    四、Elasticsearch插件

    Head插件安装

    插件作用:主要是做集群管理的插件(Elasticsearch6.0不能使用命令直接安装head插件)
    Github下载地址:https://github.com/mobz/elasticsearch-head

    4.1 安装node

    [root@linux-node1 ~]# wget https://nodejs.org/dist/v8.10.0/node-v8.10.0-linux-x64.tar.xz
    [root@linux-node1 ~]# tar xf node-v8.10.0-linux-x64.tar.xz
    [root@linux-node1 ~]# mv node-v8.10.0-linux-x64 /usr/local/node
    [root@linux-node1 ~]# vim /etc/profile
    export NODE_HOME=/usr/local/node
    export PATH=$PATH:$NODE_HOME/bin
    [root@linux-node1 ~]# source /etc/profile
    [root@linux-node1 ~]# which node
    /usr/local/node/bin/node
    [root@linux-node1 ~]# node -v
    v8.10.0
    [root@linux-node1 ~]# which npm
    /usr/local/node/bin/npm
    [root@linux-node1 ~]# npm -v
    5.6.0
    

    4.2 安装grunt

    (grunt是基于Node.js的项目构建工具,可以进行打包压缩、测试、执行等等的工作,head插件就是通过grunt启动)

    [root@linux-node1 ~]# npm install -g cnpm --registry=https://registry.npm.taobao.org
    [root@linux-node1 ~]# npm install -g grunt-cli --registry=https://registry.npm.taobao.org
    [root@linux-node1 ~]# grunt -version
    grunt-cli v1.2.0

    4.3 修改head插件源码

    修改服务器监听地址:Gruntfile.js
    
    [root@linux-node1 ~]# wget https://github.com/mobz/elasticsearch-head/archive/master.zip
    [root@linux-node1 ~]# unzip master.zip
    [root@linux-node1 ~]# cd elasticsearch-head-master/
    [root@linux-node1 elasticsearch-head-master]# vim Gruntfile.js
    90                 connect: {
    91                         server: {
    92                                 options: {
    93                                         hostname: '10.0.0.22',
    94                                         port: 9100,
    95                                         base: '.',
    96                                         keepalive: true
    97                                 }
    98                         }
    99                 }

    4.4 修改连接地址:_site/app.js 

    [root@linux-node1 elasticsearch-head-master]# vim _site/app.js
    4354 this.base_uri = this.config.base_uri || this.prefs.get("app-base_uri") || "http://10.0.0.22:9200";
    [root@linux-node1 elasticsearch-head-master]# cnpm install
    [root@linux-node1 elasticsearch-head-master]# grunt --version
    grunt-cli v1.2.0
    grunt v1.0.1
    

    4.5 运行head

    在elasticsearch-head-master目录下

    [root@linux-node1 elasticsearch-head-master]# cnpm install #(安装下载下来的包)
    [root@linux-node1 elasticsearch-head-master]# grunt --version
    grunt-cli v1.2.0
    grunt v1.0.1
    [root@linux-node1 elasticsearch-head-master]# vim /etc/elasticsearch/elasticsearch.yml
    90 # ---------------------------------- Head -------------------------------------增加如下两行:
    91 #
    92 http.cors.enabled: true
    93 http.cors.allow-origin: "*"
    [root@linux-node1 elasticsearch-head-master]# systemctl restart elasticsearch
    [root@linux-node1 elasticsearch-head-master]# grunt server
    (node:2833) ExperimentalWarning: The http2 module is an experimental API.
    Running "connect:server" (connect) task
    Waiting forever...
    Started connect web server on http://10.0.0.22:9100
    

    4.6 浏览器访问:http://10.0.0.22:9100,可以看到各个节点的状态信息,如图:

     4.7 head插件使用

    返回"概述"页面,点击"连接"

    上图中01234粗框是主分片,01234细框是副本分片,主分片和副本分片的数据一致,做备份。

    理论上应该分别放入2台主机,目前只用了一台主机,所以图中看到的副本分片是灰色,同时右上角的"集群健康值"显示黄色警告,10个分片只有5个。

    备注:如果出现红色,可能主分片和副本分片的数据同时丢失。

    上图中蓝色“信息”按钮,包含索引状态和索引信息。蓝色“动作”按钮,包含刷新、关闭、删除、快照、优化、测试分析器等功能。

      

     

      

      

     

      

      

     

      

  • 相关阅读:
    xcode构建webdriverAgent时报错Messaging unqualified id的解决办法
    ubuntu18.0安装RabbitMQ
    python中*的用法
    Jenkins构建项目
    Jenkins安装与配置
    git_仓库
    六、 Shell数组应用
    五、 Shell函数应用
    三、 Shell流程控制
    二、 Shell变量定义
  • 原文地址:https://www.cnblogs.com/jimmy-xuli/p/9202643.html
Copyright © 2011-2022 走看看