हाल ही में मैंने एक नया उबंटू सर्वर 10.04 स्थापित किया है और देखा है कि मेरा यूडीपी सर्वर अब मल्टीकास्ट समूह में शामिल होने के बाद भी इंटरफ़ेस पर भेजे गए किसी भी मल्टीकास्ट डेटा को देखने में सक्षम नहीं है। मुझे दो अन्य उबंटू 8.04.4 एलटीएस मशीनों पर सटीक एक ही सेट मिला है और एक ही मल्टीकास्ट समूह में शामिल होने के बाद डेटा प्राप्त करने में कोई समस्या नहीं है।
ईथरनेट कार्ड एक ब्रॉडकॉम netXtreme II BCM5709 है और इसका इस्तेमाल किया गया ड्राइवर है:
b $ ethtool -i eth1
driver: bnx2
version: 2.0.2
firmware-version: 5.0.11 NCSI 2.0.5
bus-info: 0000:01:00.1
मैं अपने मल्टीकास्ट पंजीकरणों को प्रबंधित करने के लिए smcroute का उपयोग कर रहा हूं।
b$ smcroute -d
b$ smcroute -j eth1 233.37.54.71
समूह में शामिल होने के बाद आईपी मैड्रिड नए जोड़े गए पंजीकरण को दिखाता है।
b$ ip maddr
1: lo
inet 224.0.0.1
inet6 ff02::1
2: eth0
link 33:33:ff:40:c6:ad
link 01:00:5e:00:00:01
link 33:33:00:00:00:01
inet 224.0.0.1
inet6 ff02::1:ff40:c6ad
inet6 ff02::1
3: eth1
link 01:00:5e:25:36:47
link 01:00:5e:25:36:3e
link 01:00:5e:25:36:3d
link 33:33:ff:40:c6:af
link 01:00:5e:00:00:01
link 33:33:00:00:00:01
inet 233.37.54.71 <------- McastGroup.
inet 224.0.0.1
inet6 ff02::1:ff40:c6af
inet6 ff02::1
अब तक अच्छा है, मैं देख सकता हूं कि मैं इस मल्टीकास्ट समूह के लिए डेटा प्राप्त कर रहा हूं।
b$ sudo tcpdump -i eth1 -s 65534 host 233.37.54.71
tcpdump: verbose output suppressed, use -v or -vv for full protocol decode
listening on eth1, link-type EN10MB (Ethernet), capture size 65534 bytes
09:30:09.924337 IP 192.164.1.120.58848 > 233.37.54.71.15572: UDP, length 212
09:30:09.947547 IP 192.164.1.120.58848 > 233.37.54.71.15572: UDP, length 212
09:30:10.108378 IP 192.164.1.120.58866 > 233.37.54.71.15574: UDP, length 268
09:30:10.196841 IP 192.164.1.120.58848 > 233.37.54.71.15572: UDP, length 212
...
मैं यह भी पुष्टि कर सकता हूं कि इंटरफ़ेस को मॉस्क पैकेट मिल रहा है।
b $ ethtool -S eth1 | grep mcast_pack
rx_mcast_packets: 103998
tx_mcast_packets: 33
अब यहाँ समस्या है। जब मैं एक सरल रूबी यूडीपी सर्वर का उपयोग करके ट्रैफ़िक को पकड़ने की कोशिश करता हूं तो मुझे शून्य डेटा प्राप्त होता है! यहां एक सरल सर्वर है जो पोर्ट 15572 पर डेटा भेजता है और पहले दो अक्षरों को प्रिंट करता है। यह दो 8.04.4 Ubuntu सर्वर पर काम करता है, लेकिन 10.04 सर्वर पर नहीं।
require 'socket'
s = UDPSocket.new
s.bind("", 15572)
5.times do
text, sender = s.recvfrom(2)
puts text
end
अगर मैं रूबी में तैयार किए गए एक यूडीपी पैकेट को लोकलहोस्ट पर भेजता हूं, तो सर्वर इसे प्राप्त करता है और पहले दो पात्रों को प्रिंट करता है। इसलिए मुझे पता है कि ऊपर दिया गया सर्वर सही तरीके से काम कर रहा है।
irb(main):001:0> require 'socket'
=> true
irb(main):002:0> s = UDPSocket.new
=> #<UDPSocket:0x7f3ccd6615f0>
irb(main):003:0> s.send("I2 XXX", 0, 'localhost', 15572)
जब मैं प्रोटोकॉल आँकड़ों की जाँच करता हूँ तो देखता हूँ कि InMcastPkts नहीं बढ़ रहा है। जबकि अन्य 8.04 सर्वरों पर, एक ही नेटवर्क पर, 10 सेकंड में कुछ हजारों पैकेट प्राप्त हुए।
b $ netstat -sgu ; sleep 10 ; netstat -sgu
IcmpMsg:
InType3: 11
OutType3: 11
Udp:
446 packets received
4 packets to unknown port received.
0 packet receive errors
461 packets sent
UdpLite:
IpExt:
InMcastPkts: 4654 <--------- Same as below
OutMcastPkts: 3426
InBcastPkts: 9854
InOctets: -1691733021
OutOctets: 51187936
InMcastOctets: 145207
OutMcastOctets: 109680
InBcastOctets: 1246341
IcmpMsg:
InType3: 11
OutType3: 11
Udp:
446 packets received
4 packets to unknown port received.
0 packet receive errors
461 packets sent
UdpLite:
IpExt:
InMcastPkts: 4656 <-------------- Same as above
OutMcastPkts: 3427
InBcastPkts: 9854
InOctets: -1690886265
OutOctets: 51188788
InMcastOctets: 145267
OutMcastOctets: 109712
InBcastOctets: 1246341
अगर मैं इंटरफेस को प्रोमिस मोड में लाने की कोशिश करता हूं तो कुछ भी नहीं बदलता है।
इस बिंदु पर मैं फंस गया हूं। मैंने पुष्टि की है कि कर्नेल विन्यास में मल्टीकास्ट सक्षम है। शायद अन्य विन्यास विकल्प हैं जिनकी मुझे जाँच करनी चाहिए?
b $ grep CONFIG_IP_MULTICAST /boot/config-2.6.32-23-server
CONFIG_IP_MULTICAST=y
यहाँ से कहाँ जाना है पर कोई विचार?
rp_filter
और /proc/sys/net/ipv4/icmp_echo_ignore_broadcasts
और फिर इसे काम करना शुरू किया।