ElasticSearch+LogStash+Kibana+Redis搭建日志管理服务

简介:

说来话长,网上的安装版本太坑爹了,很多是问题是版本兼容性,导致我在测试时一直有问题,好了,现在总结一个简单又完美的安装文档

安装版本:

先下载好以下软件包

【jdk-7u75-linux-x64.gz】

【redis-2.6.16.tar.gz】

wget http://download.redis.io/releases/redis-2.6.16.tar.gz

【elasticsearch-1.3.2.tar.gz】

wget https://download.elasticsearch.org/elasticsearch/elasticsearch/elasticsearch-1.5.2.tar.gz

【logstash-1.4.2.tar.gz】

wget https://download.elasticsearch.org/logstash/logstash/logstash-1.4.2.tar.gz

【kibana-latest.zip】

wget http://download.elasticsearch.org/kibana/kibana/kibana-latest.zip

好了,直接开工:

一、JAVA环境安装

1
2
3
4
5
6
7
tar  -zxvf jdk-7u75-linux-x64.gz -C  /opt
vi  /etc/profile
export  JAVA_HOME= /usr/local/jdk1 .7.0_75
export  JRE_HOME=${JAVA_HOME} /jre
export  CLASSPATH=.:${JAVA_HOME} /lib :${JRE_HOME} /lib
export  PATH=${JAVA_HOME} /bin :$PATH
source  /etc/profile

二、安装redis

1
2
3
4
5
6
7
tar  -zxvf redis-2.6.16. tar .gz
cd  redis-2.6.16
make  –j24
make  install
mkdir  -p  /data/redis
cd  /data/redis/
mkdir  {db,log,etc}

编辑配置文件

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
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

启动和验证redis

1
2
3
[logstash@Logstash_2 redis] # redis-server /data/redis/etc/redis.conf &
[logstash@Logstash_2 redis] # redils-cli
redis 127.0.0.1:6379> keys *

三、安装elasticsearch

1
2
3
4
5
6
7
8
9
10
11
12
#tar zxvf elasticsearch-1.5.2.tar.gz
#mv elasticsearch-1.5.2 /usr/local/
#cd /usr/local/
#ln -s elasticsearch-1.5.2 elasticsearch
在最下面文件增加如下内容(权限管理和防跨站攻击):
#vi config/elasticsearch.yml
http.cors.allow-origin:  "/.*/"
http.cors.enabled:  true
script.disable_dynamic:  true
 
保存后,我们可以用以下命令启动
#/usr/local/elasticsearch/bin/elasticsearch -f

ctrl+c退出

以后台方式运行

1
#/usr/local/elasticsearch/bin/elasticsearch -d

验证安装,访问默认的9200端口

1
2
3
4
5
6
7
8
9
10
11
12
13
14
curl -X GET http: //localhost :9200
  
{
   "status"  : 200,
   "name"  "Eros" ,
   "version"  : {
     "number"  "1.3.2" ,
     "build_hash"  "dee175dbe2f254f3f26992f5d7591939aaefd12f" ,
     "build_timestamp"  "2014-08-13T14:29:30Z" ,
     "build_snapshot"  false ,
     "lucene_version"  "4.9"
   },
   "tagline"  "You Know, for Search"
}

四、安装logstash

1
2
3
4
5
6
#tar zxvf logstash-1.4.2.tar.gz
#mv logstash-1.4.2 /usr/local
#cd /usr/local
#ln -s logstash-1.4.2 logstash
#mkdir logstash/conf
#chown -R root:root logstash

logstash分为两种:一个是服务器,一个是代理端,我们在中心服务器都要启动

先说中心服务器

启动之前我们要先配置一下文件,这个配置主要是从REDIS取出键值

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#vi logstash.conf
input {
   redis {
     host =>  "127.0.0.1"
     port =>  "6379"
     key =>  "nginx_logs"
     data_type =>  "list"
     codec  =>  "json"
     type  =>  "nginx_logs"
     tags => [ "nginx_logs" ]
   }
}
   
output {
   elasticsearch {
     host =>  "127.0.0.1"
   }
   
}

好了,保存后就可以启动了

1
#logstash/bin/logstash agent -f logstash.conf &

同样,我们要启动logstash的服务器端,也就是网页版,会启动9292

当然了,这一步也可以省去,因为后面我们配置kibana,用kibana做网页访问展示

