电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

詳解Linux使用ss命令結合zabbix對socket做監控

瀏覽:187日期:2024-09-24 17:45:09
目錄前言一、ss命令二、zabbix監控機器總體的socket情況2.1、寫腳本2.2、配置zabbix agent的配置文件2.3、配置zabbix的模板三、zabbix監控機器來源于各個機器的請求數3.1、寫腳本3.2、配置zabbix_agent.conf文件3.3、配置Discovery,配置item,trigger,graph前言

這里我們使用zabbix對其進行監控,使用的是ss命令,不使用netstat命令,因為ss的速度快很多,不信的話可以去測一下哈,一臺機器的socket越多,對比越明顯。而且ss命令能顯示更多的內容,其實我對這兩個命令不是特別的熟悉,通過man ss可以看到:

詳解Linux使用ss命令結合zabbix對socket做監控

一、ss命令

ss命令用于顯示socket狀態. 他可以顯示PACKET sockets, TCP sockets, UDP sockets, DCCP sockets, RAW sockets, Unix domain sockets等等統計. 它比其他工具展示等多tcp和state信息. 它是一個非常實用、快速、有效的跟蹤IP連接和sockets的新工具.SS命令可以提供如下信息:

所有的TCP sockets 所有的UDP sockets 所有ssh/ftp/ttp/https持久連接 所有連接到Xserver的本地進程 使用state(例如:connected, synchronized, SYN-RECV, SYN-SENT,TIME-WAIT)、地址、端口過濾 所有的state FIN-WAIT-1 tcpsocket連接以及更多

很多流行的Linux發行版都支持ss以及很多監控工具使用ss命令.熟悉這個工具有助于您更好的發現與解決系統性能問題.本人強烈建議使用ss命令替代netstat部分命令,例如netsat -ant/lnt等

直接ss命令

詳解Linux使用ss命令結合zabbix對socket做監控

對上面解釋一波:

Netid #socket類型,在上面的例子中,有 TCP、u_str(unix流)等套接字State #套接字處于什么狀態,下面是TCP套接字的所有狀態及說明, 實際上就是TCP的三次握手和四次揮手的所有狀態Recv-Q #在 ESTAB 狀態下,表示內核中還有多少字節的數據沒有被上層應用讀取,如果這里數值很大,應用程序可能發生了阻塞Send-Q #在 ESTAB 狀態下,表示內核發送隊列中還有多少字節的數據沒有收到確認的ACK,如果這個數值很大,表明接收端的接收以及處理需要加強Local Address:Port #本地地址和端口Peer Address:Port #遠程地址和端口

然后我們接著看上面的state有哪些呢,如果特別熟悉網絡的人應該很懂,至少我現在是不是特別熟悉,三次握手和四次揮手的狀態:

LISTEN #服務端偵聽套接字等待客戶端的連接SYN-SENT #客戶端已發送套接字連接請求報文,等待連接被服務器接收SYN-RECEIVED #服務器端接收連接請求報文后,等待客戶端的確認連接的回復報文ESTABLISHED #服務端和客戶端之間成功建立了一條有效的連接,可以互相傳輸數據FIN-WAIT-1 #服務器或客戶端調用close函數主動向對方發出終止連接的請求報文,同時等待對方確認終止連接的回復報文FIN-WAIT-2 #主動關閉連接端收到對方確認終止連接的回復報文,同時等待對方連接終止的請求報文,這時的狀態是TCP連接的半關閉狀態,可以接受數據,但是不能發送數據CLOSE-WAIT #被動關閉端收到主動關閉端終止連接的請求報文后,向主動關閉端發送確認終止連接的回復報文,同時被動關閉端等待本地用戶終止連接,這時被動關閉端的狀態是TCP連接的半關閉狀態,可以發送數據,但是不能接收數據CLOSING #服務器和客戶端同時向對方發送終止連接(調用close函數)請求報文,并且雙方都是在收到對方發送的終止連接回復報文之前收到了對方的發送的終止連接請求報文,這個時候雙方都進入了CLOSING狀態,進入CLOSING狀態之后,只要收到了對方對自己終止連接的回復報文,就會進入TIME-WAIT狀態,所以CLOSING狀態的持續時間會特別短,一般很難捕獲到LAST-ACK #被動關閉端發送完全部數據之后,向主動關閉端發送終止連接的請求報文,等待主動關閉端發送終止連接的回復報文TIME-WAIT #主動關閉端收到被動關閉端終止連接的請求報文后,給被動關閉端發送終止連接的回復報文,等待足夠時間以確保被動關閉端收到了主動關閉段發送的終止連接的回復報文CLOSED #完全沒有連接,套接字連接已經終止了

