一 監控原理bash
$ /bin/netstat -an|awk '/^tcp/{++S[$NF]}END{for(a in S) print a,S[a]}'服務器
TIME_WAIT 3464併發
FIN_WAIT1 31socket
FIN_WAIT2 3tcp
ESTABLISHED 12ide
SYN_RECV 6測試
CLOSING 8this
LISTEN 7rest
可使用man netstat查看TCP的各類狀態信息描述
blog
ESTABLISHED socket已經創建鏈接
CLOSED socket沒有被使用,無鏈接
CLOSING 服務器端和客戶端都同時關閉鏈接
CLOSE_WAIT 等待關閉鏈接
TIME_WAIT The socket is waiting after close to handle packets still in the network. 表示收到了對方的FIN報文,併發送出了ACK報文,等待2MSL後就可回到CLOSED狀態
LAST_ACK The remote end has shut down, and the socket is closed. Waiting for acknowledgement. 遠端關閉,當前socket被動關閉後發送FIN報文,等待對方ACK報文
LISTEN 監聽狀態
SYN_RECV 接收到SYN報文
SYN_SENT 已經發送SYN報文
FIN_WAIT1 The socket is closed, and the connection is shutting down
FIN_WAIT2 Connection is closed, and the socket is waiting for a shutdown from the remote end.
2.監控腳本編寫
tcp_connection_status.sh
#!/bin/bash #this script is used to get tcp and udp connetion status #tcp status metric=$1 tmp_file=/tmp/tcp_status.txt /bin/netstat -an|awk '/^tcp/{++S[$NF]}END{for(a in S) print a,S[a]}' > $tmp_file case $metric in closed) output=$(awk '/CLOSED/{print $2}' $tmp_file) if [ "$output" == "" ];then echo 0 else echo $output fi ;; listen) output=$(awk '/LISTEN/{print $2}' $tmp_file) if [ "$output" == "" ];then echo 0 else echo $output fi ;; synrecv) output=$(awk '/SYN_RECV/{print $2}' $tmp_file) if [ "$output" == "" ];then echo 0 else echo $output fi ;; synsent) output=$(awk '/SYN_SENT/{print $2}' $tmp_file) if [ "$output" == "" ];then echo 0 else echo $output fi ;; established) output=$(awk '/ESTABLISHED/{print $2}' $tmp_file) if [ "$output" == "" ];then echo 0 else echo $output fi ;; timewait) output=$(awk '/TIME_WAIT/{print $2}' $tmp_file) if [ "$output" == "" ];then echo 0 else echo $output fi ;; closing) output=$(awk '/CLOSING/{print $2}' $tmp_file) if [ "$output" == "" ];then echo 0 else echo $output fi ;; closewait) output=$(awk '/CLOSE_WAIT/{print $2}' $tmp_file) if [ "$output" == "" ];then echo 0 else echo $output fi ;; lastack) output=$(awk '/LAST_ACK/{print $2}' $tmp_file) if [ "$output" == "" ];then echo 0 else echo $output fi ;; finwait1) output=$(awk '/FIN_WAIT1/{print $2}' $tmp_file) if [ "$output" == "" ];then echo 0 else echo $output fi ;; finwait2) output=$(awk '/FIN_WAIT2/{print $2}' $tmp_file) if [ "$output" == "" ];then echo 0 else echo $output fi ;; *) echo -e "\e[033mUsage: sh $0 [closed|closing|closewait|synrecv|synsent|finwait1|finwait2|listen|established|lastack|timewait]\e[0m" esac
3.添加zabbix配置文件
tcp_status.conf
UserParameter=tcp.status[*],/usr/local/zabbix/bin/tcp_connection_status.sh $1
sudo service zabbix-agent restart
4.在master或proxy端使用zabbix_get測試
/usr/local/zabbix/bin/zabbix_get -s 192.168.1.179 -p 10055 -k tcp.status[timewait]
5.添加zabbix監控模板
模板參考附件