रेल का उपयोग करना, क्या मुझे डेटाबेस में बजाय फाइल सिस्टम में संलग्नक स्टोर करना चाहिए (किसी भी समय की फाइल हो सकती है)? डेटाबेस मेरे लिए आसान लगता है, फाइल सिस्टम पथ, संरचना इत्यादि के बारे में चिंता करने की कोई आवश्यकता नहीं है, आप बस अपने ब्लॉब फ़ील्ड में देखें। लेकिन ज्यादातर लोग फाइल सिस्टम का उपयोग करते हैं, जो मुझे अनुमान लगाता है कि ऐसा करने के कुछ फायदे होने चाहिए ताकि मुझे नहीं मिल रहा है, या इस तरह के भंडारण के लिए डेटाबेस का उपयोग करने के कुछ नुकसान हैं। (इस मामले में, मैं पोस्टग्रेज़ का उपयोग कर रहा हूँ)।रेल: डेटाबेस में बाइनरी फाइलों को संग्रहीत करना
उत्तर
यह एक सुंदर मानक डिजाइन प्रश्न है, और वास्तव में वास्तव में "एक सच्चा उत्तर" नहीं है।
अंगूठे का नियम आमतौर पर पालन करता है "डेटा डेटाबेस में जाता है, फाइलें फाइलों में जाती हैं"।
विचार से कुछ को ध्यान में रखना:
एक फ़ाइल डेटाबेस में संग्रहीत किया जाता है, तो आप http के माध्यम से इसे बाहर की सेवा करने के लिए कैसे जा रहे हैं? याद रखें, आपको सामग्री प्रकार, फ़ाइल नाम, आदि सेट करने की आवश्यकता है। यदि यह फाइल सिस्टम पर एक फ़ाइल है, तो वेब सर्वर आपके लिए उन सभी चीजों का ख्याल रखता है। बहुत तेज़ और कुशलता से (शायद कर्नेल स्पेस में भी), कोई व्याख्या कोड आवश्यक नहीं है।
फ़ाइलें आम तौर पर बड़ी होती हैं। बड़े डेटाबेस निश्चित रूप से व्यवहार्य हैं, लेकिन वे धीमे और बैक अप के लिए असुविधाजनक हैं आदि। जब आपको ऐसा करने की आवश्यकता नहीं है तो अपने डेटाबेस को बड़ा क्यों बनाएं?
बहुत पसंद है 2., फ़ाइलों को कई मशीनों में कॉपी करना वास्तव में आसान है। मान लें कि आप क्लस्टर चला रहे हैं, आप समय-समय पर अपने मास्टर मशीन से फाइल सिस्टम को अपने दासों में rsync कर सकते हैं और मानक स्थिर http सेवारत का उपयोग कर सकते हैं। स्पष्ट रूप से डेटाबेस को क्लस्टर भी किया जा सकता है, यह केवल सहज ज्ञान युक्त नहीं है।
3 के फ्लिप पक्ष पर, यदि आप पहले से ही अपने डेटाबेस को क्लस्टर कर रहे हैं, तो क्लस्टर फाइलों के साथ निपटने के लिए प्रशासनिक जटिलता है। डीबी में फाइलों को संग्रहीत करने पर विचार करने का यह एक कारण होगा, मैं कहूंगा।
डेटाबेस में ब्लॉब डेटा आम तौर पर अपारदर्शी है। आप इसे फ़िल्टर नहीं कर सकते हैं, इसके द्वारा क्रमबद्ध कर सकते हैं, या इसके द्वारा समूह बना सकते हैं। इससे डेटाबेस में इसे संग्रहीत करने के मूल्य कम हो जाते हैं।
फ्लिप पक्ष पर, डेटाबेस समरूपता को समझते हैं। आप यह सुनिश्चित करने के लिए लेनदेन अलगाव के अपने मानक मॉडल का उपयोग कर सकते हैं कि दो ग्राहक एक ही समय में एक ही फ़ाइल को संपादित करने का प्रयास नहीं करते हैं। यह अच्छा हो सकता है। यह नहीं कहना कि आप लॉकफाइल का उपयोग नहीं कर सके, लेकिन अब आपके पास दो चीजों को समझने की बजाय समझ में आया है।
अभिगम्यता। एक फाइल सिस्टम में फाइलें नियमित उपकरणों के साथ खोली जा सकती हैं। वी, फ़ोटोशॉप, शब्द, जो भी आपको चाहिए। यह सुविधाजनक हो सकता है। आप उस शब्द दस्तावेज़ को ब्लॉब फ़ील्ड से कैसे खोलेंगे?
अनुमतियां। फाइल सिस्टम में अनुमतियां होती हैं, और वे पीछे की ओर दर्द हो सकती हैं। इसके विपरीत, वे आपके आवेदन के लिए उपयोगी हो सकते हैं। अगर आप 7 का लाभ उठा रहे हैं तो अनुमतियां वास्तव में आपको काट लेंगी, क्योंकि यह लगभग गारंटी है कि आपका वेब सर्वर आपके अनुप्रयोगों की तुलना में अलग-अलग अनुमतियों के साथ चलता है।
कैशिंग (नीचे सरह मेई से)। यह क्लाइंट साइड पर उपरोक्त http प्रश्न में चलाता है (क्या आप जीवनकाल को सही ढंग से सेट करने के लिए याद रखना चाहते हैं?)। फाइल सिस्टम पर सर्वर साइड फाइलों पर एक बहुत अच्छी तरह से समझी और अनुकूलित पहुंच पैटर्न हैं। बड़े ब्लॉब फ़ील्ड आपके डेटाबेस द्वारा अच्छी तरह अनुकूलित हो सकते हैं या नहीं भी हो सकते हैं, और आप लगभग डेटाबेस से वेब सर्वर पर अतिरिक्त नेटवर्क यात्रा करने की गारंटी भी देते हैं।
संक्षेप में, लोगों क्योंकि वे फ़ाइल की तरह मुहावरों सबसे अच्छा समर्थन फ़ाइलों के लिए फ़ाइल सिस्टम का उपयोग करते हैं। यद्यपि आपको ऐसा करने का कोई कारण नहीं है, और फाइल सिस्टम डेटाबेस की तरह अधिक से अधिक हो रहे हैं, इसलिए अंत में एक पूर्ण अभिसरण देखने के लिए मुझे आश्चर्य नहीं होगा।
एरिक का जवाब बहुत अच्छा है। मैं यह भी जोड़ूंगा कि यदि आप कोई कैशिंग करना चाहते हैं, तो डेटाबेस सामग्री को कैश करने की तुलना में स्थिर फ़ाइलों को कैश करने के लिए यह बहुत आसान और अधिक सरल है।
यदि आप Paperclip जैसे प्लगइन का उपयोग करते हैं, तो आपको किसी भी चीज़ के बारे में चिंता करने की ज़रूरत नहीं है। फाइल सिस्टम नामक इस बात को है, जहां फाइलें चलनी चाहिए। सिर्फ इसलिए कि यह थोड़ा कठिन है इसका मतलब यह नहीं है कि आपको अपनी फाइलों को गलत जगह पर रखना चाहिए। और पेपरक्लिप (या अन्य समान प्लगइन्स) के साथ यह मुश्किल नहीं है। तो, gogo फाइल सिस्टम!
केवल यह सुनिश्चित करने के बारे में क्या है कि उपयुक्त उपयोगकर्ता फाइलों को देख/एक्सेस कर सकें - क्या पेपरक्लिप इसका ख्याल रखता है? – Greg
यह एक चरम बढ़त मामला है। फेसबुक कभी भी उनकी छवियों की रक्षा नहीं करता है (छवियों को बहुत ही खराब यूआरएल देने के अलावा)। –
ऐसा करने का एक तरीका अपाचे सर्वर के पीछे फ़ाइलों को रखने में एक होगा। Htaccess फ़ाइल इसे बंद कर सकती है। समस्या? फाइलें प्राप्त करना मुझे यकीन नहीं है कि यह रेल में संभव है लेकिन PHP में, आप यह जांचने के बाद फ़ाइल को एक .htaccess संरक्षित निर्देशिका से पकड़ सकते हैं कि उपयोगकर्ता को इसे देखने की अनुमति है या नहीं। PHP स्क्रिप्ट, ज़ाहिर है, एक अलग सार्वजनिक निर्देशिका में है। –
फाइलों के लिए फाइल सिस्टम का उपयोग करने के बारे में कुछ अच्छी सलाह है, लेकिन यहां कुछ और सोचने के लिए कुछ और है। यदि आप संवेदनशील या सुरक्षित फाइल/अनुलग्नक संग्रहित कर रहे हैं, तो डीबी का उपयोग करना वास्तव में जाने का एकमात्र तरीका है। मैंने ऐप बनाया है जहां डेटा को डेटा पर नहीं रखा जा सकता है। सुरक्षा कारणों से इसे डीबी में रखा जाना है। आप सर्वर/मशीन पर किसी उपयोगकर्ता के लिए फ़ाइल सिस्टम में इसे उचित सुरक्षा के बिना देखने या उनके साथ लेने के लिए नहीं छोड़ सकते हैं। ओरेकल जैसे उच्च श्रेणी के डीबी का उपयोग करके, आप उस डेटा को बहुत कसकर बंद कर सकते हैं और यह सुनिश्चित कर सकते हैं कि केवल उचित उपयोगकर्ताओं के पास उस डेटा तक पहुंच हो।
लेकिन बनाए गए अन्य अंक बहुत मान्य हैं। यदि आप बस अवतार छवियों या गैर-संवेदनशील जानकारी जैसी चीजें कर रहे हैं, तो अधिकांश सिस्टम सिस्टम के लिए फाइल सिस्टम आमतौर पर तेज़ और अधिक सुविधाजनक होता है।
डीबी फ़ाइलों को वापस भेजने के लिए सेटअप करना बहुत आसान है; यह थोड़ा और काम है, लेकिन अगर आप जानते हैं कि आप क्या कर रहे हैं तो बस कुछ ही मिनटों में। तो हां, फाइल सिस्टम समग्र रूप से जाने का बेहतर तरीका है, आईएमओ, लेकिन डीबी एकमात्र व्यवहार्य विकल्प है जब सुरक्षा या संवेदनशील डेटा एक प्रमुख चिंता है।
यह सच है। फाइल सिस्टम और डेटाबेस में सुरक्षा नियमों को एक साथ सिंक्रनाइज़ करने का प्रयास करना मुश्किल है। – easel
हालांकि यह असंभव हो सकता है एक विचार लिनक्स की तरह कुछ होगा।फ़ाइल सिस्टम पर htaccess फ़ाइलें अनधिकृत वेब दर्शकों को फ़ाइल देखने से रोकती हैं, या आप इसे सार्वजनिक वेब-सर्वर निर्देशिका से स्टोर कर सकते हैं और इसके साथ एक रिफ्रेंस लिंक प्राप्त कर सकते हैं। PHP, मुझे पता है कि एक तथ्य के लिए फ़ाइल को ओएस में सार्वजनिक रूप से कहीं भी नहीं खींच सकता है यदि उसके पास सही अनुमतियां हैं। –
मुझे नहीं लगता कि ब्लॉबस्टोर के साथ समस्या क्या है। आप हमेशा से फ़ाइल सिस्टम स्टोर का पुनर्निर्माण कर सकते हैं, उदा। सिस्टम का उपयोग होने पर स्थानीय वेब सर्वर पर सामान को कैश करके। लेकिन आधिकारिक स्टोर हमेशा डेटाबेस होना चाहिए। जिसका अर्थ है कि आप डेटाबेस में फेंककर और स्रोत नियंत्रण से कोड निर्यात करके अपना आवेदन तैनात कर सकते हैं। किया हुआ। और एक वेब सर्वर जोड़ना कोई मुद्दा नहीं है।
उत्पादन अनुभव के आधार पर मेरा मानना है कि यह उत्तर सही उत्तर है। – cfeduke
- 1. डोलॉल्स: डेटाबेस में नियमों को संग्रहीत करना
- 2. सूर्य आरपीसी: बाइनरी फाइलों को स्थानांतरित करना
- 3. डेटाबेस में पुस्तकें संग्रहीत करना
- 4. डेटाबेस में enum मानों को संग्रहीत करना
- 5. रेल: डेटाबेस में erb टेम्पलेट्स संग्रहीत
- 6. जावा में बाइनरी फाइलों को निष्पादित करना संभव है?
- 7. रेल: डेटाबेस में वस्तुओं को क्रमबद्ध करना?
- 8. एसक्यूएल में बूलियन मूल्यों को संग्रहीत करना?
- 9. सादा पाठ बनाम डेटाबेस में डेटाबेस में पासवर्ड संग्रहीत करना
- 10. डेटाबेस में एक्सएमएल डेटा संग्रहीत करना - कॉलम
- 11. डेटाबेस में 'अमान्य' तिथि संग्रहीत करना
- 12. वेब रूट के बाहर स्क्रिप्ट फाइलों को संग्रहीत करना
- 13. एक एमएसएसक्यूएल डेटाबेस में जेएसओएन संग्रहीत करना?
- 14. लंबे बाइनरी (कच्चे डेटा) तारों को संग्रहीत करना
- 15. रेल में एक सत्र में ऑब्जेक्ट्स संग्रहीत करना
- 16. डेटाबेस में क्रिस्टल रिपोर्ट फ़ाइलों को संग्रहीत करना?
- 17. डेटाबेस में संग्रहीत करने से पहले पाठ को संपीड़ित करना
- 18. डेटाबेस में बड़े प्राइम नंबरों को संग्रहीत करना
- 19. डेटाबेस में उपयोगकर्ता पहुंच स्तर को संग्रहीत करना
- 20. जावा: एक ऑरैकल डेटाबेस में संग्रहीत प्रक्रिया को कॉल करना
- 21. ऑब्जेक्ट को MySQL डेटाबेस में संग्रहीत करना चाहते हैं
- 22. डेटाबेस या फ़ाइलों में पोस्ट निकायों को संग्रहीत करना?
- 23. डेटाबेस में ऑडियो फ़ाइल संग्रहीत
- 24. डेटाबेस में उपयोगकर्ता द्वारा जेनरेट किए गए टेक्स्ट को सुरक्षित रूप से संग्रहीत करना (रूबी/रेल)
- 25. रेल बाइनरी स्ट्रीम समर्थन
- 26. डेटाबेस में ओपनआईडी जानकारी संग्रहीत
- 27. डेटाबेस में "वोट" संग्रहीत
- 28. रेल: डेटाबेस में सत्र संग्रहीत करने के लाभ?
- 29. डेटाबेस में यूटीसी के रूप में दिनांक/समय संग्रहीत करना
- 30. रेलवे पर रूबी में डेटाबेस में एक सरणी संग्रहीत करना
धन्यवाद, एरिक। यह एक बहुत ही उपयोगी और व्यापक उत्तर था। –
7. क्या आपका मतलब सर्वर पर सीधे काम करना है? एक फ़ाइल के रूप में, मैं फ़ोटोशॉप में इसे खोलने से पहले इसे डाउनलोड भी करूंगा। या मेरी संस्करण प्रणाली मेरे लिए ऐसा करेगी। – Luc
स्थानीय फाइल सिस्टम में चीजों को संग्रहीत करना जो दोहराया नहीं जाता है अक्सर 12 फ़ैक्टर-स्टाइल ऐप्स को तोड़ता है, जो एक मध्यम या बेहतर ऐप को समस्याग्रस्त बनाता है। एस 3/क्लाउडफ्रंट या इसी तरह के क्लोन बैकएंड में अनुलग्नक संग्रहीत करना अधिकांश (लेकिन सभी नहीं) उपयोग-मामलों के लिए जाने का तरीका है। कैरियरवेव, पेपरक्लिप इत्यादि उन मतभेदों को दूर करने में मदद कर सकते हैं। – Barry