那么這些狀態ss命令又怎么對應呢?(后面的是ss命令顯示的狀態信息)

[TCP_ESTABLISHED] = 'ESTAB',[TCP_SYN_SENT] = 'SYN-SENT',[TCP_SYN_RECV] = 'SYN-RECV',[TCP_FIN_WAIT1] = 'FIN-WAIT-1',[TCP_FIN_WAIT2] = 'FIN-WAIT-2',[TCP_TIME_WAIT] = 'TIME-WAIT',[TCP_CLOSE] = 'UNCONN',[TCP_CLOSE_WAIT] = 'CLOSE-WAIT',[TCP_LAST_ACK] = 'LAST-ACK',[TCP_LISTEN] = 'LISTEN',[TCP_CLOSING] = 'CLOSING',

江到這里其實就可以去做下面的監控了,繼續往下看ss命令的使用。

Usage: ss [ OPTIONS ]

       ss [ OPTIONS ] [ FILTER ]

-h, --help 幫助信息-V, --version 程序版本信息-n, --numeric 不解析服務名稱-r, --resolve 解析主機名-a, --all 顯示所有套接字(sockets)-l, --listening 顯示監聽狀態的套接字(sockets)-o, --options 顯示計時器信息-e, --extended 顯示詳細的套接字(sockets)信息-m, --memory 顯示套接字(socket)的內存使用情況-p, --processes 顯示使用套接字(socket)的進程-i, --info 顯示 TCP內部信息-s, --summary 顯示套接字(socket)使用概況-4, --ipv4 僅顯示IPv4的套接字(sockets)-6, --ipv6 僅顯示IPv6的套接字(sockets)-0, --packet 顯示 PACKET 套接字(socket)-t, --tcp 僅顯示 TCP套接字(sockets)-u, --udp 僅顯示 UCP套接字(sockets)-d, --dccp 僅顯示 DCCP套接字(sockets)-w, --raw 僅顯示 RAW套接字(sockets)-x, --unix 僅顯示 Unix套接字(sockets)-f, --family=FAMILY 顯示 FAMILY類型的套接字(sockets),FAMILY可選,支持 unix, inet, inet6, link, netlink-A, --query=QUERY, --socket=QUERYQUERY := {all|inet|tcp|udp|raw|unix|packet|netlink}[,QUERY]-D, --diag=FILE 將原始TCP套接字(sockets)信息轉儲到文件-F, --filter=FILE 從文件中都去過濾器信息FILTER := [ state TCP-STATE ] [ EXPRESSION ]

重點在下面的監控

二、zabbix監控機器總體的socket情況

做這個監控前可以熟悉下awk命令

這是使用的監控系統為zabbix,我們這里會結合zabbix的模板(這里選擇模板是為了后期拓展),和自定義腳本的方式進行監控。

2.1、寫腳本

二話不多說上腳本先:

