zabbix自定義用戶key

有時我們需要被監控端執行一個zabbix沒有預定義的檢測項,zabbix的用戶自定義參數功能提供了這個方法。我們可以在客戶端配置文件zabbix_angentd.conf裏面配置UserParameter或者在/etc/zabbix/zabbix_agentd.d/目錄下編輯配置文件,其語法相同爲:

UserParameter=key,command

用戶自定義參數包含一個key和一個命令,key必須整個系統唯一,配置好之後,重啓客戶端;

然後配置item,在key的位置填上我們自定義的key即可。

用戶自定義參數裏指定的腳本由zabbix agent來執行,最大可以返回512KB的數據


簡單點的命令示例:
UserParameter=ping,echo 1
如果調用ping這個key,將會收到返回值1.
更復雜的命令示例:
UserParameter=mysql.ping,mysqladmin -uroot ping|grep -c alive
如果返回1表示MySQL運行中,如果返回0表示MySQL掛了


如下爲靈活的用戶自定義參數

UserParameter=key[*],command

key        唯一. [*]表示裏面可以傳遞多個參數

command    需要執行的腳本,key的[]裏面的參數一一對應$1到$9,一共9個參數。$0表示腳本命令


注意:

  1. 如果需要使用命令行裏面出現$2這種變量,那麼你要使用兩個$$2,例如awk ’{ print $$2 }’,之前就遇到過這個問題,不停的測試自己腳本輸出正常,但是zabbix卻拿不到數據,原來是出在這裏。爲了防止和參數衝突,所以zabbix做了這 個規定。

  2. zabbix禁止使用一些不安全的參數,如下:
        \ ' ” ` * ? [ ] { } ~ $ ! & ; ( ) < > | # @

  3. 從zabbix 2.0開始,zabbix返回文本數據可以是空格


例一:

UserParameter=ping[*],echo $1
ping[0] - 將一直返回0
ping[aaa] - 將一直返回 'aaa'


例二:

UserParameter=mysql.ping[*],mysqladmin -u$1 -p$2 ping | grep -c alive
如下參數用於監控MYSQL,並且可以傳遞用戶名和密碼。
mysql.ping[zabbix,our_password]


例三:

統計一個文件中有多少行被匹配?
UserParameter=wc[*],grep -c "$2" $1
如下方法將會返回文件中出現指定字符的行數
wc[/etc/passwd,root]
wc[/etc/services,zabbix]


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章