简单使用packetbeat

本文涉及的产品
检索分析服务 Elasticsearch 版,2核4GB开发者规格 1个月
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云数据库 MongoDB,通用型 2核4GB
简介:

在前面两篇文章中记录了使用logstash来收集mysql的慢查询日志,然后通过kibanaweb的方式展示出来,但在生产环境中,需求会更复杂一些,而且通过logstash写正则,实在是个费时费劲的事。例如在生产环境中会有要求分析某个时间段mysql或者mongodb的慢查询日志情况;还有I/O吞吐量;这个时间段内经常执行的查询语句,http访问情况等信息;然后将分析出来的结果以图表的形式展现出来。听起来是不是有点头晕,有点高大上的感觉,其实通过packetbeat,一切将变得简单高效。本文介绍使用packetbeatelasticsearch,kibana实现这个需求。

 

操作系统版本:centos6.6 64bit

Elasticsearch版本:elasticsearch-2.1.0.tar.gz

Kibana版本:Kibana 4.2.1

Packetbeat版本:packetbeat-1.0.0-1.x86_64

Topbeat版本:topbeat-1.0.0-x86_64 topbeat其实是用来收集操作系统信息的)

 

在前两篇文章中未介绍如果安装elasticsearch和kibana,这个其实很简单,基本下载下来解压一下,稍微修改一下配置文件即可运行起来,所有就忽略了,如果有问题,可以自行百度或者bing一下。

目前packetbeat支持的网络协议有http,mysql,postgresql,redis,mongodbthriftPacketet支持pcappf_ring抓包方式,采用哪种方式进行抓包,则需要安装相应的依赖包。

 

一:下载并安装packetbeat

1
2
3
# yum -y install libpcap
# rpm -ivh https://download.elastic.co/beats/packetbeat/packetbeat-1.0.0-x86_64.rpm
# rpm -ivh https://download.elastic.co/beats/topbeat/topbeat-1.0.0-x86_64.rpm

二:向elasticsearch导入packetbeat模板

1
2
# curl -XPUT 
'http://192.168.1.226:9200/_template/packetbeat' -d@/etc/packetbeat/packetbeat.template.json

三:修改packetbeat配置文件

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
38
39
40
41
42
43
44
45
# cat /etc/packetbeat/packetbeat.yml  --server15
shipper:
  name: server15
  tags: ["server15"]
interfaces:
   device: any
   type: pcap
   buffer_size_mb: 100
protocols:
   mysql:
     ports: [3306]
output:
   elasticsearch:
     host: 192.168.1.207
     port: 9200
enabled: true
  
# cat /etc/packetbeat/packetbeat.yml  --server226
shipper:
  name: server226
  tags: ["server226"]
interfaces:
   device: eth0
   type: pcap
   buffer_size_mb: 100
  
protocols:  
   mongodb:
     ports: [37017, 38017]
     send_request: true     # index the request payload
     send_response: true    # index the response payload
     max_docs: 10           # maximum number of documents to index per request/response
     max_doc_length: 1024   # maximum document size to index
protocols:
  mysql:
     ports: [3306]
protocols:
  redis:
     ports: [6379]
  
output:
   elasticsearch:
     enabled: true
     host: 192.168.1.207
     port: 9200

四:启动packetbeat服务

1
# /etc/init.d/packetbeat start

五:导入packetbeat-dashboards

1
2
3
# git clone https://github.com/elastic/packetbeat-dashboards
# cd packetbeat-dashboards
# sh load.sh -url http://192.168.1.207:9200

六:web展示

1: 配置索引,这个在执行完load.sh脚本之后,索引会自动创建

wKiom1ZuiQ_wSfvGAACffDA-MDM552.png

2: 查看客户端的数据推送情况

wKiom1ZuiTnDruz2AADq8GDSF-E663.png

3: 查看导入的面板,可视化视图,点击setting-objects

wKioL1ZuiW7jT1nlAABr3Brl0hc212.png

4: 图形展示,点击dashboard-load save dashboards

wKioL1ZuiZySBukgAABD8K7ZGHQ261.png

Mysql情况:

wKiom1Zuib3B0N8GAAC-SiDsHqY275.png

在有多台mysql服务的情况下,可以根据tags来区分,在搜索框中输入相应的tag,则只显示对应的数据

wKiom1ZuieKx5OKOAADLhj9NrP8791.png

Mongodb情况

wKiom1ZuigDgzATgAABt0o2Rnfw187.png

汇总情况:

wKiom1ZuihuCI8WaAACjCa0H8Ww300.png

更多数据演示请访问packetbeat demo网址:http://demo.elastic.co/packetbeat/

 

七:故障排错

1: 在测试过程中曾经发现mysql里面的most frequent Mysql queriesslowest mysql queries数据显示不全,像是被截断的样子,排查后发现其实是模板的问题,删除模板后重新导入即可.

wKioL1ZuilehmdvhAACK_2SQDeI261.png