vim tcp_status.sh#################腳本內容##################!/bin/bashif [ $# -ne 1 ];then echo 'Follow the script name with an argument 'ficase $1 in LISTEN)result=`ss -ant | awk ’NR>1 {a[$1]++} END {for (b in a) print b,a[b]}’ | awk ’/LISTEN/{print $2}’`if [ '$result' == '' ];then echo 0else echo $resultfi;; ESTAB)result=`ss -ant | awk ’NR>1 {a[$1]++} END {for (b in a) print b,a[b]}’ | awk ’/ESTAB/{print $2}’`if [ '$result' == '' ];then echo 0else echo $resultfi;; CLOSE-WAIT)result=`ss -ant | awk ’NR>1 {a[$1]++} END {for (b in a) print b,a[b]}’ | awk ’/CLOSE-WAIT/{print $2}’`if [ '$result' == '' ];then echo 0else echo $resultfi;; TIME-WAIT)result=`ss -ant | awk ’NR>1 {a[$1]++} END {for (b in a) print b,a[b]}’ | awk ’/TIME-WAIT/{print $2}’`if [ '$result' == '' ];then echo 0else echo $resultfi;; SYN-SENT)result=`ss -ant | awk ’NR>1 {a[$1]++} END {for (b in a) print b,a[b]}’ | awk ’/SYN-SENT/{print $2}’`if [ '$result' == '' ];then echo 0else echo $resultfi;; SYN-RECV)result=`ss -ant | awk ’NR>1 {a[$1]++} END {for (b in a) print b,a[b]}’ | awk ’/SYN-RECV/{print $2}’`if [ '$result' == '' ];then echo 0else echo $resultfi;; FIN-WAIT-1)result=`ss -ant | awk ’NR>1 {a[$1]++} END {for (b in a) print b,a[b]}’ | awk ’/FIN-WAIT-1/{print $2}’`if [ '$result' == '' ];then echo 0else echo $resultfi;; FIN-WAIT-2)result=`ss -ant | awk ’NR>1 {a[$1]++} END {for (b in a) print b,a[b]}’ | awk ’/FIN-WAIT-2/{print $2}’`if [ '$result' == '' ];then echo 0else echo $resultfi;; UNCONN)result=`ss -ant | awk ’NR>1 {a[$1]++} END {for (b in a) print b,a[b]}’ | awk ’/UNCONN/{print $2}’`if [ '$result' == '' ];then echo 0else echo $resultfi;; LAST-ACK)result=`ss -ant | awk ’NR>1 {a[$1]++} END {for (b in a) print b,a[b]}’ | awk ’/LAST-ACK/{print $2}’`if [ '$result' == '' ];then echo 0else echo $resultfi;; CLOSING)result=`ss -ant | awk ’NR>1 {a[$1]++} END {for (b in a) print b,a[b]}’ | awk ’/CLOSING/{print $2}’`if [ '$result' == '' ];then echo 0else echo $resultfi;; esac2.2、配置zabbix agent的配置文件

vim zabbix_agent.conf##############添加如下內容#################UnsafeUserParameters=1 #這個參數是自定義腳本需要配置的UserParameter=tcp.status[*],sh /home/zabbix/tcp_status.sh $1 #這里就是用來指定剛剛寫的腳本,后面傳一個參數

配置好了以后記得重啟zabbix agent

2.3、配置zabbix的模板

往其中添加item,trigger,graph

新增模板,然后往其中添加item,如下圖所示

詳解Linux使用ss命令結合zabbix對socket做監控

上圖中key中的tcp.status指的是剛剛在第二步中的配置UserParameter=tcp.status[*],sh /home/zabbix/tcp_status.sh $1

然后中括號里面的內容就是$1進行傳參的參數,具體的參數就是[UNCONN]里面的UNCONN,這些值對應第一步監控腳本中的case中的每一種情況,到這里基本上完成了,不,還是畫個圖吧,在模板中添加graph,如下圖所示:

詳解Linux使用ss命令結合zabbix對socket做監控

還有最重要的一步就是把配置好監控腳本的(第一步)的主機添加到該模板,到此為止這個監控就做完了,看個結果圖吧

詳解Linux使用ss命令結合zabbix對socket做監控

三、zabbix監控機器來源于各個機器的請求數

這個監控的目的就是看看到底是哪些機器訪問目標機器比較頻繁。

這個監控采用自發現的監控,比上面那個會難一點哈,為啥要選擇自發現的監控呢,因為item不是確定的,這里選擇:原地址ip和目的ip地址作為item,我們在目的ip地址進行監控,這個是不變的,所以原地址ip值會發生變化,所以這里采用的是自動生成item的方式進行監控,自動添加和刪除item,其實挺好用的,只要學會了,超級簡單

這里也是分為三步,寫腳本,配置zabbix_agent.conf文件,配置Discovery

3.1、寫腳本

這里需要兩個腳本,一個用來做自發現(需要輸出json格式),一個用來做item的)

