यहां एक ओपन-एंड प्रश्न का बिट, इसलिए मैं पहले समस्या की रूपरेखा तैयार करूंगा। हमारे पास Resque कर्मचारी है जो कतार से डेटा-सिंक्रनाइज़ेशन नौकरियों को पॉप करना चाहता है, कारण दो गुना हैं, क्रॉन का उपयोग करके (और रेल पर्यावरण पर्यावरण बूट समय ओवर-एंड-ओवर का भुगतान) बेकार है, और वैकल्पिक कतार, अच्छी तरह से गिथब बनाया गया उनके खिलाफ एक बहुत अच्छा मामला जब वे announced Resque। इसके अलावा, Redis समय श्रृंखला कार्यक्षमता पहले से ही हमारे बुनियादी ढांचे, जहां हम भी RRDTool & आदि में टीएस डेटा शफ़ल की भूमिका अदा करता है ...ActiveRecord फोर्क/थ्रेडेड एप्लिकेशन के अंदर चलते समय पुनः कनेक्ट करने में असमर्थ?
यहाँ समस्या है, नौकरियों के बीच एक आम त्रि-घंटे के साथ (लेकिन कर्मचारी किसी भी समय नौकरियां निर्धारित कर सकते हैं ... इसलिए कतार), PostgreSQL सर्वर चला जाता है। इलाज के लिए काफी आसान है, मुझे उम्मीद है कि संबंधित वातावरण के तहत reconnect: true
सेटिंग सुनिश्चित करेगा कि यह अपेक्षित के रूप में काम करे .. मैंने fewplaces में पढ़ा है कि reconnect: true
fork()
का उपयोग करने वाले अनुप्रयोगों के लिए काम नहीं करेगा। जो, स्वाभाविक रूप से Resque करता है, अपने कर्मचारियों को शुरू करने के लिए ... जिस हिस्से को मैं समझ नहीं पा रहा हूं वह है कि ActiveRecord का पुन: कनेक्ट इन परिस्थितियों में क्यों काम नहीं कर सकता है?
मैं की reconnect!
MySQL Adapter और ActiveRecord में PostgreSQL Adapter अलग हैं कार्यान्वयन देखा ... लेकिन किसी भी तरह से मैं ActiveRecord reconnect: true
विन्यास काम करने की उम्मीद होगी। एक ऐसे में एक filehandle बंद करने के लिए यह संभव है -
समस्या(इस प्रकार डेटाबेस के लिए कनेक्शन को फांसी) पर्याप्त, जब बच्चे प्रक्रिया मौजूद है, यह फ़ाइल माता-पिता द्वारा बनाई गई हैंडल बंद कर देता है स्पष्ट हो रहा है जिस तरह से ActiveRecord यह नहीं पहचानता कि कनेक्शन समाप्त कर दिया गया है?
वहाँ भी है, क्या इसके लायक है के लिए, एक ActiveRecord aware fork() जो मैं एक pastie के रूप में, Github पर मिल करने में सक्षम था - यह untested है, लेकिन मैं यह काम करता है मान (वर्तमान रेल के साथ यह प्रयास नहीं किया है ..)
मेरा प्रश्न अधिक है, यदि आप fork()
पर स्वचालित रूप से एआर काम में पुन: कनेक्ट नहीं कर सकते हैं? (और, बाद में - मैं अकेला व्यक्ति नहीं हो सकता जो इस समस्या का सामना कर रहा है; मैं इसे पीजीएसक्यूएल का उपयोग रेस्क्यू के साथ करने के लिए तैयार कर रहा हूं!)
रोमन, यकीन है - मेरे पास कामकाज है, लेकिन मैं विशेष रूप से पुनः कनेक्ट करने का कारण ढूंढ रहा हूं: सत्य काम नहीं करता है।मैं सोच रहा हूं कि यह समरूपता (activerecord की 'allowconcurrency' ध्वज) के बारे में कुछ है - और यह स्वीकार करना कि पहला कनेक्शन अभी भी जुड़ा हुआ है ... लेकिन मुझे वास्तव में नुकसान हुआ है। –
ठीक है, activerecord कोड को देखकर, मैं क्या कह सकता हूं, यह है कि 'रीकनेक्ट' विकल्प PostgreSQL एडाप्टर के लिए समर्थित नहीं है। – Roman
रोमन, क्या आप अधिक विशिष्ट हो सकते हैं, शायद एक लिंक - वहां कहीं भी एक कार्यान्वयन हुआ था ... (मुझे यकीन है) –