簡體   English   中英

python3 socket recvfrom僅從netcat接收數據

[英]python3 socket recvfrom only receives data from netcat

我試圖為rtp序列跟蹤創建一個簡單的python程序,但是遇到了一個奇怪的問題。 我可以在tcpdump上看到rtp數據,但是當我運行腳本recvfrom時,我確認端口已通過netstat打開,並且如果我使用netcat發送數據,則腳本確實會接收數據。

#!/usr/bin/python3

import socket, threading, time
import datetime, sys



def main():
    """
    MAIN
    """
    #udp = rxUdp()
    #udp.startUDPRx()

    udp_ip = '192.168.1.100'
    udp_port = 6022

    sock = socket.socket(socket.AF_INET,socket.SOCK_DGRAM) #IP/UDP
    sock.setsockopt(socket.SOL_SOCKET, socket.SO_BROADCAST, 1)
    sock.bind(('', udp_port))
    #sock.bind(('eth1', 0))


    expected_rtp_seq = None
    print('Running')
    ts_file = open('test.ts', 'wb')
    #while True:
    for i in range (1, 1000):

        data = b''
        data, addr = sock.recvfrom(1500) #buffer size
        rtp_sequence_no = data[2:4]
        rtp_sequence_no = int.from_bytes(rtp_sequence_no, byteorder='big')

        rtp_len = data[19:20]

        mpegts_data = data[12:len(data)]
        print(rtp_sequence_no)
        print('.', end='')
        sys.stdout.flush()
        ts_file.write(mpegts_data)
        print(len(data))      
        if expected_rtp_seq == None:
            expected_rtp_seq = rtp_sequence_no
        if expected_rtp_seq != rtp_sequence_no:
            print('\n%s: Sequence Mismatch.  Expected %d, got %d' %
              (datetime.datetime.now(), expected_rtp_seq, rtp_sequence_no))
            expected_rtp_seq = rtp_sequence_no

        if expected_rtp_seq == 65535:
            expected_rtp_seq = 0
        else:
            expected_rtp_seq += 1


    ts_file.close()



if __name__ == '__main__':
    main()

我應該提一下,這段代碼似乎確實可以在Windows 7上運行,但不能在ubuntu上運行。

這是我的rtp流的tcpdump的輸出

10:26:57.486256 IP 209.87.232.169.57346> 192.168.1.100.6022:UDP,長度1328 0x0000:4500 054c 66e6 0000 3d11 95ad d157 e8a9 E..Lf ... = .... W .. 0x0010:c0a8 0164 e002 1786 0538 9797 8021 eddc ... d ..... 8 ...!.. 0x0020:6512 e48b e7a0 747d 4700 6513 e ..... t} Ge

這是netcat的tcpdump的輸出

10:26:51.709234 IP 192.168.2.149.52305> 192.168.2.241.6022:UDP,長度3 0x0000:4500 001f 7d3c 4000 4011 36bb c0a8 0295 E ...} <@。@。6 ..... 0x0010: c0a8 02f1 cc51 1786 000b 22c0 6869 0a00 ..... Q ....“。hi .. 0x0020:0000 0000 0000 0000 0000 0000 ............

謝謝看

好的,如果其他人將頭撞在牆上,他們想出了解決方案。

所以問題是net.ipv4.conf.all.rp_filter,net.ipv4.conf.eth1.rp_filter,net.ipv4.conf.eth2.rp_filter都已啟用,在這里找到了我的答案https://serverfault.com/a / 216568

基本上,這些配置的作用是過濾掉並非來自您本地局域網的任何數據,以防止欺騙,我將它們全部設置為0並啟動了腳本。

感謝您的評論並抽出寶貴的時間查看。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM