java - DatagramChannel, blocking mode and cpu -


मुझे निम्नलिखित कोड स्निपेट मिलता है:

  डेटाग्राम चैनल = डेटाग्राम चैनल। ओपन (मानकप्रोटोकॉफिल। INET ) .सेटऑप (मानक सॉकेट विकल्प। SO_UUSEADDR, सच है) .सेटऑप (मानक सॉकेटऑप्शन। IP_MULTICAST_IF, नेटवर्क इंटरफेस); datagramChannel.configureBlocking (सही); डेटाग्राम चैनल.बिंद (नया इनसेट सॉकेट अटैडर (फिल्टर.टाटाइप ()। GetPort (filter.getTimeFrameType ()))); डाटाग्राम। चैनल (समूह, नेटवर्क इंटरफेस); datagramChannel.receive (बफर);   

यह कोड एक कॉल करने योग्य में स्थित है और मैं मल्टिकास्ट पैकेट को पुनर्प्राप्त करने के लिए 12 से बना कोलाबल s (12 सूत्र) बना सकता हूं 12 विभिन्न बंदरगाहों से अलग डेटा यह केवल सूचना से पढ़ता है जो नेटवर्क पर हर 3-8 सेकंड में ब्रोकेस्ट किया जाता है।

जब 12 बंदरगाहों को निरंतर ( जानकारी की प्रतीक्षा करें, सूचना प्राप्त करें, और इतने पर ), यह मेरे सीपीयू में से एक का 100% खाता है।

JVisualVM के साथ निष्पादन की रूपरेखा, मुझे लगता है कि निष्पादन समय का 90% java.nio.channels.DatagramChannel # के लिए समर्पित है () , और अधिक सटीक com.sun.nio.ch.DatagramChannelImpl # receiveIntoBuffer ()

  1. मुझे अच्छी तरह समझ में नहीं आ रहा है क्यों ब्लॉकिंग मोड इतना सीपीयू खाते हैं।

  2. मैंने ब्लॉकिंग मोड के बजाय selector s का उपयोग करने पर कुछ लेख पढ़ा है, लेकिन मैं वास्तव में नहीं देखें कि एक जबकि (सच) के साथ चयनकर्ता अवरुद्ध चैनल से कम उपभोग होगा।

    समस्या यह है कि आप चयनकर्ता के बिना एनआईओ का प्रयोग कर रहे हैं।

    चयनकर्ता के बिना एनआईओ ठीक है लेकिन फिर चैनल। निरंतर प्रयास करना

    • पढ़ने के लिए कुछ है या नहीं पता लगाने के लिए चयनकर्ता का उपयोग करें। कॉल चैनल। केवल जब चयनकर्ता इंगित करता है कि पढ़ने के लिए डेटा है
    • ब्लॉकिंग मोड में भेजने / प्राप्त करने के लिए जावानेट। डेटाग्राम / डेटाग्राम पैकेट का उपयोग करें। < / html>

Comments

Popular posts from this blog

c - Mpirun hangs when mpi send and recieve is put in a loop -

python - Apply coupon to a customer's subscription based on non-stripe related actions on the site -

java - Unable to get JDBC connection in Spring application to MySQL -