博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
3、zabbix_get和zabbix_sender命令的使用
阅读量:6045 次
发布时间:2019-06-20

本文共 5413 字,大约阅读时间需要 18 分钟。

Zabbix_get命令:


zabbix_get是zabbix中的一个程序,用于zabbix-server到zabbix-agent获取数据。通常用来检测agent的配置是否正确。

1
2
3
4
5
6
7
8
9
10
11
[root@localhost ~]
# zabbix_get -h
Zabbix get v2.2.11 (revision 56693) (12 November 2015)
usage: zabbix_get [-hV] -s <host name or IP> [-p <port>] [-I <IP address>] -k <key>
Options:
  
-s --host <host name or IP>          Specify host name or IP address of a host
  
-p --port <port number>              Specify port number of agent running on the host. Default is 10050
  
-I --
source
-address <IP address>     Specify 
source 
IP address
  
-k --key <key of metric>             Specify key of item to retrieve value 
for
  
-h --help                            Give this help
  
-V --version                         Display version number
Example: zabbix_get -s 127.0.0.1 -p 10050 -k 
"system.cpu.load[all,avg1]"

参数说明:

-s --host: 指定客户端主机名或者IP

-p --port:客户端端口,默认10050

-I --source-address:指定源IP,写上zabbix server的ip地址即可,一般留空,服务器如果有多ip的时候,你指定一个。

-k --key:你想获取的key

至于使用长参数还是短的,自己选,我经常使用-s而不是--host,太长了。


获取CPU负载

1
2
[root@localhost ~]
# zabbix_get -s 127.0.0.1 -p 10050 -k "system.cpu.load[all,avg15]"
0.000000

key可以加引号,也可以不加。

获取主机名

1
2
[root@localhost ~]
# zabbix_get -s 127.0.0.1 -p 10050 -k system.hostname
localhost.localdomain

Zabbix_sender命令:

zabbix_sender是什么?有什么作用?

zabbix获取key值有超时时间,如果自定义的key脚本一般需要执行很长时间,这根本没法去做监控,那怎么办呢?使用zabbix监控类型zabbix trapper,需要配合zabbix_sender给它传递数据。关于trapper的用法,我们来弄个实例。

执行超长时间脚本,如:脚本去几十台服务器拉去数据,每个日志都上G,然后日志整合在一起,统计出返回值。这种脚本比如超时,所以我们必须改成让客户端提交数据的方式。


zabbix_sender命令用法:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
[root@localhost ~]
# zabbix_sender -h
Zabbix Sender v2.2.11 (revision 56693) (12 November 2015)
usage: zabbix_sender [-Vhv] {[-zpsI] -ko | [-zpI] -T -i <
file
> -r} [-c <
file
>]
Options:
  
-c --config <
file
>                   Absolute path to the configuration 
file
  
-z --zabbix-server <server>          Hostname or IP address of Zabbix server
  
-p --port <server port>              Specify port number of server trapper running on the server. Default is 10051
  
-s --host <
hostname
>                 Specify host name. Host IP address and DNS name will not work
  
-I --
source
-address <IP address>     Specify 
source 
IP address
  
-k --key <key> 
                       
Specify item key
  
-o --value <key value>               Specify value
  
-i --input-
file 
<input 
file
>         Load values from input 
file
. Specify - 
for 
standard input
                                       
Each line of 
file 
contains whitespace delimited: <
hostname
> <key> <value>
                                       
Specify - 
in 
<
hostname
> to use 
hostname 
from configuration 
file 
or --host argument
  
-T --with-timestamps                 Each line of 
file 
contains whitespace delimited: <
hostname
> <key> <timestamp> <value>
                                       
This can be used with --input-
file 
option
                                       
Timestamp should be specified 
in 
Unix timestamp 
format
  
-r --real-
time                       
Send metrics one by one as soon as they are received
                                       
This can be used when reading from standard input
  
-
v 
--verbose                         Verbose mode, -vv 
for 
more 
details
Other options:
  
-h --help                            Give this help
  
-V --version                         Display version number

使用参数:

1
2
3
4
5
6
7
8
9
10
11
  
-c --config <
file
>                   配置文件绝对路径
  
-z --zabbix-server <server>          zabbix server的IP地址
  
-p --port <server port>              zabbix server端口.默认10051
  
-s --host <
hostname
>                 主机名,zabbix里面配置的主机名(不是服务器的
hostname
),不能使用ip地址
  
-I --
source
-address <IP address>     源IP
  
-k --key <key>                       监控项的key
  
-o --value <key value>               key值
  
-i --input-
file 
<input 
file
>         从文件里面读取
hostname
、key、value 一行为一条数据,使用空格作为分隔符,如果主机名带空格,那么请使用双引号包起来
  
