logstash+elasticsearch+kibana日志收集

一. 环境准备

角色 SERVER IP
logstash agent 10.1.11.31
logstash agent 10.1.11.35
logstash agent 10.1.11.36
logstash central 10.1.11.13
elasticsearch  10.1.11.13
redis 10.1.11.13
kibana 10.1.11.13

架构图如下:

整个流程如下:

1) 远程节点的logstash agent收集本地日志后发送到远程redis的list队列

2) 使用redis作为日志收集的中间件, 可以暂存远程节点的日志数据, 起到数据缓冲,提高并发的作用

3) central logstash分别从redis和本地日志文件读取数据发送到elasticsearch进行存储,索引

4) kibana从elasticsearch中读取数据,通过web gui展示给用户

二. 安装

ELK的安装很简单,只需将二进制包下载下来解压即可用,所需二进制包如下:

elasticsearch-1.7.1.tar.gz

kibana-4.1.1-linux-x64.tar.gz

logstash-1.5.3.tar.gz

1)启动redis (10.1.11.13)

从官方下载redis源码编译安装后,进行如下配置后启动即可:

#调整内核参数:
echo 1 > /proc/sys/vm/overcommit_memory 
echo never > /sys/kernel/mm/transparent_hugepage/enabled
echo 524288 > /proc/sys/net/core/somaxconn

#修改redis配置文件如下:
[[email protected] logstash]# cat /etc/redis-logstash.conf
daemonize yes
pidfile /data/redis-logstash/run/redis.pid
port 6377
tcp-backlog 511
timeout 0
tcp-keepalive 0
loglevel notice
logfile "/data/redis-logstash/log/redis.log"
databases 16
save 900 1
save 300 10
save 60 10000
stop-writes-on-bgsave-error yes
rdbcompression yes
rdbchecksum yes
dbfilename dump.rdb
dir /data/redis-logstash/db
slave-serve-stale-data yes
slave-read-only yes
repl-diskless-sync no
repl-diskless-sync-delay 5
repl-disable-tcp-nodelay no
slave-priority 100
appendonly no
appendfilename "appendonly.aof"
appendfsync everysec
no-appendfsync-on-rewrite no
auto-aof-rewrite-percentage 100
auto-aof-rewrite-min-size 64mb
aof-load-truncated yes
lua-time-limit 5000
slowlog-log-slower-than 10000
slowlog-max-len 128
latency-monitor-threshold 0
notify-keyspace-events ""
hash-max-ziplist-entries 512
hash-max-ziplist-value 64
list-max-ziplist-entries 512
list-max-ziplist-value 64
set-max-intset-entries 512
zset-max-ziplist-entries 128
zset-max-ziplist-value 64
hll-sparse-max-bytes 3000
activerehashing yes
client-output-buffer-limit normal 0 0 0
client-output-buffer-limit slave 256mb 64mb 60
client-output-buffer-limit pubsub 32mb 8mb 60
hz 10
aof-rewrite-incremental-fsync yes
maxmemory 32212254720
maxmemory-policy allkeys-lru

#启动redis
/usr/local/bin/redis-server /etc/redis-logstash.conf

2)安装logstash agent (10.1.11.31/35/36)

解压logstash-1.5.3.tar.gz到/usr/local

cd /usr/local
ln -s logstash-1.5.3 logstash
#创建/etc/logstash目录,用户保存agent端的规则文件
mkdir /etc/logstash
# 配置agent端收集tomcat日志的规则
vim /etc/logstash/tomcat_api.conf
#配置日志输入源
input {
    file {
        type => "tomcat_api"  #指定日志类别名称
        path => "/data/logs/bd_api/api"   #指定日志路径
        start_position => "beginning"   #从日志文件首部开始收集
    }
}
#过滤规则配置
filter {
    if [type] == "tomcat_api" {
        #multiline用于将多行日志合并成一行,因为java的exception会有多行,但应该将其作为一条日志记录看待
        multiline {
            patterns_dir => "/usr/local/logstash/patterns"   #patterns_dir用于指定patterns文件的位置,patterns文件用于保存匹配日志字段的正则表达式
            pattern => "^%{TIMESTAMP_ISO8601}"   #指定匹配的pattern
            negate => true     #true表示只要不匹配pattern的行都会进行合并,默认为false
            what => "previous"    #匹配pattern的行追加到合并行的前方,作为一条日志记录输出
        } 
        #grok用来进行日志字段的解析
        grok {
            patterns_dir => "/usr/local/logstash/patterns"
            match => { "message" => "%{LOG4JLOG}" }    #在/usr/local/logstash/patterns中创建%{LOG4JLOG}的pattern如下:
#LOG4JLOG %{TIMESTAMP_ISO8601:datetime}\s+(?<thread>\S+)\s+(?<line>\d+)\s+(?<level>\S+)\s+(?<class>\S+)\s+-\s+(?<msg>.*)
    
        #mutate可以对字段的内容进行替换
        mutate {
            replace => [ "host", "10.1.11.31"]
        }
    }
}
#日志输出源
output {
    #规则调试时开启
    #stdout { codec => "rubydebug" }
    #将日志数据输出到远程redis list中
    redis {
      host => "10.1.11.13"
      port => 6377
      data_type => "list"
      key => "tomcat_api"
    }
}

3) 安装central logstash (10.1.11.13)

