Я пытаюсь найти способ определить время приема-передачи для каждого IP-адреса, который подключается к порту 80 на моем сервере. Как это лучше сделать?
Соединений слишком много, и пинговать каждый ip нецелесообразно. Я думал, как-то измерить разницу во времени между тем, когда сервер отправляет пакет синхронизации / подтверждения, и когда сервер получает подтверждение для него.
Есть ли способ записать это дешево? Может, с помощью какого-нибудь волшебного фильтра tcpdump?
Цель этого упражнения - агрегировать данные и определить, есть ли какие-либо недостатки маршрутизации. Скажем, один интернет-провайдер в одном регионе может неправильно маршрутизировать и т. Д.
FWIW веб-сервер - это nginx.
$ tcpinfo_rtt, $ tcpinfo_rttvar, $ tcpinfo_snd_cwnd, $ tcpinfo_rcv_space
information about the client TCP connection; available on systems that support the TCP_INFO socket option
http://nginx.org/en/docs/http/ngx_http_core_module.html#variables
Если у вас есть доступ к Linux или Unix машине1, вы должны использовать tcptrace. Все, что вам нужно сделать, это захватить клиентский трафик с помощью WireShark или tcpdump в файл pcap.
После того, как у вас есть это .pcap
файл2, анализируйте с tcptrace -xtraffic <pcap_filename>
3. Это сгенерирует два текстовых файла, и средняя статистика RTT для всех подключений в этом pcap отображается внизу файла, который называется traffic_stats.dat
.
[mpenning@Bucksnort tcpperf]$ tcptrace -xtraffic willers.pcap
mod_traffic: characterizing traffic
1 arg remaining, starting with 'willers.pcap'
Ostermann's tcptrace -- version 6.6.1 -- Wed Nov 19, 2003
16522 packets seen, 16522 TCP packets traced
elapsed wallclock time: 0:00:00.200709, 82318 pkts/sec analyzed
trace file elapsed time: 0:03:21.754962
Dumping port statistics into file traffic_byport.dat
Dumping overall statistics into file traffic_stats.dat
Plotting performed at 15.000 second intervals
[mpenning@Bucksnort tcpperf]$
[mpenning@Bucksnort tcpperf]$ cat traffic_stats.dat
Overall Statistics over 201 seconds (0:03:21.754962):
4135308 ttl bytes sent, 20573.672 bytes/second
4135308 ttl non-rexmit bytes sent, 20573.672 bytes/second
0 ttl rexmit bytes sent, 0.000 bytes/second
16522 packets sent, 82.199 packets/second
200 connections opened, 0.995 conns/second
11 dupacks sent, 0.055 dupacks/second
0 rexmits sent, 0.000 rexmits/second
average RTT: 67.511 msecs <------------------
[mpenning@Bucksnort tcpperf]$
В .pcap
файл, используемый в этом примере, был записью, которую я создал, когда я прошел через expect
скрипт, который извлекал данные с одного из моих серверов. Вот как я создал цикл ...
#!/usr/bin/python
from subprocess import Popen, PIPE
import time
for ii in xrange(0,200):
# willers.exp is an expect script
Popen(['./willers.exp'], stdin=PIPE, stdout=PIPE, stderr=PIPE)
time.sleep(1)
tcptrace
может получить очень подробную статистику по сокету, если вы используете другие параметры ...================================ [mpenning@Bucksnort tcpperf]$ tcptrace -lr willers.pcap 1 arg remaining, starting with 'willers.pcap' Ostermann's tcptrace -- version 6.6.1 -- Wed Nov 19, 2003 16522 packets seen, 16522 TCP packets traced elapsed wallclock time: 0:00:00.080496, 205252 pkts/sec analyzed trace file elapsed time: 0:03:21.754962 TCP connection info: 200 TCP connections traced: TCP connection 1: host c: myhost.local:44781 host d: willers.local:22 complete conn: RESET (SYNs: 2) (FINs: 1) first packet: Tue May 31 22:52:24.154801 2011 last packet: Tue May 31 22:52:25.668430 2011 elapsed time: 0:00:01.513628 total packets: 73 filename: willers.pcap c->d: d->c: total packets: 34 total packets: 39 resets sent: 4 resets sent: 0 ack pkts sent: 29 ack pkts sent: 39 pure acks sent: 11 pure acks sent: 2 sack pkts sent: 0 sack pkts sent: 0 dsack pkts sent: 0 dsack pkts sent: 0 max sack blks/ack: 0 max sack blks/ack: 0 unique bytes sent: 2512 unique bytes sent: 14336 actual data pkts: 17 actual data pkts: 36 actual data bytes: 2512 actual data bytes: 14336 rexmt data pkts: 0 rexmt data pkts: 0 rexmt data bytes: 0 rexmt data bytes: 0 zwnd probe pkts: 0 zwnd probe pkts: 0 zwnd probe bytes: 0 zwnd probe bytes: 0 outoforder pkts: 0 outoforder pkts: 0 pushed data pkts: 17 pushed data pkts: 33 SYN/FIN pkts sent: 1/1 SYN/FIN pkts sent: 1/0 req 1323 ws/ts: Y/Y req 1323 ws/ts: Y/Y adv wind scale: 6 adv wind scale: 1 req sack: Y req sack: Y sacks sent: 0 sacks sent: 0 urgent data pkts: 0 pkts urgent data pkts: 0 pkts urgent data bytes: 0 bytes urgent data bytes: 0 bytes mss requested: 1460 bytes mss requested: 1460 bytes max segm size: 792 bytes max segm size: 1448 bytes min segm size: 16 bytes min segm size: 32 bytes avg segm size: 147 bytes avg segm size: 398 bytes max win adv: 40832 bytes max win adv: 66608 bytes min win adv: 5888 bytes min win adv: 66608 bytes zero win adv: 0 times zero win adv: 0 times avg win adv: 14035 bytes avg win adv: 66608 bytes initial window: 32 bytes initial window: 40 bytes initial window: 1 pkts initial window: 1 pkts ttl stream length: 2512 bytes ttl stream length: NA missed data: 0 bytes missed data: NA truncated data: 0 bytes truncated data: 0 bytes truncated packets: 0 pkts truncated packets: 0 pkts data xmit time: 1.181 secs data xmit time: 1.236 secs idletime max: 196.9 ms idletime max: 196.9 ms throughput: 1660 Bps throughput: 9471 Bps RTT samples: 18 RTT samples: 24 RTT min: 43.8 ms RTT min: 0.0 ms RTT max: 142.5 ms RTT max: 7.2 ms RTT avg: 68.5 ms RTT avg: 0.7 ms RTT stdev: 35.8 ms RTT stdev: 1.6 ms RTT from 3WHS: 80.8 ms RTT from 3WHS: 0.0 ms RTT full_sz smpls: 1 RTT full_sz smpls: 3 RTT full_sz min: 142.5 ms RTT full_sz min: 0.0 ms RTT full_sz max: 142.5 ms RTT full_sz max: 0.0 ms RTT full_sz avg: 142.5 ms RTT full_sz avg: 0.0 ms RTT full_sz stdev: 0.0 ms RTT full_sz stdev: 0.0 ms post-loss acks: 0 post-loss acks: 0 segs cum acked: 0 segs cum acked: 9 duplicate acks: 0 duplicate acks: 1 triple dupacks: 0 triple dupacks: 0 max # retrans: 0 max # retrans: 0 min retr time: 0.0 ms min retr time: 0.0 ms max retr time: 0.0 ms max retr time: 0.0 ms avg retr time: 0.0 ms avg retr time: 0.0 ms sdv retr time: 0.0 ms sdv retr time: 0.0 ms ================================