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

Kibana+Logstash+Elasticsearch 日志查询系统搭建

210次阅读
没有评论

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

搭建该日志查询系统的目的就是为了运维、研发很方便的进行日志的查询。Kibana 一个免费的 web 壳;Logstash 集成各种收集日志插件,还是一个比较优秀的正则切割日志工具;Elasticsearch 一个开源的搜索引擎框架(支持群集架构方式)。

1 安装需求

1.1 理论拓扑

Kibana+Logstash+Elasticsearch 日志查询系统搭建

1.2 安装环境

1.2.1 硬件环境

服务器配置:

(HP DL 385 G7、RAM:12G、CPU:AMD 6128、DISK:SAS 146*4)

(Xen 虚拟机、RAM:8G、CPU:×4、DISK:100G)

服务器 ip:

192.168.50.62(logstash 角色 agent)

192.168.50.98(redis 消息队列服务、logstash 角色 indexing、Elasticsearch)

192.168.10.42(kibana)

1.2.2 操作系统

CentOS 5.6 X64

1.2.3 Web-server 基础环境

Nginx+php(安装过程略过)

1.2.4 软件列表

JDK 1.6.0_25

logstash-1.1.0-monolithic.jar

elasticsearch-0.18.7.zip

redis-2.4.12.tar.gz

kibana

1.3 获取方法

1.3.1 Jdk 获取路径

http://www.Oracle.com/technetwork/Java/javase/downloads/jdk-6u25-download-346242.html

1.3.2 Logstash 获取路径

http://semicomplete.com/files/logstash/logstash-1.1.0-monolithic.jar

1.3.3 Elasticsearch 获取路径

https://github.com/downloads/elasticsearch/elasticsearch/ elasticsearch-0.18.7.zip

1.3.4 Kibana 获取路径

http://github.com/rashidkpc/Kibana/tarball/master

2 安装步骤

2.1 JDK 的下载及安装

基础安装

wget http://download.oracle.com/otn-pub/java/jdk/6u25-b06/jdk-6u25-linux-x64.bin

sh jdk-6u25-linux-x64.bin

mkdir -p /usr/java

mv ./jdk1.6.0_25 /usr/java

ln –s /usr/java/jdk1.6.0_25 /usr/java/default

编辑 /etc/profile 文件,加入以下行内容

export JAVA_HOME=/usr/java/default

export PATH=$JAVA_HOME/bin:$PATH

export CLASSPATH=.:$JAVA_HOME/lib/tools.jar:$JAVA_HOME/lib/dt.jar:$CLASSPATH

刷新环境变量

source /etc/profile

2.2 Redis 下载及安装

wget http://redis.googlecode.com/files/redis-2.4.14.tar.gz

make –j24

make install

mkdir -p /data/redis

cd /data/redis/

mkdir {db,log,etc}

2.3 Elasticsearch 下载及安装

cd /data/

mkdir –p elasticsearch && cd elasticsearch

wget –no-check-certificate https://github.com/downloads/elasticsearch/elasticsearch/ elasticsearch-0.18.7.zip

unzip elasticsearch-0.18.7.zip

2.4 Logstash 下载及安装

mkdir –p /data/logstash/ && cd /data/logstash

wget http://semicomplete.com/files/logstash/logstash-1.1.0-monolithic.jar

2.5 Kibana 下载及安装

wget http://github.com/rashidkpc/Kibana/tarball/master –no-check-certificate

tar zxvf master

3 相关配置及启动

首先需要提前启动消息队列(redis),Elasticsearch 服务,假如不提前启动,而去启动 logstash 会有报错,原因 logstash 不能连接对应的服务。

3.1 Redis 配置及启动

3.1.1 配置文件

vim /data/redis/etc/redis.conf

#—————————————————-

#this is the config file for redis

pidfile /var/run/redis.pid

port 6379

timeout 0

loglevel verbose

logfile /data/redis/log/redis.log

databases 16

save 900 1

save 300 10

save 60 10000

rdbcompression yes

dbfilename dump.rdb

dir /data/redis/db/

slave-serve-stale-data yes

appendonly no

appendfsync everysec

no-appendfsync-on-rewrite no

auto-aof-rewrite-percentage 100

auto-aof-rewrite-min-size 64mb

slowlog-log-slower-than 10000

slowlog-max-len 128

vm-enabled no

vm-swap-file /tmp/redis.swap

vm-max-memory 0

vm-page-size 32

vm-pages 134217728

vm-max-threads 4

hash-max-zipmap-entries 512

hash-max-zipmap-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

activerehashing yes

3.1.2 Redis 启动(192.168.50.98)

[logstash@Logstash_2 redis]# redis-server /data/redis/etc/redis.conf &

3.2 Elasticsearch 配置及启动(192.168.50.98)

3.2.1 Elasticsearch 启动

[logstash@Logstash_2 redis]# /data/elasticsearch/elasticsearch-0.18.7/bin/elasticsearch –p ../esearch.pid &

 