解压logstash-1.5.3.tar.gz到/usr/local

cd /usr/local
ln -s logstash-1.5.3 logstash
#创建/etc/logstash目录,用户保存central端和本地agent的规则文件
mkdir /etc/logstash
#这里创建有两个规则文件
/etc/logstash/
├── central.conf         #保存central端的logstash规则
└── tomcat_uat.conf      #保存本地agent的logstash规则
vim central.conf
input {
    ##product
    #从redis中获取类别为tomcat_api的日志
    redis {
        host => "127.0.0.1"
        port => 6377
        type => "redis-input"
        data_type => "list"
        key => "tomcat_api"
    }
    #从redis中获取类别为tomcat_editor的日志
    redis {
        host => "127.0.0.1"
        port => 6377
        type => "redis-input"
        data_type => "list"
        key => "tomcat_editor"
    }
}

output {
    #stdout { codec => "rubydebug" }
    #日志输出到elasticsearch进行索引
    elasticsearch {
        flush_size => 50000
        idle_flush_time => 10
        cluster => "logstash-1113"
        host =>  ["127.0.0.1:9300"]
        workers => 2
    }
}
#-----------------------------------------------------------------
vim tomcat_uat.conf   
input {
    
    file {
        type => "tomcat_api_ab"
        path => "/data/logs/bd_api/errors/api_error"
        start_position => "beginning"
    }

    file {
        path => "/data/logs/bd_admin/admin"
        type => "tomcat_9083"
        start_position => "beginning"
    }
}

filter {
    if [type] in ["tomcat_api_ab","tomcat_9083"] {
        multiline {
            patterns_dir => "/usr/local/logstash/patterns"
            pattern => "^%{TIMESTAMP_ISO8601}"
            negate => true
            what => "previous"
        } 
        
        grok {
            patterns_dir => "/usr/local/logstash/patterns"
            match => { "message" => "%{LOG4JLOG}" } 
        }
 
        mutate {
            replace => [ "host", "10.1.11.13"]
        }
    }
}

output {
    #stdout { codec => "rubydebug" }
    elasticsearch {
        flush_size => 50000
        idle_flush_time => 10
        cluster => "logstash-1113"
        host =>  ["127.0.0.1:9300"]
        workers => 2
    }
}

4) 安装elasticsearch

#解压elasticsearch-1.7.1.tar.gz到/usr/local
tar xf elasticsearch-1.7.1.tar.gz -C /usr/local
cd /usr/local
ln -s elasticsearch-1.7.1 elasticsearch
[[email protected] config]# egrep -v ‘^#|^$‘ elasticsearch.yml 
#指定集群名称
cluster.name: logstash-1113
#数据索引目录路径
path.data: /data/logstash/els/data
#数据临时目录路径
path.work: /data/logstash/els/work
#日志路径
path.logs: /data/logstash/els/logs
#解决访问kibana时提示无法连接elasticsearch的问题(之前kibana3时出现过)
http.cors.enabled: true
#调整jvm对内存大小
vim /usr/local/elasticsearch/bin/elasticsearch.in.sh
if [ "x$ES_MIN_MEM" = "x" ]; then
    ES_MIN_MEM=4g
fi
if [ "x$ES_MAX_MEM" = "x" ]; then
    ES_MAX_MEM=16g
fi

5)安装kibana

#解压kibana-4.1.1-linux-x64.tar.gz到/usr/local
tar xf kibana-4.1.1-linux-x64.tar.gz -C /usr/local
cd /usr/local
ln -s kibana-4.1.1-linux-x64 kibana

三. 启动ELK

central端启动:

### Starting logstash ###
/usr/local/elasticsearch/bin/elasticsearch -d  || /bin/true
nohup /usr/local/logstash/bin/logstash agent -f /etc/logstash/central.conf -l /data/logstash/log/logstash-central.log &>/data/logstash/log/logstash-central.out  || /bin/true &
sleep 3
nohup /usr/local/logstash/bin/logstash agent -f /etc/logstash/tomcat_uat.conf -l /data/logstash/log/logstash-uat.log &>/data/logstash/log/logstash-uat.out  || /bin/true &
sleep 1
nohup /usr/local/kibana/bin/kibana &>/dev/null || /bin/true &

agent 端启动:

### starting logstash api-agent ###
/usr/bin/nohup /usr/local/logstash/bin/logstash agent -f /etc/logstash/tomcat_api.conf -l /data/logstash/log/logstash-api.log &> /dev/null || /bin/true &

将以上命令复制到/etc/rc.local可实现开机自动启动

时间: 2024-12-19 10:32:36

