首页 > 解决方案 > 如何获取 TCP 包的包数?

问题描述

我正在使用 _flow_stats_reply_handler 检索流量统计信息,如 Ryu Traffic Monitor 示例中所示。

我使用以下打印:

file.write("\n{},{},{},{},{},{},{},{},{}"
                   .format(ev.msg.datapath.id,
                           stat.match['in_port'], stat.match['eth_src'], stat.match['eth_dst'],
                           stat.instructions[0].actions[0].port,
                           stat.packet_count, stat.byte_count,
                           stat.duration_sec, stat.duration_nsec))

注意stat.packet_count.

我怎样才能改变它来计算 TCP 数据包?我知道有一个ip_proto字段和一个tcp_flags字段,但我不知道如何编码匹配/计数。

编辑:我对此进行了进一步调查,并在我的请求流统计功能中添加了流匹配:

def _request_stats(self, datapath):
    self.logger.debug('send stats request: %016x', datapath.id)
    ofp = datapath.ofproto
    parser = datapath.ofproto_parser

    cookie = cookie_mask = 0
    match = parser.OFPMatch(eth_type=0x0800)
    req = parser.OFPFlowStatsRequest(datapath, 0, ofp.OFPTT_ALL, ofp.OFPP_ANY, ofp.OFPG_ANY,
                                     cookie, cookie_mask, match)
    datapath.send_msg(req)

不幸的是,这仍然不起作用,任何关于为什么不的想法将不胜感激。

标签: pythonopenflowryu

解决方案


您应该在匹配中添加更多数据,例如ip_proto为了与 tcp 匹配,您可能知道,TCP 的 IP 协议编号为 6,有关 IP 协议编号的更多信息,请查看Wikipedia

tcp_flags请使用下面的代码,在这种情况下您不需要设置。

match = parser.OFPMatch(
    eth_type=0x0800, 
    ip_proto=6, 
    )

推荐阅读