3.3 Logstash 配置及启动

3.3.1 Logstash 配置文件(agent 收集日志角色)

配置文件

input {

file{

type => “linux-syslog”

path => [“/var/log/*.log”, “/var/log/messages”, “/var/log/syslog”]

}

file {

type => “nginx-access”

path => “/usr/local/nginx/logs/access.log”

}

file {

type => “nginx-error”

path => “/usr/local/nginx/logs/error.log”

}

}

output {

redis {

host => “192.168.50.98”

data_type =>”list”

key => “logstash:redis”

}

}

 

Agent 启动方法

java -jar logstash-1.1.0-monolithic.jar agent -f shipper.conf &

 

3.3.2 Logstash 启动为 Index(从 redis 读取日志,负责日志的切割,存储至 Elasticsearch)

input {

redis {

host => “192.168.50.98”

data_type =>”list”

key => “logstash:redis”

type => “redis-input”

}

}

filter {

grok {

type => “linux-syslog”

pattern => “%{SYSLOGLINE}”

}

grok {

type => “nginx-access”

pattern => “%{NGINXACCESSLOG}”

}

}

output {

elasticsearch {

host =>”192.168.50.62″

}

}

启动方法

java -jar logstash.jar agent -f my.conf &

3.3.4 kibana 配置

首先在 nginx 添加站点配置

server {

listen 80;

server_name logstash.test.com;

index index.php;

root /usr/local/nginx/html;

#charset koi8-r;

#access_log logs/host.access.log main;

location ~ .*\.(php|php5)$

{

#fastcgi_pass unix:/tmp/php-cgi.sock;

fastcgi_pass 127.0.0.1:9000;

fastcgi_index index.php;

include fastcgi.conf;

}

}

4 性能调优

4.1 Elasticsearch 调优

4.1.1 JVM 调优

编辑 Elasticsearch.in.sh 文件

ES_CLASSPATH=$ES_CLASSPATH:$ES_HOME/lib/*:$ES_HOME/lib/sigar/*

if [“x$ES_MIN_MEM” = “x”]; then

ES_MIN_MEM=4g

fi

if [“x$ES_MAX_MEM” = “x”]; then

ES_MAX_MEM=4g

fi

4.1.2 Elasticsearch 索引压缩

vim index_elastic.sh

#!/bin/bash

#comperssion the data for elasticsearch now

date=` date +%Y.%m.%d `

# compression the new index;

/usr/bin/curl -XPUT http://localhost:9200/logstash-$date/nginx-access/_mapping -d ‘{“nginx-access” : {“_source” : { “compress” : true}}}’

echo “”

/usr/bin/curl -XPUT http://localhost:9200/logstash-$date/nginx-error/_mapping -d ‘{“nginx-error” : {“_source” : { “compress” : true}}}’

echo “”

/usr/bin/curl -XPUT http://localhost:9200/logstash-$date/linux-syslog/_mapping -d ‘{“linux-syslog” : {“_source” : { “compress” : true}}}’

echo “”

保存该脚本并执行

sh index_elastic.sh

5 使用

5.1 Logstash 查询页

使用火狐浏览器或者谷歌浏览器访问 http://logstash.test.com

Kibana+Logstash+Elasticsearch 日志查询系统搭建

Linux 上安装部署 ElasticSearch 全程记录  http://www.linuxidc.com/Linux/2015-09/123241.htm

Elasticsearch 安装使用教程 http://www.linuxidc.com/Linux/2015-02/113615.htm

ElasticSearch 配置文件译文解析 http://www.linuxidc.com/Linux/2015-02/114244.htm

ElasticSearch 集群搭建实例  http://www.linuxidc.com/Linux/2015-02/114243.htm

分布式搜索 ElasticSearch 单机与服务器环境搭建  http://www.linuxidc.com/Linux/2012-05/60787.htm

ElasticSearch 的工作机制  http://www.linuxidc.com/Linux/2014-11/109922.htm 

Elasticsearch 的安装,运行和基本配置 http://www.linuxidc.com/Linux/2016-07/133057.htm

使用 Elasticsearch + Logstash + Kibana 搭建日志集中分析平台实践  http://www.linuxidc.com/Linux/2015-12/126587.htm

Ubuntu 14.04 搭建 ELK 日志分析系统 (Elasticsearch+Logstash+Kibana) http://www.linuxidc.com/Linux/2016-06/132618.htm

Elasticsearch1.7 升级到 2.3 实践总结  http://www.linuxidc.com/Linux/2016-11/137282.htm

Ubuntu 14.04 中 Elasticsearch 集群配置  http://www.linuxidc.com/Linux/2017-01/139460.htm

Elasticsearch-5.0.0 移植到 Ubuntu 16.04  http://www.linuxidc.com/Linux/2017-01/139505.htm

ElasticSearch 的详细介绍 :请点这里
ElasticSearch 的下载地址 :请点这里 

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

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