阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

CentOS 6.5下安装配置ELK及收集Nginx日志

223次阅读
没有评论

共计 7356 个字符,预计需要花费 19 分钟才能阅读完成。

Elasticsearch 是个开源分布式搜索引擎,它的特点有:分布式,零配置,自动发现,索引自动分片,索引副本机制,restful 风格接口,多数据源,自动搜索负载等。

Logstash 是一个完全开源的工具,他可以对你的日志进行收集、分析,并将其存储供以后使用(如,搜索)

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

环境:

192.168.50.119:ELK+Nginx

192.168.50.120:Redis+Logstash

架构图

CentOS 6.5 下安装配置 ELK 及收集 Nginx 日志

部署流程:

192.168.50.119 ELK 服务器

1. 安装 JDK

Logstash 的运行依赖于 Java 运行环境,Logstash 1.5 以上版本不低于 java 7 推荐使用最新版本的 Java,我这里使用了 1.8 版本

tar -zxf jdk-8u45-linux-x64.tar.gz -C /usr/local/
vim /etc/profile  #设置环境变量
export JAVA_HOME=/usr/local/jdk1.8.0_45
export PATH=$PATH:$JAVA_HOME/bin
export CLASSPATH=.:$JAVA_HOME/lib/tools.jar:$JAVA_HOME/lib/dt.jar:$CLASSPATH
source /etc/profile  #使环境变量生效

验证是否安装成功

[root@localhost ~]# java -version
java version “1.8.0_45”
Java(TM) SE Runtime Environment (build 1.8.0_45-b14)
Java HotSpot(TM) 64-Bit Server VM (build 25.45-b02, mixed mode)

2. 安装 Logstash(日志收集、分析,并将其存储供以后使用)

wget https://download.elastic.co/logstash/logstash/logstash-2.4.0.tar.gz
tar –zxf logstash-2.4.0.tar.gz -C /usr/local/

验证 logstash 是否安装成功

[root@localhost ~]# /usr/local/logstash-2.4.0/bin/logstash -e ‘input {stdin {} } output {stdout {} }’
Settings: Default pipeline workers: 1
Logstash startup completed
等待输入:hello world
2016-11-28T20:32:07.853Z localhost.localdomain hello world

我们可以看到,我们输入什么内容 logstash 按照某种格式输出,其中 - e 参数参数允许 Logstash 直接通过命令行接受设置。

这点尤其快速的帮助我们反复的测试配置是否正确而不用写配置文件。使用 CTRL- C 命令可以退出之前运行的 Logstash。

3. 部署 nginx 并收集日志

yum -y install nginx
设置 nginx 的 log 格式
vim /etc/nginx/nginx.conf
    log_format main ‘$remote_addr – $remote_user [$time_local] “$request” ‘
                      ‘$status $body_bytes_sent “$http_referer” ‘
                      ‘”$http_user_agent” $http_x_forwarded_for $request_length $msec $connection_requests $request_time’;

启动 nginx

service nginx start

mkdir /usr/local/logstash-2.4.0/conf/  #创建 logstash 配置目录
定义 logstash 配置文件,用来收集 nginx 日志
[root@localhost conf]# cat logstash_nginx.conf
input {
    file {
        path => [“/var/log/nginx/access.log”]
        type => “nginx_log”
    }
}
output {
    redis{
        host => “192.168.50.120”
        key => ‘logstash-redis’
        data_type => ‘list’
    }
    stdout {
codec => rubydebug
    }
}

4. 安装部署 redis   

192.168.50.120 服务器

yum -y install redis
vim /etc/redis.conf
bind 192.168.50.120

启动

service redis start

5. 启动 Logstash

[root@localhost conf]# /usr/local/logstash-2.4.0/bin/logstash -f ./logstash_nginx.conf  –configtest  #检查配置文件
Configuration OK

[root@localhost conf]# /usr/local/logstash-2.4.0/bin/logstash agent  -f ./logstash_nginx.conf          #将日志信息输出到 redis 服务器
Settings: Default pipeline workers: 1
Logstash startup completed
{
      “message” => “192.168.50.114 – – [29/Nov/2016:00:58:43 +0800] \”GET / HTTP/1.1\” 304 0 \”-\” \”Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.99 Safari/537.36\” \”-\””,
      “@version” => “1”,
    “@timestamp” => “2016-11-28T18:55:49.587Z”,
          “path” => “/var/log/nginx/access.log”,
          “host” => “localhost.localdomain”,
          “type” => “nginx_log”
}
{
      “message” => “192.168.50.114 – – [29/Nov/2016:00:58:43 +0800] \”GET /nginx-logo.png HTTP/1.1\” 304 0 \”http://192.168.50.119/\” \”Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.99 Safari/537.36\” \”-\””,
      “@version” => “1”,
    “@timestamp” => “2016-11-28T18:55:49.590Z”,
          “path” => “/var/log/nginx/access.log”,
          “host” => “localhost.localdomain”,
          “type” => “nginx_log”
}
{
      “message” => “192.168.50.114 – – [29/Nov/2016:00:58:43 +0800] \”GET /poweredby.png HTTP/1.1\” 304 0 \”http://192.168.50.119/\” \”Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.99 Safari/537.36\” \”-\””,
      “@version” => “1”,
    “@timestamp” => “2016-11-28T18:55:49.590Z”,
          “path” => “/var/log/nginx/access.log”,
          “host” => “localhost.localdomain”,
          “type” => “nginx_log”
}

6. 安装部署 Elasticsearch

192.168.50.119 ELK 服务器

创建安装用户

groupadd elk
useradd es -g elk