1
#logstash/bin/logstash web &

以上配置完,我们的中心服务就配置完了,看下我们的进程

1
2
3
4
5
root@admin: /yundata/data/logstash # ps -ef|grep java
root     11885 11724  0 09:20 pts /0     00:00:25  /usr/local/jdk1 .7.0_75 /bin/java  -Xmx500m -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -Djava.awt.headless= true  -XX:CMSInitiatingOccupancyFraction=75 -XX:+UseCMSInitiatingOccupancyOnly -jar  /yundata/data/logstash/vendor/jar/jruby-complete-1 .7.11.jar -I /yundata/data/logstash/lib  /yundata/data/logstash/lib/logstash/runner .rb web
root     12619     1  0 09:34 pts /3     00:00:13  /usr/local/jdk1 .7.0_75 /bin/java  -Xms256m -Xmx1g -Xss256k -Djava.awt.headless= true  -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:CMSInitiatingOccupancyFraction=75 -XX:+UseCMSInitiatingOccupancyOnly -XX:+HeapDumpOnOutOfMemoryError -XX:+DisableExplicitGC -Delasticsearch -Des.path.home= /yundata/data/elasticsearch-1 .3.2 - cp  : /yundata/data/elasticsearch-1 .3.2 /lib/elasticsearch-1 .3.2.jar: /yundata/data/elasticsearch-1 .3.2 /lib/ *: /yundata/data/elasticsearch-1 .3.2 /lib/sigar/ * org.elasticsearch.bootstrap.Elasticsearch
root     13768 12251  0 10:04 pts /3     00:00:00  grep  --color=auto java
root     21322     1  0 Apr15 ?        00:01:51  /usr/local/jdk1 .7.0_75 /bin/java  -Xmx500m -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -Djava.awt.headless= true  -XX:CMSInitiatingOccupancyFraction=75 -XX:+UseCMSInitiatingOccupancyOnly -jar  /yundata/data/logstash/vendor/jar/jruby-complete-1 .7.11.jar -I /yundata/data/logstash/lib  /yundata/data/logstash/lib/logstash/runner .rb agent -f redis.conf

以上配置完,就可以访问我们的服务了,

1
http: //127 .0.0.1:9292 /index .html #/dashboard/file/logstash.json

以这里就不上图了,不过只能正常访问还看不到数据,后面我们再采集数据

五、安装kibana

这一步可以安装,也可以不用,因为:

logstash的最新版已经内置kibana,你也可以单独部署kibana。kibana3是纯粹JavaScript+html的客户端,所以可以部署到任意http服务器上。

前提安装好APACHE,我们直接放到目录下

1
2
unzip kibana-latest.zip
cp  -r  kibana-latest  /var/www/html

可以修改config.js来配置elasticsearch的地址和索引。

用浏览器访问试试看 http://127.0.0.1/html/kibana-latest/index.html

好了,至此已经安装完了,很简单吧

我们接下来采集数据:在我们的NGINX服务器,

1、安装好JAVA环境,

2、拷贝logstash

3、编写采集脚本

