Git मध्ये विशिष्ट उपनिर्देशिका क्लोनिंग

Git configuration

क्लोनिंग उपनिर्देशिका: एक द्रुत विहंगावलोकन

Git सह आवृत्ती नियंत्रण व्यवस्थापित करताना, SVN सारख्या जुन्या प्रणालींच्या तुलनेत भिन्न परिस्थितींना भिन्न दृष्टिकोन आवश्यक असतात. विशेषत:, विविध विकास कार्यप्रवाहांसाठी रिपॉझिटरीच्या उपनिर्देशिका निवडकपणे क्लोन करण्याची क्षमता महत्त्वपूर्ण असू शकते. जेव्हा प्रोजेक्ट स्ट्रक्चर्स क्लिष्ट असतात किंवा जेव्हा तुम्हाला रिपॉझिटरीच्या फक्त एका भागासह कार्य करण्याची आवश्यकता असते तेव्हा हे वैशिष्ट्य विशेषतः उपयुक्त आहे.

SVN मध्ये, रिपॉजिटरीमधून वेगवेगळ्या ठिकाणी उपनिर्देशिका तपासणे सोपे होते. तथापि, Git रेपॉजिटरी डेटा वेगळ्या पद्धतीने हाताळते, ज्याने 'svn co' सारख्या SVN कमांडशी थेट समतुल्य कमी स्पष्ट होते. हे मार्गदर्शक विरळ चेकआउट आणि इतर रणनीती वापरून Git समान परिणाम कसे मिळवू शकते हे एक्सप्लोर करेल.

आज्ञा वर्णन
git init सर्व आवश्यक मेटाडेटासह प्रारंभिक .git निर्देशिका तयार करून, नवीन Git रेपॉजिटरी सुरू करते.
git remote add -f तुमच्या Git कॉन्फिगरेशनमध्ये एक नवीन रिमोट रिपॉजिटरी जोडते आणि ते लगेच मिळवते.
git config core.sparseCheckout true विरळ-चेकआउट वैशिष्ट्य सक्षम करते, जे रेपॉजिटरीच्या आंशिक चेकआउटला अनुमती देते.
echo "finisht/*" >> .git/info/sparse-checkout कोणती उपडिरेक्ट्री चेक आउट करायची हे परिभाषित करण्यासाठी स्पार्स-चेकआउट कॉन्फिगरेशन फाइलमध्ये 'finisht/*' पथ जोडते.
git pull origin master 'मूळ' रिमोटमधून 'मास्टर' शाखा खेचते, विरळ-चेकआउट नियम वापरून केवळ निर्दिष्ट उपनिर्देशिका पुनर्प्राप्त करण्यासाठी.
git sparse-checkout set कार्यरत निर्देशिकेमध्ये पॉप्युलेट केलेले पथ कॉन्फिगर करते.

गिट स्पार्स चेकआउट आणि स्क्रिप्ट वर्कफ्लोचे स्पष्टीकरण

प्रदान केलेल्या स्क्रिप्ट्स Git रेपॉजिटरीमधून विशिष्ट उपनिर्देशिका क्लोन करण्यासाठी डिझाइन केल्या आहेत, SVN सोबत पूर्वी उपलब्ध असलेल्या वर्तनाची नक्कल करून. रिपॉझिटरीच्या केवळ काही भागांची आवश्यकता असलेल्या वातावरणात, यामुळे डेटा मिळवण्यात लक्षणीय घट होऊ शकते, कार्यक्षमता सुधारते. पहिली स्क्रिप्ट चे संयोजन वापरते , , आणि नवीन Git रेपॉजिटरी सुरू करण्यासाठी, रिमोट स्त्रोत जोडा आणि विरळ चेकआउट सक्षम करा जे रेपॉजिटरी सामग्रीच्या निवडक क्लोनिंगसाठी परवानगी देते.

त्यानंतर, 'finisht/*' सारखे पथ विरळ-चेकआउट कॉन्फिगरेशनमध्ये द्वारे जोडले जातात आदेश, Git ला फक्त त्या विशिष्ट डिरेक्टरीज आणण्यासाठी निर्देशित करते. आज्ञा रिमोट रिपॉझिटरीच्या मास्टर ब्रँचमधून फक्त कॉन्फिगर केलेल्या उपडिरेक्टरीज खेचण्यासाठी वापरला जातो. दुसरी स्क्रिप्ट फायदा घेते कमांड, अलीकडील गिट आवृत्त्यांमध्ये सादर करण्यात आलेला अधिक सुव्यवस्थित दृष्टीकोन जो थेट निर्देशिकेचे मार्ग निर्दिष्ट करणे सुलभ करते, स्पष्टता वाढवते आणि काय तपासले जाते यावर नियंत्रण ठेवते.

गिट रिपॉझिटरीजमध्ये क्लोनिंगसाठी उपनिर्देशिका अलग करणे