vim tcp_monitory.sh##################tcp_monitor.sh###################!/bin/bash#獲取數據輸出到data.txt文件中,格式為:原地址ip:count:目標地址ip#并且過濾掉count小于200的數據,這里沒有分socket的狀態,眉毛胡子一把抓了,個人可以根據具體的需求改進ip_addr=`ip addr | grep -w inet | grep -v '127.0.0.1' | awk ’{print $2}’| awk -F '/' ’{print $1}’`ss -ant | awk ’{ print $5}’|grep -Ev ’127.0.0.1’ | cut -d ’:’ -f4 | awk -v ip_addr=$ip_addr ’NR>1 {++s[$1]} END {for(k in s)if(s[k]>=200){print k,s[k],ip_addr}}’ | grep -E '^([0-9]{1,3}.){3}[0-9]' > /home/zabbix/data.txt#執行Python腳本,這是為了輸出json格式,python /home/zabbix/get_json.py######################################如下是get_json.py的內容##############get_json.py#################!/usr/bin/env python#coding=utf-8import jsondef create_json(path): json_list = [] with open(path) as f:for line in f.readlines(): dict = {} split = line.split(' ') dict['{#DES_IP}'] = split[0] //dict['{#LINK_COUNT}'] = split[1] //這個是可以不要的 dict['{#SOU_IP}'] = split[2][:-1] json_list.append(dict) sum = {} sum['data'] = json_list sum = json.dumps(sum) print sumif __name__ == ’__main__’: path = '/home/zabbix/data.txt' create_json(path)##############分割線:上面的是自發現的腳本#############################分割線:下面的是item相關腳本###############vim tcp_item.sh##################tcp_item.sh#####################!/bin/bashexport LANG='en_US.UTF-8'path=/home/zabbix/data.txtcount=`cat $path | grep $1 | grep $2 | awk ’{print $2}’`[ 1'$count' -eq 1 ] && echo 0 || echo $count

兩個腳本都搞定了,就可以進行zabbix_agent.conf的配置了

3.2、配置zabbix_agent.conf文件

在配置文件中新增如下內容:

UnsafeUserParameters=1 #如果已經配置就不需要配置了UserParameter=discovery.tcp_monitor[*],sh /home/zabbix/tcp_monitor.sh #自發現UserParameter=alert.tcp_count[*],sh /home/zabbix/tcp_item.sh $1 $2 #item,其中$1,$2為item中的傳遞參數,用來區別item的不同3.3、配置Discovery,配置item,trigger,graph

這里還是選擇在zabbix的模板上進行配置,現在新增一個Discovery

詳解Linux使用ss命令結合zabbix對socket做監控

然后在Discovery上配置item,trigger,graph

詳解Linux使用ss命令結合zabbix對socket做監控

配置item:

詳解Linux使用ss命令結合zabbix對socket做監控

上面的DES_IP,SOU_IP來源于自發現腳本中的Python腳本,用于輸出的格式。alter.tcp_count是UserParameter=alert.tcp_count[*],sh /home/zabbix/tcp_item.sh $1 $2,后面的$1,$2與DES_IP,SOU_IP相對應生成唯一確定的item。

item配置完畢后就可以配置trigger了:

詳解Linux使用ss命令結合zabbix對socket做監控

接下來繼續配置graph了

詳解Linux使用ss命令結合zabbix對socket做監控

最后把模板添加到機器,然后看結果

詳解Linux使用ss命令結合zabbix對socket做監控

以上就是詳解Linux使用ss命令結合zabbix對socket做監控的詳細內容,更多關于Linux ss命令 zabbix socket監控的資料請關注好吧啦網其它相關文章!