10.252.35.170是我们有中心服器,我们现在把数据写入到中心服务器的redis

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#vi nginx.conf
input {
         file  {
                 type  =>  "nginx_logs"
                 path => [ "/alidata/log/nginx/access/default.log" ]
                 exclude => [ "*.gz" "access.log" ]
        
}
   
output {
         stdout {}
         redis {
                 host =>  "10.252.35.170"
                 port => 6379
                 data_type =>  "list"
                 key =>  "nginx_logs"
        
}

启动

1
logstash /bin/logstash  agent -f nginx.conf &

当然以上是我们测试写的一个配置,如果要具体的配置

可以参考《logstash 过虑nginx访问日志

好了,在中心服务器我们启动redis监控,看数据有没有写入

1
# redis-cli monitor

这样一个比较快速 简单的日志服务器就搭建好了,当然这个采集脚本还要改进,后续我们再谈,

采集到数据后,我们刷新页面,就可以看到数据了

小小激动下~~~

wKioL1W65gvjPe0mAAP4Cqzo-H0494.jpg



本文转自 jackjiaxiong 51CTO博客,原文链接:http://blog.51cto.com/xiangcun168/1680441

相关实践学习
以电商场景为例搭建AI语义搜索应用
本实验旨在通过阿里云Elasticsearch结合阿里云搜索开发工作台AI模型服务,构建一个高效、精准的语义搜索系统,模拟电商场景,深入理解AI搜索技术原理并掌握其实现过程。
ElasticSearch 最新快速入门教程
本课程由千锋教育提供。全文搜索的需求非常大。而开源的解决办法Elasricsearch(Elastic)就是一个非常好的工具。目前是全文搜索引擎的首选。本系列教程由浅入深讲解了在CentOS7系统下如何搭建ElasticSearch,如何使用Kibana实现各种方式的搜索并详细分析了搜索的原理,最后讲解了在Java应用中如何集成ElasticSearch并实现搜索。  
相关文章
|
存储 NoSQL Redis
阿里面试:Redis 为啥那么快?怎么实现的100W并发?说出了6大架构,面试官跪地: 纯内存 + 尖端结构 + 无锁架构 + EDA架构 + 异步日志 + 集群架构
阿里面试:Redis 为啥那么快?怎么实现的100W并发?说出了6大架构,面试官跪地: 纯内存 + 尖端结构 + 无锁架构 + EDA架构 + 异步日志 + 集群架构
阿里面试:Redis 为啥那么快?怎么实现的100W并发?说出了6大架构,面试官跪地: 纯内存 + 尖端结构 +  无锁架构 +  EDA架构  + 异步日志 + 集群架构
|
11月前
|
JSON 安全 数据可视化
Elasticsearch(es)在Windows系统上的安装与部署(含Kibana)
Kibana 是 Elastic Stack(原 ELK Stack)中的核心数据可视化工具,主要与 Elasticsearch 配合使用,提供强大的数据探索、分析和展示功能。elasticsearch安装在windows上一般是zip文件,解压到对应目录。文件,elasticsearch8.x以上版本是自动开启安全认证的。kibana安装在windows上一般是zip文件,解压到对应目录。elasticsearch的默认端口是9200,访问。默认用户是elastic,密码需要重置。
5651 0
|
存储 运维 监控
金融场景 PB 级大规模日志平台:中信银行信用卡中心从 Elasticsearch 到 Apache Doris 的先进实践
中信银行信用卡中心每日新增日志数据 140 亿条(80TB),全量归档日志量超 40PB,早期基于 Elasticsearch 构建的日志云平台,面临存储成本高、实时写入性能差、文本检索慢以及日志分析能力不足等问题。因此使用 Apache Doris 替换 Elasticsearch,实现资源投入降低 50%、查询速度提升 2~4 倍,同时显著提高了运维效率。
1008 3
金融场景 PB 级大规模日志平台:中信银行信用卡中心从 Elasticsearch 到 Apache Doris 的先进实践
|
存储 运维 NoSQL
【赵渝强老师】Redis的慢查询日志
Redis慢查询日志用于记录执行时间超过预设阈值的命令,帮助开发和运维人员定位性能问题。每条慢查询日志包含标识ID、发生时间戳、命令耗时及详细信息。配置参数包括`slowlog-max-len`(默认128)和`slowlog-log-slower-than`(默认10000微秒)。实战中可通过`slowlog get`获取日志、`slowlog len`查看长度、`slowlog reset`重置日志。建议线上环境将`slowlog-max-len`设为1000以上,并根据并发量调整`slowlog-log-slower-than`。需要注意的是,慢查询只记录命令执行时间。
679 5
|
存储 机器学习/深度学习 人工智能
Elasticsearch:使用阿里云 AI 服务进行向量化和重新排名
本文介绍了如何将阿里云 AI 功能与 Elasticsearch 集成,以提高语义搜索的相关性。
805 0
|
存储 弹性计算 运维
海量日志接入 Elasticsearch Serverless 应用降本70%以上
本文将探讨在日志场景下,使用阿里云Elasticsearch Serverless相较于基于ECS自建Elasticsearch集群的成本与性能优势,展示如何通过Serverless架构实现高达 70%以上的成本节约。
819 0
ELK 圣经:Elasticsearch、Logstash、Kibana 从入门到精通
ELK是一套强大的日志管理和分析工具,广泛应用于日志监控、故障排查、业务分析等场景。本文档将详细介绍ELK的各个组件及其配置方法,帮助读者从零开始掌握ELK的使用。
|
存储 SQL 监控
|
自然语言处理 监控 数据可视化
|
存储 监控 安全

热门文章

最新文章

下一篇
开通oss服务