wKiom1ZuilLyFRN8AABmQsQvIVk594.png

1
2
3
4
5
  # curl -XDELETE 'http://192.168.1.207:9200/*'
  # curl -XPUT
  'http://192.168.1.207:9200/_template/packetbeat' -d@/etc/packetbeat/packetbeat.template.json
# cd packetbeat-dashboards
# sh load.sh -url http://192.168.1.207:9200

2: elasticsearch数据维护

搜索数据:(如果你有多个索引,可以把packetbeat-*换成对应的索引名)

1
# curl -XGET 'http://192.168.1.226:9200/packetbeat-*/_search?pretty'

删除数据(如果你有多个索引,可以把packetbeat-*换成对应的索引名)

1
# curl -XDELETE 'http://192.168.1.207:9200/packetbeat-*'
本文转自斩月博客51CTO博客,原文链接http://blog.51cto.com/ylw6006/1722905如需转载请自行联系原作者

ylw6006
相关实践学习
使用阿里云Elasticsearch体验信息检索加速
通过创建登录阿里云Elasticsearch集群,使用DataWorks将MySQL数据同步至Elasticsearch,体验多条件检索效果,简单展示数据同步和信息检索加速的过程和操作。
ElasticSearch 入门精讲
ElasticSearch是一个开源的、基于Lucene的、分布式、高扩展、高实时的搜索与数据分析引擎。根据DB-Engines的排名显示,Elasticsearch是最受欢迎的企业搜索引擎,其次是Apache Solr(也是基于Lucene)。 ElasticSearch的实现原理主要分为以下几个步骤: 用户将数据提交到Elastic Search 数据库中 通过分词控制器去将对应的语句分词,将其权重和分词结果一并存入数据 当用户搜索数据时候,再根据权重将结果排名、打分 将返回结果呈现给用户 Elasticsearch可以用于搜索各种文档。它提供可扩展的搜索,具有接近实时的搜索,并支持多租户。
相关文章
|
4月前
|
存储 关系型数据库 MySQL
packetbeat配置分析
packetbeat配置分析
|
JavaScript
Mac电脑npm:Failed to download repo vuejs-templates/webpack: tunneling socket could not be established,
Mac电脑npm:Failed to download repo vuejs-templates/webpack: tunneling socket could not be established,
82 0
|
前端开发 JavaScript API
【webpack】解决报错:Cannot GET /xxxx
【webpack】解决报错:Cannot GET /xxxx
302 0
【webpack】解决报错:Cannot GET /xxxx
|
前端开发 JavaScript 开发者
webpack-dev-server 的常用命令参数| 学习笔记
快速学习 webpack-dev-server 的常用命令参数
316 0
webpack-dev-server 的常用命令参数| 学习笔记
|
运维 Ubuntu Linux
【iniparser】项目配置工具iniparser的简单使用
【iniparser】项目配置工具iniparser的简单使用
|
Python
configparser 配置文件不再难 | Python 主题月
configparser 配置文件不再难 | Python 主题月
129 0
|
JavaScript 前端开发 开发者
基于webpack的热重载live reload和热更新HMR(中)
在前端应用框架中不管是react还是vue,官方都提供了相应的脚手架方便开发者快速入手,当我们在开发时修改某个js或者css文件时,webpack会自动编译我们的文件,我们刷新浏览器就可以看到编译后的文件。为此我们会想,如果我们修改保存之后,文件被编译、浏览器自动刷新、或者浏览器局部刷新(不刷新整个浏览器),这样的话多好。当然,基于webpack打包工具的相关库已经实现了。下面对此部分流程做简单的分析
|
缓存 前端开发 JavaScript
基于webpack的热重载live reload和热更新HMR(下)
在前端应用框架中不管是react还是vue,官方都提供了相应的脚手架方便开发者快速入手,当我们在开发时修改某个js或者css文件时,webpack会自动编译我们的文件,我们刷新浏览器就可以看到编译后的文件。为此我们会想,如果我们修改保存之后,文件被编译、浏览器自动刷新、或者浏览器局部刷新(不刷新整个浏览器),这样的话多好。当然,基于webpack打包工具的相关库已经实现了。下面对此部分流程做简单的分析
|
前端开发 JavaScript API
基于webpack的热重载live reload和热更新HMR(上)
在前端应用框架中不管是react还是vue,官方都提供了相应的脚手架方便开发者快速入手,当我们在开发时修改某个js或者css文件时,webpack会自动编译我们的文件,我们刷新浏览器就可以看到编译后的文件。为此我们会想,如果我们修改保存之后,文件被编译、浏览器自动刷新、或者浏览器局部刷新(不刷新整个浏览器),这样的话多好。当然,基于webpack打包工具的相关库已经实现了。下面对此部分流程做简单的分析
webpack-cli和它的自定义命令行
今天我要给大家带来webpack-cli的原理浅析和它的自定义命令行工具
344 0