-T --with-timestamps              一行一条数据,空格作为分隔符: <
hostname
> <key> <timestamp> <value>,配合 --input-
file 
option,timestamp为unix时间戳
  
-r --real-
time                      
将数据实时提交给服务器
  
-
v 
--verbose                         详细模式, -vv 更详细

Zabbix_sender使用实例:

先在主机zabbix server 上创建一个key。

传递一个数据到item中,注意-s后面为zabbix_agent.conf文件中配置的hostname,不是IP地址,也不是服务器的主机名。

1
2
3
[root@ZabbixServer alertscripts]
# zabbix_sender -s "ZabbixServer" -z 127.0.0.1 -k "key.test.trapper" -o 1 -r
info from server: 
"processed: 1; failed: 0; total: 1; seconds spent: 0.000034"
sent: 1; skipped: 0; total: 1

failed为0,表示传送失败的为0个。

zabbix_sender还可以批量上传数据,即将服务器的hostname(zabbix_agent.conf文件中配置的主机名)、key、value三个值保存到文件中,然后将该文件中的数据上传到各个item中。


zabbix_sender批量传递key值

1
2
3
4
5
6
7
8
9
#cat f.txt
"Zabbix server" 
ttlsa.trapper 10
"Zabbix server" 
ttlsa.trapper 20
"Zabbix server" 
ttlsa.trapper 30
"Zabbix server" 
ttlsa.trapper 40
"Zabbix server" 
ttlsa.trapper 1
# ./zabbix_sender -z 127.0.0.1 -i f.txt 
info from server: 
"processed: 5; failed: 0; total: 5; seconds spent: 0.000085"
sent: 5; skipped: 0; total: 5

每行对应一个key值,一般是相同的主机名、不同的key、不同的key值。这边方便测试,所以都用了同一个key

这种方式也是zabbix trapper监控方式的模型。

Zabbix Trapper监控案例演示

创建两个监控项,monitor[TotalMemory]和monitor[FreeMemory],分别用来监控总内存和剩余内存。

监控脚本如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#!/bin/bash
hostname
=$1
zabbix_server_ip=172.16.206.130
TotalMemory()
{
    
TotalMemory=`
cat 
/proc/meminfo 
awk 
'/^MemTotal:/{print $2}'
`
    
echo 
"$hostname monitor[TotalMemory] $TotalMemory" 
}
FreeMemory()
{
    
FreeMemory=`
cat 
/proc/meminfo 
awk 
'/^MemFree:/{print $2}'
`
    
echo 
"$hostname monitor[FreeMemory] $FreeMemory"
}
TotalMemory >> 
/tmp/test
.txt
FreeMemory >> 
/tmp/test
.txt
zabbix_sender -z $zabbix_server_ip -i 
/tmp/test
.txt &>
/dev/null
if 
[ `
echo 
$?` -
eq 
0 ];
then
    
echo 
0
else
    
echo 
1
fi
rm 
-rf 
/tmp/test
.txt

注意:脚本最后一行是当数据上传完成后删除保存数据的文件,这样下次执行脚本时保证不会有相同的key对应多个value。

zabbix web上创建对应的item

注意:上面我们创建了item,也创建了获取item值的脚本。但是这个脚本不会自动执行,将数据传送到zabbix server上。所以我们还需要再创建一个监控项,这个监控项会定时执行我们创建的脚本。

创建自定义监控的conf文件

1
2
[root@ZabbixServer zabbix_agentd.d]
# vim userparameter_memory.conf
UserParameter=send.
date
[*],
/etc/zabbix/scripts/memory
.monitor.sh $1

zabbix server上创建监控项:

本文转自 曾哥最爱 51CTO博客,原文链接:http://blog.51cto.com/zengestudy/1788297,如需转载请自行联系原作者
你可能感兴趣的文章
数据存储小例
查看>>
C++中构造函数详解
查看>>
电商网站中添加商品到购物车功能模块2017.12.8
查看>>
android 模拟器 hardWare 属性说明
查看>>
六款值得推荐的android(安卓)开源框架简介
查看>>
max_element( )
查看>>
java中的类
查看>>
pthread_create线程创建的过程剖析(转)
查看>>
android存储访问框架Storage Access Framework
查看>>
Mysql C API调用存储过程的总结
查看>>
Oracle的层次查询
查看>>
远程调用服务(RPC)和消息(Message Queue)对比及其适用/不适用场合
查看>>
FreeBSD 的 Ports 系统
查看>>
有关web
查看>>
读Nginx官方文档笔记
查看>>
Spring中用了哪些设计模式?
查看>>
存储问题
查看>>
转: jquery中ajax回调函数使用this
查看>>
我的Java开发学习之旅------>Java 格式化类(java.util.Formatter)基本用法
查看>>
我的Android进阶之旅------>adbd cannot run as root in production builds 的解决方法
查看>>