IGMP v3 JOIN이 전송되었지만 스위치에 트래픽이 없습니다.

IGMP v3 JOIN이 전송되었지만 스위치에 트래픽이 없습니다.

Centos 8 시스템에서 IGMP 멀티캐스트 스트림에 참여하려고 하지만 JOIN을 보낸 후 스위치에서 트래픽이 없습니다.

간단한 연결:

MUX <-----------> cisco3850 <--------> Centos8
192.168.117.13                         192.168.117.21

업스트림 스위치(cisco Catalyst 3850)는 MUX에서 239.1.1.1:4000으로 MPEG-TS를 공급합니다.

socat나는 소켓을 열고, 스트림에 참여하고, 소켓을 열어두기 위해 내 자신의 프로그램을 시도해 보았습니다 . 둘 다 Wireshark에서 확인한 동일한 IGMP 조인 메시지를 보냅니다.

Internet Group Management Protocol
    [IGMP Version: 3]
    Type: Membership Report (0x22)
    Reserved: 00
    Checksum: 0xe9fb [correct]
    [Checksum Status: Good]
    Reserved: 0000
    Num Group Records: 1
    Group Record : 239.1.1.1  Change To Exclude Mode
        Record Type: Change To Exclude Mode (4)
        Aux Data Len: 0
        Num Src: 0
        Multicast Address: 239.1.1.1

ip route add멀티캐스트 그룹을 위해 생성한 경로를 인터페이스에 사용합니다 .

224.0.0.0/4 dev eth1 scope link
225.0.0.0/8 dev eth1 scope link
239.0.0.0/8 dev eth1 scope link

그리고 cat /proc/net/igmp그룹이 가입되었음을 표시합니다.

cat /proc/net/igmp
Idx     Device    : Count Querier       Group    Users Timer    Reporter
3       eth1      :     2      V3
                                030101E1     1 0:00000000               0
                                010000E0     1 0:00000000               0

의심하다이것은 Linux 문제가 아닌 스위치 문제인데, (스위치를 소유한) 고객이 모든 것이 괜찮다고 말합니다.

이 문제를 조사/수정하기 위해 Linux 측에서 또 무엇을 할 수 있습니까?

스위치 문제라면 어떨까요? 거기에서 무엇을 구성해야 합니까? (고객에게 설명이 필요함)


참고로 소켓을 연결하고 열어두는 내 프로그램은 다음과 같습니다.

// Error checking omitted for brevity
fd = socket(PF_INET, SOCK_DGRAM, IPPROTO_IP);
setsockopt(fd, SOL_SOCKET, SO_REUSEADDR, &yes, sizeof(yes);

memset(&saddr, 0, sizeof(saddr));
saddr.sin_family      = PF_INET;
saddr.sin_addr.s_addr = mcastAddr;
saddr.sin_port        = htons(port);

bind(fd, (struct sockaddr *)&saddr, sizeof(saddr);

struct ip_mreq mcastReq;
mcastReq.imr_multiaddr.s_addr = mcastAddr;
&mcastReq.imr_interface.s_addr = interfaceAddr;

setsockopt(sock, IPPROTO_IP, IP_ADD_MEMBERSHIP, &mcastReq, sizeof(mcastReq);

답변1

마지막으로 고객 스위치는 IGMPv3를 활성화할 수 없거나 활성화하지 않으므로 /etc/sysctl.d.

그런 다음 JOIN이 작동했지만 Linux가 멀티캐스트 멤버십 쿼리에 응답하지 않았기 때문에 스위치는 1-2분 후에 흐름을 중단했습니다( net.ipv4.conf.default.rp_filter0으로 설정했음에도 불구하고).

반환 경로 유효성 검사를 완전히 비활성화하려면 모든 설정을 0으로 설정해야 합니다 rp_filter(인터페이스 명시적 나열 포함).

# Set IGMP Version for eth1
# Set to '2' or '3' depending on what is enabled in the switch
net.ipv4.conf.eth1.force_igmp_version = 2

# Disable source route verification
# In addition to 90-torque.conf, also explicitly set eth1 to ignore
# return path validation
net.ipv4.conf.default.rp_filter = 0
net.ipv4.conf.all.rp_filter = 0
net.ipv4.conf.eth1.rp_filter = 0

관련 정보