埠監控指令碼
對指定的埠列表分別進行監控
說明:
LSNPORTS引數指定要監聽的埠列表,以空格作為分割;
INTERVAL引數指定監控的時間間隔;
LOGPATH引數指定監控日誌存放路徑,如果該路徑不存在,則指令碼會自動新增。
日誌生成方式:按照埠,每個埠生成一個日誌檔案,各自存放。
每次狀態列表生成後都有一個簡單彙總,彙報此次監控所有的埠連線數。
日誌檔案格式:netstat[port]-yyyy-mm-dd.log
日誌檔案內容格式:
DATE:2008-06-23 12:29:01 >> *.8080 *.* 0 0 24576 0 LISTEN
DATE:2008-06-23 12:29:01 >> 218.108.243.67.8080 10.0.16.42.30467 1 0 24840 0 ESTABLISHED
DATE:2008-06-23 12:29:01 >> 218.108.243.67.8080 10.0.19.30.1272 17680 0 25840 0 FIN_WAIT_1
DATE:2008-06-23 12:29:01 >> 218.108.243.67.8080 10.0.31.36.1338 256288 0 24840 0 ESTABLISHED
DATE:2008-06-23 12:29:01 >> 218.108.243.67.8080 10.0.16.42.35565 65535 0 24840 0 ESTABLISHED
DATE:2008-06-23 12:29:01 >> 218.108.243.67.8080 10.0.16.42.31873 65535 0 24840 0 ESTABLISHED
DATE:2008-06-23 12:29:01 >> 218.108.243.67.8080 125.210.228.71.34502 11040 0 24840 0 TIME_WAIT
DATE:2008-06-23 12:29:01 >> 218.108.243.67.8080 10.0.16.42.34210 16560 0 24840 0 ESTABLISHED
DATE:2008-06-23 12:29:01 >> 218.108.243.67.8080 10.0.16.42.37854 16467 0 24840 0 ESTABLISHED
DATE:2008-06-23 12:29:01 >> 218.108.243.67.8080 10.0.16.42.37997 65535 0 24840 0 ESTABLISHED
DATE:2008-06-23 12:29:01 >> 218.108.243.67.8080 10.0.90.25.2298 65110 0 24840 0 ESTABLISHED
DATE:2008-06-23 12:29:01 >> 218.108.243.67.8080 10.0.31.36.1339 256680 0 24840 0 ESTABLISHED
DATE:2008-06-23 12:29:01 >> Total connections[8080]: 12
指令碼內容如下:
#!/bin/sh
LSNPORTS="8080 23234 23345 1521";
INTERVAL=30;
iter=0;
LOGPATH=$HOME/lyon/toplog/logs;
if [ -n $LOGPATH ]; then
mkdir -p $LOGPATH;
fi;
while [ 1 ]; do
for port in $LSNPORTS
do
CCTLST=`netstat -an | grep ".$port" | awk 'BEGIN{OFS="|";}{print $1,$2,$3,$4,$5,$6,$7;}'`;
LOGDATE=`date +%Y-%m-%d`;
LOGFILE="${LOGPATH}/netstat[${port}]-${LOGDATE}.log";
LOGTIME=`date '+DATE:%Y-%m-%d %H:%M:%S'`;
for ns in $CCTLST
do
NETLST=`echo $ns | awk -F"|" 'BEGIN{OFS=" ";}{print $1,$2,$3,$4,$5,$6,$7;}'`;
iter=`expr $iter + 1`;
loginfo=`echo "$LOGTIME" ">>" "$NETLST"`;
echo "$loginfo" >> $LOGFILE;
#echo "$loginfo";
done;
echo "$LOGTIME >> Total connections[$port]: " $iter >> $LOGFILE;
#echo "Total connections[$port]: " $iter;
iter=0;
sleep $INTERVAL;
done;
done;
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/12932950/viewspace-578360/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- memcached程式埠監控指令碼指令碼
- 每5秒監控5000埠的shell指令碼指令碼
- 監控指令碼指令碼
- mysql監控指令碼MySql指令碼
- DBA監控指令碼指令碼
- session指令碼監控Session指令碼
- oracle 監控指令碼Oracle指令碼
- listener監聽監控指令碼指令碼
- 【SQL監控】SQL完全監控的指令碼SQL指令碼
- ogg監控指令碼指令碼
- stap監控IO指令碼指令碼
- 【shell】磁碟監控指令碼指令碼
- mysql 的一個監控指令碼,監控heartbeatMySql指令碼
- mysql mon 的一個監控指令碼,監控heartbeatMySql指令碼
- PostgreSQL之鎖監控指令碼SQL指令碼
- Oracle DBA常用監控指令碼Oracle指令碼
- Nagios 監控ESXI指令碼iOS指令碼
- 監控cpu與memory指令碼指令碼
- 資料庫監控指令碼資料庫指令碼
- (Datagurad)監控指令碼指令碼
- 監控session數量指令碼Session指令碼
- 監控硬碟空間指令碼硬碟指令碼
- 監控sqlldr執行指令碼SQL指令碼
- 監控資料庫指令碼資料庫指令碼
- cacti自定義監控指令碼指令碼
- 監控系統告警指令碼集合指令碼
- 監控oracle表空間指令碼Oracle指令碼
- Goldengate for nrpe監控指令碼Go指令碼
- systemtap的網路監控指令碼指令碼
- stap監控cpu指令碼小結指令碼
- 指令碼監控MySQL伺服器指令碼MySql伺服器
- [zt]資料庫監控指令碼資料庫指令碼
- LINUX主機監控指令碼Linux指令碼
- 資料庫監控指令碼(一)資料庫指令碼
- 資料庫監控指令碼(二)資料庫指令碼
- 資料庫監控指令碼(三)資料庫指令碼
- oracle會話監控shell指令碼Oracle會話指令碼
- oracle空間使用監控指令碼Oracle指令碼