logstash+elasticsearch+kibana日志收集的相关文章

logstash+elasticsearch +kibana 日志管理系统

Logstash是一个完全开源的工具,他可以对你的日志进行收集.分析,并将其存储供以后使用(如,搜索),您可以使用它.说到搜索,logstash带有一个web界面,搜索和展示所有日志.kibana 也是一个开源和免费的工具,他可以帮助您汇总.分析和搜索重要数据日志并提供友好的web界面.他可以为 Logstash 和 ElasticSearch 提供的日志分析的 Web 界面. 目的就是为了运维.研发很方便的进行日志的查询.Kibana一个免费的web壳:Logstash集成各种收集日志插件,还

Filebeat+Kafka+Logstash+ElasticSearch+Kibana 日志采集方案

前言 Elastic Stack 提供 Beats 和 Logstash 套件来采集任何来源.任何格式的数据.其实Beats 和 Logstash的功能差不多,都能够与 Elasticsearch 产生协同作用,而且 logstash比filebeat功能更强大一点,2个都使用是因为:Beats 是一个轻量级的采集器,支持从边缘机器向 Logstash 和 Elasticsearch 发送数据.考虑到 Logstash 占用系 统资源较多,我们采用 Filebeat 来作为我们的日志采集器.并且

Logstash+Elasticsearch+Kibana日志服务器搭建

官网https://www.elastic.co 软件版本: Logstash 2.2.0 All Plugins Elasticsearch 2.2.0 Kibana 4.4.0 说明:此环境变Centos6.5 64位,单机做测试,具体配置从简. 1.Logstash安装配置 解压到/usr/local/logstash-2.2.0/ Logstash配置文件: vim /usr/local/logstash-2.2.0/etc/agent.conf input {     file {  

使用logstash+elasticsearch+kibana快速搭建日志平台

日志的分析和监控在系统开发中占非常重要的地位,系统越复杂,日志的分析和监控就越重要,常见的需求有: 根据关键字查询日志详情 监控系统的运行状况 统计分析,比如接口的调用次数.执行时间.成功率等 异常数据自动触发消息通知 基于日志的数据挖掘 很多团队在日志方面可能遇到的一些问题有: 开发人员不能登录线上服务器查看详细日志,经过运维周转费时费力 日志数据分散在多个系统,难以查找 日志数据量大,查询速度慢 一个调用会涉及多个系统,难以在这些系统的日志中快速定位数据 数据不够实时 常见的一些重量级的开源

【转载】使用logstash+elasticsearch+kibana快速搭建日志平台

原文链接:http://www.cnblogs.com/buzzlight/p/logstash_elasticsearch_kibana_log.html 日志的分析和监控在系统开发中占非常重要的地位,系统越复杂,日志的分析和监控就越重要,常见的需求有: 根据关键字查询日志详情 监控系统的运行状况 统计分析,比如接口的调用次数.执行时间.成功率等 异常数据自动触发消息通知 基于日志的数据挖掘 很多团队在日志方面可能遇到的一些问题有: 开发人员不能登录线上服务器查看详细日志,经过运维周转费时费力

Logstash+Elasticsearch+Kibana 联合使用搭建日志分析系统(Windows系统)

最近在做日志分析这块儿,要使用 Logstash+Elasticsearch+Kibana 实现日志的导入.过滤及可视化管理,官方文档写的不够详细,网上的文章大多要么是针对Linux系统的用法,要么就是抄袭别人的配置大都没法运行.费了很大劲才搞定了这仨东西,写一篇用法心得,废话不多说,进入主题. 首先,你的电脑上要装Java 的JDK环境,要使用  Logstash+Elasticsearch+Kibana,需要下载这三个软件和一些必要的插件,列表如下 : 1.Java JDK (最新版Logs

logstash+elastic+kibana日志管理工具介绍及安装

logstash+elastic+kibana日志管理工具介绍及安装 一. Logstash 安装 1.1 前置条件,安装了官方java 7或更新版本 查看 [ldx@1511-min ~]$ java -version openjdk version "1.8.0_71" OpenJDK Runtime Environment (build 1.8.0_71-b15) OpenJDK 64-Bit Server VM (build 25.71-b15, mixed mode) 1.2

(原)logstash-forwarder + logstash + elasticsearch + kibana

[logstash-forwarder + logstash + elasticsearch + kibana]------------------------------------------------------------------------------------------------------------------------------------------------摘要:logstash-forwarder搜集日志,汇总给logstash,然后输出到elastic

安装logstash,elasticsearch,kibana三件套

原文地址:http://www.cnblogs.com/yjf512/p/4194012.html logstash,elasticsearch,kibana三件套 elk是指logstash,elasticsearch,kibana三件套,这三件套可以组成日志分析和监控工具 注意: 关于安装文档,网络上有很多,可以参考,不可以全信,而且三件套各自的版本很多,差别也不一样,需要版本匹配上才能使用.推荐直接使用官网的这一套:elkdownloads. 比如我这里下载的一套是logstash 1.4