बॅश आणि गिट कमांड वापरणे

mkdir specific-dir-clone
cd specific-dir-clone
git init
git remote add -f origin https://your-repository-url.git
git config core.sparseCheckout true
echo "finisht/*" >> .git/info/sparse-checkout
git pull origin master
cd ..
mkdir another-specific-dir
cd another-specific-dir
git init
git remote add -f origin https://your-repository-url.git
git config core.sparseCheckout true
echo "static/*" >> .git/info/sparse-checkout
git pull origin master

Git मध्ये उपडिरेक्ट्रीजसाठी स्पार्स चेकआउट लागू करणे

Git स्पार्स-चेकआउट वैशिष्ट्य वापरणे

निर्देशिका-विशिष्ट ऑपरेशन्ससाठी Git मधील प्रगत तंत्रे

Git मधील उपनिर्देशिका क्लोनिंग करण्याच्या मूलभूत पद्धतींव्यतिरिक्त, प्रगत तंत्रे आहेत जी विकासक अनेक प्रकल्पांसह मोठ्या भांडारांचे व्यवस्थापन कसे करतात हे आणखी ऑप्टिमाइझ करू शकतात. अशा पद्धतीचा वापर समाविष्ट आहे . हा आदेश गिट रेपॉजिटरीला इतर गिट रेपॉजिटरी सबमॉड्यूल म्हणून समाविष्ट करण्यास अनुमती देतो, जे पालकांसह क्लोन केले जाऊ शकतात परंतु स्वतंत्रपणे राखले जाऊ शकतात. हे विशेषतः उपयोगी असते जेव्हा रेपॉजिटरीचे वेगवेगळे भाग वेगळे करणे आवश्यक असते परंतु तरीही ते केंद्रीय भांडारातून नियंत्रित केले जाते.

आणखी एक प्रगत वैशिष्ट्य म्हणजे वापर एकत्रित . हे संयोजन तुम्हाला उपडिरेक्ट्रीचा इतिहास जतन करून नवीन, वेगळ्या Git रिपॉझिटरीमध्ये काढण्याची परवानगी देते. जेव्हा एखादा प्रकल्प स्वतःच्या अस्तित्वात वाढतो आणि त्याचा ऐतिहासिक संदर्भ न गमावता मुख्य भांडारापासून दूर जाणे आवश्यक असते अशा परिस्थितींसाठी हे आदर्श आहे.

  1. मी गिट रेपॉजिटरीमधून फक्त एक निर्देशिका क्लोन करू शकतो?
  2. होय, सारख्या आज्ञा वापरून किंवा फक्त त्या निर्देशिकेतील सामग्रीसह एक वेगळी शाखा तयार करणे.
  3. Git मध्ये विरळ चेकआउट म्हणजे काय?
  4. स्पार्स चेकआउट तुम्हाला संपूर्ण प्रोजेक्ट डाउनलोड न करता रिपॉजिटरीमधून काही फोल्डर्स किंवा फाइल्स निवडकपणे तपासू देते.
  5. मी सबडिरेक्टरीसाठी सबमॉड्यूल कसे वापरू?
  6. सह सबमॉड्यूल जोडा इच्छित भांडार आणि मार्गाकडे निर्देश करत आहे.
  7. मी उपडिरेक्टरी नवीन रेपॉजिटरीमध्ये विभक्त करू शकतो का?
  8. होय, वापरून फक्त उपनिर्देशिकेच्या इतिहासासह एक नवीन शाखा तयार करण्यासाठी, जी नंतर क्लोन केली जाऊ शकते.
  9. git submodule आणि git subtree मध्ये काय फरक आहे?
  10. सबमॉड्यूल तुमच्या प्रोजेक्टमध्ये डिपेंडेंसी म्हणून वेगळ्या रेपॉजिटरी लिंक करतात, तर सबट्रीज तुमच्या प्रोजेक्टमध्ये दुसऱ्या रेपॉजिटरीला परत विभाजित करण्याच्या क्षमतेसह विलीन करतात.

Git वैयक्तिक डिरेक्ट्रीसाठी SVN च्या चेकआउटच्या समतुल्य थेट कमांड प्रदान करत नाही, तर विरळ चेकआउट, सबमॉड्यूल्स आणि सबट्री स्ट्रॅटेजीजचा वापर मजबूत पर्याय देतात. या पद्धती केवळ प्रतिकृती बनवत नाहीत तर जुन्या आवृत्ती नियंत्रण प्रणालीद्वारे प्रदान केलेली कार्यक्षमता वाढवतात. SVN मधून संक्रमण करणाऱ्या किंवा Git मधील जटिल प्रकल्प व्यवस्थापित करणाऱ्या विकासकांसाठी, या तंत्रांवर प्रभुत्व मिळवणे त्यांच्या विकास प्रक्रियेस लक्षणीयरीत्या सुव्यवस्थित करू शकते.