मैं एक Django वेब ऐप के लिए virtualenv डालने के बारे में सोच रहा हूं जो मैं ऐप के लिए अपने गिट रिपॉजिटरी के अंदर बना रहा हूं। यह तैनाती के सरल और आसान रखने के लिए एक आसान तरीका की तरह लगता है। क्या कोई कारण है कि मुझे ऐसा क्यों नहीं करना चाहिए?
मैं एक Django वेब ऐप के लिए virtualenv डालने के बारे में सोच रहा हूं जो मैं ऐप के लिए अपने गिट रिपॉजिटरी के अंदर बना रहा हूं। यह तैनाती के सरल और आसान रखने के लिए एक आसान तरीका की तरह लगता है। क्या कोई कारण है कि मुझे ऐसा क्यों नहीं करना चाहिए?
जवाबों:
मैं pip freeze
उन पैकेजों को प्राप्त करने के लिए उपयोग करता हूं जिनकी मुझे एक requirements.txt
फ़ाइल में आवश्यकता होती है और उन्हें मेरे भंडार में जोड़ते हैं। मैंने एक तरीका सोचने की कोशिश की कि आप पूरे वर्चुअन को क्यों स्टोर करना चाहते हैं, लेकिन मैं नहीं कर सका।
pip install mysql-python
, 64 बिट मशीन पर, और फिर 32 बिट मशीन वाला कोई व्यक्ति इसका उपयोग करने की कोशिश करता है, तो यह काम नहीं करेगा। यह C मॉड्यूल का उपयोग करता है, जैसे कई पायथन मॉड्यूल प्रदर्शन को बढ़ाने के लिए करते हैं। मुझे लगता है कि विंडोज-> लिनक्स भी काम नहीं करेगा।
pip freeze
ऐसा करने के लिए फिर कभी भरोसा नहीं करूंगा । मुद्दा यह है कि आपके जबरन नवीनीकरण के दौरान, कोई भी इसके लिए भुगतान नहीं करता है, और मध्यवर्ती उन्नयन ("सर्वोत्तम अभ्यास" रखरखाव) के लिए कोई भी नहीं करता है।
--distribute
और --setuptools
विकल्प अब नो-ऑप हैं। (वितरित करें, कि सेटप्टूल का एक कांटा बहुत पहले विलय कर दिया गया है)। --no-site-packages
Git के अंदर virtualenv डायरेक्टरी को स्टोर करना, जैसा कि आपने नोट किया है, आपको सिर्फ एक गिट क्लोन (प्लस अपाचे / mod_wsgi को स्थापित करने और कॉन्फ़िगर करने) द्वारा पूरे ऐप को तैनात करने की अनुमति देता है। इस दृष्टिकोण के साथ एक संभावित रूप से महत्वपूर्ण मुद्दा यह है कि लिनक्स पर पूर्ण पथ को vev के सक्रिय, django-admin.py, easy_install और pip स्क्रिप्ट में हार्ड-कोडित किया जाता है। इसका अर्थ है कि यदि आप एक ही पथ पर एक से अधिक वर्चुअल होस्ट्स चलाना चाहते हैं, तो आपका virtualenv पूरी तरह से काम नहीं करेगा। मुझे लगता है कि वेबसाइट वास्तव में उन फाइलों में गलत रास्तों के साथ काम कर सकती है, लेकिन अगली बार जब आपने पाइप चलाने की कोशिश की तो आपको समस्या होगी।
समाधान, पहले से ही दिया गया है, गिट में पर्याप्त जानकारी संग्रहीत करने के लिए है ताकि तैनाती के दौरान आप वर्चुअन बना सकें और आवश्यक पाइप डिस्क कर सकें। आमतौर पर लोग pip freeze
सूची प्राप्त करने के लिए दौड़ते हैं, फिर इसे आवश्यकताओं के नाम से एक फ़ाइल में संग्रहीत करते हैं। इसके साथ लोड किया जा सकता है pip install -r requirements.txt
। रयान ब्रैडी पहले ही दिखा चुके हैं कि आप एक ही लाइन में तैनाती स्टेटमेंट को कैसे स्ट्रिंग कर सकते हैं:
# before 15.1.0
virtualenv --no-site-packages --distribute .env &&\
source .env/bin/activate &&\
pip install -r requirements.txt
# after deprecation of some arguments in 15.1.0
virtualenv .env && source .env/bin/activate && pip install -r requirements.txt
व्यक्तिगत रूप से, मैंने इन्हें केवल एक शेल स्क्रिप्ट में रखा है जिसे मैं गिट क्लोन या गिट पुल करने के बाद चलाता हूं।
Virtualenv निर्देशिका को संग्रहीत करना भी पाइप अपग्रेड को संभालने के लिए इसे थोड़ा पेचीदा बनाता है, क्योंकि आपको मैन्युअल रूप से अपग्रेड से परिणामी फ़ाइलों को जोड़ना / निकालना होगा। आवश्यकताओं के साथ। फ़ाइल के साथ, आप आवश्यकताओं में उचित लाइनों को बदल देते हैं pip install -r requirements.txt
। फिर से और फिर से चलाएँ । जैसा कि पहले ही उल्लेख किया गया है, यह "कमिट स्पैम" भी करता है।
--distribute DEPRECATED. Retained only for backward compatibility. This option has no effect.
--no-site-packages
15.1.0 के रूप में अच्छी तरह से डिफ़ॉल्ट के रूप में पदावनत किया गया है।
जब तक मैंने पुस्तकालयों का उपयोग शुरू नहीं किया, तब तक मैं ऐसा ही करता था, जो कि पर्यावरण पर निर्भर करता है जैसे कि PyCrypto। मेरा PyCrypto mac, उबंटू पर काम नहीं करेगा।
यह भंडार का प्रबंधन करने के लिए एक बुरा सपना बन जाता है।
किसी भी तरह से मुझे पाइप फ्रीज़ और आवश्यकताओं की फाइल को आसानी से प्रबंधित करने की तुलना में यह सब मिल गया। यह बहुत साफ है क्योंकि आपको हजारों फाइलों के लिए प्रतिबद्ध स्पैम से बचना है क्योंकि उन पुस्तकालयों को अद्यतन किया जाता है ...
मुझे लगता है कि एक मुख्य समस्या यह है कि virtualenv अन्य लोगों द्वारा उपयोग करने योग्य नहीं हो सकता है। कारण यह है कि यह हमेशा पूर्ण पथ का उपयोग करता है। इसलिए यदि आप virtualenv उदाहरण के लिए था, तो /home/lyle/myenv/
इस रिपॉजिटरी का उपयोग करने वाले अन्य सभी लोगों के लिए समान होगा (यह बिल्कुल एक ही निरपेक्ष पथ होना चाहिए)। आप उसी निर्देशिका संरचना का उपयोग करके लोगों को अनुमान नहीं लगा सकते हैं।
बेहतर अभ्यास यह है कि हर कोई अपने स्वयं के वातावरण को स्थापित कर रहा है (यह virtualenv के साथ या इसके बिना हो) और वहां पुस्तकालय स्थापित कर रहा है। यह भी आपको विभिन्न प्लेटफार्मों (लिनक्स / विंडोज / मैक) पर अधिक प्रयोग करने योग्य बनाता है, क्योंकि उनमें से प्रत्येक में वर्चुअनव अलग-अलग स्थापित है।
manage.py
) आप समस्याओं के बारे में सुनिश्चित करेंगे।
मैं थोड़ा और अधिक स्वचालन के साथ मूल रूप से डेविड सिकमिलर के उत्तर का उपयोग करता हूं । मैं अपने प्रोजेक्ट के शीर्ष स्तर पर (गैर-निष्पादन योग्य) फ़ाइल बनाता हूं जिसका नाम activate
निम्नलिखित सामग्री के साथ दिया गया है:
[ -n "$BASH_SOURCE" ] \
|| { echo 1>&2 "source (.) this with Bash."; exit 2; }
(
cd "$(dirname "$BASH_SOURCE")"
[ -d .build/virtualenv ] || {
virtualenv .build/virtualenv
. .build/virtualenv/bin/activate
pip install -r requirements.txt
}
)
. "$(dirname "$BASH_SOURCE")/.build/virtualenv/bin/activate"
(डेविड के जवाब के अनुसार, यह मानता है कि आप pip freeze > requirements.txt
अपनी आवश्यकताओं की सूची को अद्यतन रखने के लिए कर रहे हैं ।)
उपरोक्त सामान्य विचार देता है; वास्तविक सक्रिय स्क्रिप्ट ( प्रलेखन ) जो मैं सामान्य रूप से उपयोग करता हूं, थोड़ा अधिक परिष्कृत है, एक -q
(शांत) विकल्प की पेशकश , python
जब python3
उपलब्ध नहीं है, आदि का उपयोग करना ।
इसके बाद इसे किसी भी वर्तमान वर्किंग डायरेक्टरी से सॉर्ट किया जा सकता है और यदि आवश्यक हो तो पहले वर्चुअल वातावरण सेट करते हुए, ठीक से सक्रिय हो जाएगा। मेरी शीर्ष-स्तरीय परीक्षण स्क्रिप्ट में आमतौर पर इन पंक्तियों के साथ कोड होता है ताकि इसे डेवलपर के बिना पहले सक्रिय करने के लिए चलाया जा सके:
cd "$(dirname "$0")"
[[ $VIRTUAL_ENV = $(pwd -P) ]] || . ./activate
सोर्सिंग ./activate
, नहीं activate
, यहां महत्वपूर्ण है क्योंकि उत्तरार्द्ध activate
आपके रास्ते में किसी अन्य को ढूंढेगा, इससे पहले कि वह वर्तमान निर्देशिका में मिल जाएगा।
[[ $_ != $0 ]] || { echo 1>&2 "source (.) this script with Bash."; exit 2; }
पता लगाने के लिए पहली पंक्ति को बदलना पड़ा कि क्या पटकथा को विरोध के रूप में क्रियान्वित किया जा रहा था
किसी भी पर्यावरण-निर्भर घटक को शामिल करना या रेपो का उपयोग करने के प्रमुख पहलुओं में से एक के रूप में अपने रिपॉज में शामिल करना एक अच्छा विचार नहीं है, शायद, यह अन्य डेवलपर्स के साथ साझा कर रहा है। यहां बताया गया है कि मैं अपने विकास के माहौल को विंडोज पीसी पर कैसे सेट करूंगा (कहते हैं, Win10)।
Pycharm खोलें और पहले पृष्ठ पर, अपने स्रोत नियंत्रण प्रणाली से परियोजना की जांच करना चुनें (मेरे मामले में, मैं स्मिथ का उपयोग कर रहा हूं)
Pycharm में, सेटिंग में नेविगेट करें और "प्रोजेक्ट इंटरप्रेटर" चुनें और एक नया आभासी वातावरण जोड़ने का विकल्प चुनें, आप इसे "वेनव" कह सकते हैं।
आधार पायथन इंटरप्रेटर चुनें जो C: \ Users {user} \ AppData \ Local \ Programs \ Python \ Python36 पर स्थित है (सुनिश्चित करें कि आपने जो इंस्टॉल किया है, उसके आधार पर आप Python का उपयुक्त संस्करण चुनें)
ध्यान दें कि Pycharm नया वर्चुअल वातावरण बनाएगा और अपने प्रोजेक्ट फ़ोल्डर के अंदर अपने venv फ़ोल्डर के तहत अजगर बायनेरिज़ और आवश्यक पुस्तकालयों की प्रतिलिपि बनाएँ।
Pycharm को अपनी स्कैनिंग पूरी करने दें क्योंकि उसे आपके प्रोजेक्ट कंकाल को फिर से बनाने / ताज़ा करने की आवश्यकता है
अपना Git बातचीत (venv \ में जोड़ने से venv फ़ोल्डर को बाहर .gitignore अपनी परियोजना फ़ोल्डर में फ़ाइल)
बोनस: यदि आप चाहते हैं कि लोग आसानी से (अच्छी तरह से, लगभग आसानी से) सभी पुस्तकालयों को आपके सॉफ़्टवेयर की ज़रूरतों को स्थापित करें, तो आप उपयोग कर सकते हैं
pip freeze > requirements.txt
और अपने git पर निर्देश डालें ताकि लोग एक ही समय में सभी आवश्यक पुस्तकालयों को डाउनलोड करने के लिए निम्न कमांड का उपयोग कर सकें।
pip install -r requirements.txt
यदि आप जानते हैं कि आपका एप्लिकेशन किन ऑपरेटिंग सिस्टमों पर चल रहा है, तो मैं प्रत्येक सिस्टम के लिए एक वर्चुअन बनाऊंगा और इसे अपने रिपॉजिटरी में शामिल करूंगा। फिर मैं अपने एप्लिकेशन का पता लगाऊंगा कि यह किस सिस्टम पर चल रहा है और संबंधित virtualenv का उपयोग करें।
सिस्टम को प्लेटफ़ॉर्म मॉड्यूल का उपयोग करके पहचाना जा सकता है ।
वास्तव में, यह वही है जो मैं एक इन-हाउस एप्लिकेशन के साथ करता हूं जो मैंने लिखा है, और जिस पर मैं जरूरत पड़ने पर एक नई प्रणाली के वर्चुअन को जल्दी से जोड़ सकता हूं। इस तरह, मुझे उस पर भरोसा करने की ज़रूरत नहीं है कि जिस पाइप को मेरे आवेदन की आवश्यकता है, उसे सफलतापूर्वक डाउनलोड करने में सक्षम होगा। मैं भी मानस psopopg2 जो मैं उपयोग के संकलन के बारे में चिंता करने की ज़रूरत नहीं होगी ।
यदि आप नहीं जानते हैं कि आपका एप्लिकेशन किस ऑपरेटिंग सिस्टम पर चल सकता है, तो आप संभवतः pip freeze
अन्य उत्तरों में सुझाए गए उपयोग से बेहतर हैं।
मुझे लगता है कि रिपॉजिटरी फ़ोल्डर के अंदर एक पथ में आभासी वातावरण को स्थापित करने के लिए सबसे अच्छा है, शायद पर्यावरण के लिए समर्पित एक उपनिर्देशिका का उपयोग करने के लिए बेहतर है (जब मैंने भंडार में एक आभासी वातावरण स्थापित करने पर बलपूर्वक गलती से मेरी पूरी परियोजना को हटा दिया है फ़ोल्डर, अच्छा है कि मैं अपने नवीनतम संस्करण Github में सहेजा गया था)।
या तो स्वचालित इंस्टॉलर, या प्रलेखन को वर्चुअलएनव पथ को एक सापेक्ष पथ के रूप में इंगित करना चाहिए, इस तरह आप अन्य लोगों के साथ प्रोजेक्ट साझा करते समय समस्याओं में नहीं चलेंगे। पैकेजों के बारे में, उपयोग किए जाने वाले पैकेजों को सहेजना चाहिए pip freeze -r requirements.txt
।
यदि आप सिर्फ विकास एनवी की स्थापना कर रहे हैं, तो पाइप फ्रीज़ फ़ाइल, काज का उपयोग करें जो गिट रेपो को साफ करता है।
फिर यदि उत्पादन परिनियोजन करते हैं, तो पूरे venv फ़ोल्डर की जांच करें। यह आपकी तैनाती को और अधिक प्रतिलिपि प्रस्तुत करने योग्य बना देगा, न कि उन libxxx-dev संकुल की जरूरत है, और इंटरनेट के मुद्दों से बचें।
तो दो रिपोज हैं। आपके मुख्य स्रोत कोड के लिए एक, जिसमें एक आवश्यकताएँ शामिल हैं। और एक एनवी रेपो, जिसमें पूरा वीवी फोल्डर होता है।