इसे ठीक किया:
sudo sysctl net.ipv4.tcp_tw_reuse=1
फिर, मोंगो को फिर से शुरू करें।
वैकल्पिक रूप से, आप इसे /etc/sysctl.conf में जोड़ सकते हैं (इसलिए इसे रीबूट पर चलाया जाएगा):
net.ipv4.tcp_tw_reuse=1
फिर इसे पुनः लोड करने के लिए चलाएं (बिना रीबूट किए)
sudo sysctl -p /etc/sysctl.conf
यह "फिक्स" टीसीपी सॉकेट्स (सर्वर-वाइड) के लिए टाइमवेट स्थिति को अक्षम कर देगा। तो, यह वास्तव में बिल्कुल भी ठीक नहीं है। हालाँकि, जब तक mongo SO_LINGER का उपयोग करके अपनी टाइमवेट स्थिति को कम नहीं करता, तब तक बड़ी संख्या में सर्वर सॉकेट TIME_WAIT स्थिति में जमा हो जाएंगे और नए कनेक्शन के लिए अनुपयोगी रहेंगे। आप इसके साथ TIME_WAIT में कनेक्शनों की संख्या देख सकते हैं:
netstat -an | grep TIME_WAIT | wc -l
इसके साथ, मैं इसे लगभग 28k TIME_WAIT कनेक्शन पर विफल होते देख पा रहा था। इस कर्नेल ध्वज का उपयोग करना:
sysctl net.ipv4.ip_local_port_range="18000 65535"
सर्वर 45k कनेक्शन पर विफल रहता है। इसलिए, त्रुटि को अधिक आसानी से पुन:उत्पन्न करने के लिए, आप सीमा को 200 या कुछ छोटा कर सकते हैं।
तो, इसका परिणाम था आखिर एक प्रोग्रामिंग प्रश्न (जैसा कि आप अंतिम लिंक से देख सकते हैं):
TCP विकल्प SO_LINGER (शून्य) ) - जब इसकी आवश्यकता हो
http://alas.matf.bg.ac.rs /manuals/lspe/snode=105.html