使用zabbix監控TCP鏈接狀態

一 監控原理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監控模板

模板參考附件

wKiom1SALq2D2nPrAASKSE5wnZA348.jpg

wKioL1SALzuwlyepAAQkGiPjhYU442.jpg

相關文章
相關標籤/搜索