標簽: Linux系統
相關文章:
主站蜘蛛池模板: 防水套管厂家-柔性防水套管-不锈钢|刚性防水套管-天翔管道 | 清洁设备_洗地机/扫地机厂家_全自动洗地机_橙犀清洁设备官网 | 层流手术室净化装修-检验科ICU改造施工-华锐净化工程-特殊科室建设厂家 | 质检报告_CE认证_FCC认证_SRRC认证_PSE认证_第三方检测机构-深圳市环测威检测技术有限公司 | 外贮压-柜式-悬挂式-七氟丙烷-灭火器-灭火系统-药剂-价格-厂家-IG541-混合气体-贮压-非贮压-超细干粉-自动-灭火装置-气体灭火设备-探火管灭火厂家-东莞汇建消防科技有限公司 | 酒店品牌设计-酒店vi设计-酒店标识设计【国际级】VI策划公司 | 代写标书-专业代做标书-商业计划书代写「深圳卓越创兴公司」 | 油冷式_微型_TDY电动滚筒_外装_外置式电动滚筒厂家-淄博秉泓机械有限公司 | 【铜排折弯机,钢丝折弯成型机,汽车发泡钢丝折弯机,线材折弯机厂家,线材成型机,铁线折弯机】贝朗折弯机厂家_东莞市贝朗自动化设备有限公司 | 土壤检测仪器_行星式球磨仪_土壤团粒分析仪厂家_山东莱恩德智能科技有限公司 | 北京办公室装修,办公室设计,写字楼装修-北京金视觉装饰工程公司 北京成考网-北京成人高考网 | 微水泥_硅藻泥_艺术涂料_艺术漆_艺术漆加盟-青岛泥之韵环保壁材 武汉EPS线条_EPS装饰线条_EPS构件_湖北博欧EPS线条厂家 | VI设计-LOGO设计公司-品牌设计公司-包装设计公司-导视设计-杭州易象设计 | 佛山市钱丰金属不锈钢蜂窝板定制厂家|不锈钢装饰线条|不锈钢屏风| 电梯装饰板|不锈钢蜂窝板不锈钢工艺板材厂家佛山市钱丰金属制品有限公司 | 高压互感器,电流互感器,电压互感器-上海鄂互电气科技有限公司 | 气动绞车,山东气动绞车,气动绞车厂家-烟台博海石油机械有限公司 气动隔膜泵厂家-温州永嘉定远泵阀有限公司 | 无锡网站建设-做网站-建网站-网页设计制作-阿凡达建站公司 | 流量检测仪-气密性检测装置-密封性试验仪-东莞市奥图自动化科技有限公司 | 粉丝机械,粉丝烘干机,粉丝生产线-招远市远东粉丝机械有限公司 | 亿立分板机_曲线_锯片式_走刀_在线式全自动_铣刀_在线V槽分板机-杭州亿协智能装备有限公司 | MVE振动电机_MVE震动电机_MVE卧式振打电机-河南新乡德诚生产厂家 | 辊道窑炉,辊道窑炉厂家-山东艾希尔| 高压直流电源_特种变压器_变压器铁芯-希恩变压器定制厂家 | 抖音短视频运营_企业网站建设_网络推广_全网自媒体营销-东莞市凌天信息科技有限公司 | 热缩管切管机-超声波切带机-织带切带机-无纺布切布机-深圳市宸兴业科技有限公司 | 智能门锁电机_智能门锁离合器_智能门锁电机厂家-温州劲力智能科技有限公司 | 附着力促进剂-尼龙处理剂-PP处理剂-金属附着力处理剂-东莞市炅盛塑胶科技有限公司 | 代办建筑资质升级-建筑资质延期就找上海国信启航 | PU树脂_水性聚氨酯树脂_聚氨酯固化剂_聚氨酯树脂厂家_宝景化工 | 电伴热系统施工_仪表电伴热保温箱厂家_沃安电伴热管缆工业技术(济南)有限公司 | 中天寰创-内蒙古钢结构厂家|门式刚架|钢结构桁架|钢结构框架|包头钢结构煤棚 | 大通天成企业资质代办_承装修试电力设施许可证_增值电信业务经营许可证_无人机运营合格证_广播电视节目制作许可证 | 智能汉显全自动量热仪_微机全自动胶质层指数测定仪-鹤壁市科达仪器仪表有限公司 | 硫酸亚铁-聚合硫酸铁-除氟除磷剂-复合碳源-污水处理药剂厂家—长隆科技 | 电磁流量计_智能防腐防爆管道式计量表-金湖凯铭仪表有限公司 | 哈希余氯测定仪,分光光度计,ph在线监测仪,浊度测定仪,试剂-上海京灿精密机械有限公司 | 臭氧灭菌箱-油桶加热箱-原料桶加热融化烘箱-南京腾阳干燥设备厂 臭氧发生器_臭氧消毒机 - 【同林品牌 实力厂家】 | 压缩空气检测_气体_水质找上海京工-服务专业、价格合理 | 飞象网 - 通信人每天必上的网站 全球化工设备网—化工设备,化工机械,制药设备,环保设备的专业网络市场。 | 三效蒸发器_多效蒸发器价格_四效三效蒸发器厂家-青岛康景辉 | 老房子翻新装修,旧房墙面翻新,房屋防水补漏,厨房卫生间改造,室内装潢装修公司 - 一修房屋快修官网 |