tar -xf elasticsearch-2.2.0.tar.gz -C /usr/local/
vim /usr/local/elasticsearch-2.2.0/config/elasticsearch.yml
  network.host: 192.168.50.119  # 端口绑定 ip 地址
  http.port: 9200

启动

这里遇到一个坑:es 用户默认是不能用 root 用户启动的。所以要切到普通用户启动

chown -R es.elk /usr/local/elasticsearch-2.2.0
su – es
nohup  /usr/local/elasticsearch-2.2.0/bin/elasticsearch >/usr/local/elasticsearch-2.2.0/nohub &

[root@localhost ELK]# netstat -tunpl | grep 9200
tcp        0      0 ::ffff:192.168.50.119:9200  :::*                        LISTEN      2183/java

[root@localhost ELK]# curl http://192.168.50.119:9200  #查看状态
{
  “name” : “Blood Brothers”,
  “cluster_name” : “elasticsearch”,
  “version” : {
    “number” : “2.2.0”,
    “build_hash” : “8ff36d139e16f8720f2947ef62c8167a888992fe”,
    “build_timestamp” : “2016-01-27T13:32:39Z”,
    “build_snapshot” : false,
    “lucene_version” : “5.4.1”
  },
  “tagline” : “You Know, for Search”
}

CentOS 6.5 下安装配置 ELK 及收集 Nginx 日志

安装 kopf 和 head 插件

[root@localhost conf]# cd /usr/local/elasticsearch-2.2.0/bin/
[root@localhost bin]# ./plugin  install lmenezes/elasticsearch-kopf
-> Installing lmenezes/elasticsearch-kopf…
Trying https://github.com/lmenezes/elasticsearch-kopf/archive/master.zip …
Downloading …………………………………………………… DONE
Verifying https://github.com/lmenezes/elasticsearch-kopf/archive/master.zip checksums if available …
NOTE: Unable to verify checksum for downloaded plugin (unable to find .sha1 or .md5 file to verify)
Installed kopf into /usr/local/elasticsearch-2.2.0/plugins/kopf

[root@localhost bin]# ./plugin install mobz/elasticsearch-head
-> Installing mobz/elasticsearch-head…
Trying https://github.com/mobz/elasticsearch-head/archive/master.zip …
Downloading …………………………………………………DONE
NOTE: Unable to verify checksum for downloaded plugin (unable to find .sha1 or .md5 file to verify)
Installed head into /usr/local/elasticsearch-2.2.0/plugins/head

7. 安装 kibana

192.168.50.119 ELK 服务器

安装

[root@localhost ELK]# tar -xf kibana-4.4.0-linux-x64.tar.gz  -C /usr/local/
[root@localhost ELK]# cd /usr/local/kibana-4.4.0-linux-x64/

配置

[root@localhost kibana-4.4.0-linux-x64]# vim config/kibana.yml
elasticsearch.url: “http://192.168.50.119:9200”
server.port: 5601
server.host: “0.0.0.0”

启动

[root@localhost kibana-4.4.0-linux-x64]# nohup  /usr/local/kibana-4.4.0-linux-x64/bin/kibana > /usr/local/kibana-4.4.0-linux-x64/nohub.out &

[root@localhost ELK]# netstat -tunpl | grep 5601
tcp        0      0 0.0.0.0:5601                0.0.0.0:*

浏览器访问 http://192.168.50.119:5601/

CentOS 6.5 下安装配置 ELK 及收集 Nginx 日志

8. 安装 logstash-server 服务器

192.168.50.120  服务器

安装 jdk 和 logstash

tar -zxf jdk-8u45-linux-x64.tar.gz -C /usr/local/
vim /etc/profile  #设置环境变量
export JAVA_HOME=/usr/local/jdk1.8.0_45
export PATH=$PATH:$JAVA_HOME/bin
export CLASSPATH=.:$JAVA_HOME/lib/tools.jar:$JAVA_HOME/lib/dt.jar:$CLASSPATH
source /etc/profile  #使环境变量生效

tar –zxf logstash-2.4.0.tar.gz -C /usr/local/
mkdir /usr/local/logstash-2.4.0/conf

将 redis 中的数据发送到 elasticsearch 中

[root@localhost conf]# cat logstash_server.conf
input {
    redis {
        port => “6379”
        host => “192.168.50.120”
        data_type => “list”
        key => “logstash-redis”
        type => “redis-input”
  }
}
output {
    elasticsearch {
        hosts => “192.168.50.119”
        index => “logstash-%{+YYYY.MM.dd}”
  }
}

9. 在 Kibanda 上创建 nginx 日志监控视图

CentOS 6.5 下安装配置 ELK 及收集 Nginx 日志

CentOS 6.5 下安装配置 ELK 及收集 Nginx 日志

CentOS 6.5 下安装配置 ELK 及收集 Nginx 日志

es 常规操作

es 健康状态
[root@localhost ~]# curl  http://192.168.50.119: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
1480345315 23:01:55  elasticsearch yellow          1        1      6  6    0    0        6            0                  –                50.0%
health 的状态包括:green, yellow, red.
列出节点
[root@localhost ~]# curl  http://192.168.50.119:9200/_cat/nodes?v
host          ip            heap.percent ram.percent load node.role master name         
192.168.50.119 192.168.50.119            8          99 0.00 d        *      Blood Brothers
列出索引
[root@localhost ~]# curl  http://192.168.50.119:9200/_cat/indices?v
health status index              pri rep docs.count docs.deleted store.size pri.store.size
yellow open  .kibana              1  1          2            0      5.6kb          5.6kb
yellow open  logstash-2016.11.28  5  1          1            0      4.9kb          4.9kb

本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-03/141312.htm

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-21发表,共计7356字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中