Git शाखाओं में फ़ाइल मर्ज को कैसे रोकें

Git शाखाओं में फ़ाइल मर्ज को कैसे रोकें
Git शाखाओं में फ़ाइल मर्ज को कैसे रोकें

Git शाखाओं में कस्टम संसाधनों का प्रबंधन

कई ब्रांडों में वितरित एप्लिकेशन पर काम करते समय, निरंतरता बनाए रखना चुनौतीपूर्ण हो सकता है। प्रत्येक ब्रांड में अद्वितीय लोगो छवियां और शैली संसाधन हो सकते हैं, जबकि बाकी सामग्री समान रहती है। ये ब्रांड-विशिष्ट संस्करण Git रिपॉजिटरी के भीतर अलग-अलग शाखाओं में संग्रहीत हैं।

अक्सर, आपको इन शाखाओं को मुख्य शाखाओं के साथ विलय करने की आवश्यकता होगी, लेकिन इन विलयों के दौरान कस्टम संसाधनों को अपरिवर्तित रखना महत्वपूर्ण है। यह आलेख विशिष्ट संसाधनों के लिए फ़ाइल मर्ज को रोकने के तरीकों की पड़ताल करता है, यह सुनिश्चित करता है कि फास्ट-फॉरवर्ड मर्ज के दौरान भी ब्रांड-विशिष्ट फ़ाइलें अपरिवर्तित रहें।

आज्ञा विवरण
git config merge.ours.driver true "हमारी" मर्ज रणनीति का उपयोग करने के लिए Git को कॉन्फ़िगर करें, जो मर्ज के दौरान फ़ाइल का वर्तमान शाखा संस्करण रखता है।
echo 'path/to/logo.png merge=ours' >>echo 'path/to/logo.png merge=ours' >> .gitattributes निर्दिष्ट फ़ाइल के लिए हमेशा "हमारी" रणनीति का उपयोग करने के लिए .gitattributes में एक नियम जोड़ता है, इसे मर्ज के दौरान संशोधित होने से रोकता है।
git config merge.keepBranchResources.driver "true" "KeepBranchResources" नामक एक कस्टम मर्ज ड्राइवर को परिभाषित करता है जो विलय के दौरान फ़ाइलों के वर्तमान शाखा संस्करण को हमेशा रखता है।
echo 'path/to/logo.png merge=keepBranchResources' >>echo 'path/to/logo.png merge=keepBranchResources' >> .gitattributes निर्दिष्ट फ़ाइल के लिए कस्टम मर्ज ड्राइवर का उपयोग करने के लिए .gitattributes में एक नियम जोड़ता है, यह सुनिश्चित करते हुए कि यह मर्ज के दौरान अपरिवर्तित रहता है।
git checkout $branch कार्यशील निर्देशिका को निर्दिष्ट शाखा में स्विच करता है, जिससे शाखा-विशिष्ट संचालन करने की अनुमति मिलती है।
git merge main --strategy-option ours "हमारी" रणनीति का उपयोग करके मुख्य शाखा को वर्तमान शाखा में विलय करता है, यह सुनिश्चित करता है कि परस्पर विरोधी फ़ाइलें वर्तमान शाखा का संस्करण बनाए रखती हैं।
chmod +x $HOOK_FILE इसे निष्पादन योग्य बनाने के लिए निर्दिष्ट हुक स्क्रिप्ट की फ़ाइल अनुमतियों को बदलता है, जिससे इसे विलय के दौरान Git द्वारा चलाने की अनुमति मिलती है।

Git स्क्रिप्ट की विस्तृत व्याख्या

ऊपर दी गई स्क्रिप्ट विशिष्ट ब्रांड-संबंधित फ़ाइलों को संरक्षित करते हुए Git शाखाओं के विलय को प्रबंधित करने के लिए डिज़ाइन की गई हैं। पहली स्क्रिप्ट लोगो और स्टाइलशीट जैसी निर्दिष्ट फ़ाइलों के लिए "हमारी" मर्ज रणनीति का उपयोग करने के लिए एक Git विशेषता फ़ाइल (*.gitattributes*) सेट करती है। चलाकर echo 'path/to/logo.png merge=ours' >> .gitattributes, हम यह सुनिश्चित करते हैं कि मर्ज के दौरान ये फ़ाइलें अधिलेखित न हों। आदेश git config merge.ours.driver true "हमारी" रणनीति को पहचानने के लिए Git को कॉन्फ़िगर करें, जो मर्ज के दौरान फ़ाइल के वर्तमान शाखा संस्करण को रखता है।

दूसरी स्क्रिप्ट "keepBranchResources" नाम का एक कस्टम मर्ज ड्राइवर पेश करती है git config merge.keepBranchResources.driver "true". यह ड्राइवर "हमारी" रणनीति के समान कार्य करता है लेकिन इसे विशेष रूप से ब्रांड संसाधनों के लिए तैयार किया गया है। स्क्रिप्ट *.gitattributes* के साथ अपडेट होती है echo 'path/to/logo.png merge=keepBranchResources' >> .gitattributes, यह सुनिश्चित करना कि मर्ज के दौरान ब्रांड-विशिष्ट फ़ाइलें संरक्षित हैं। स्वचालन स्क्रिप्ट अनेक शाखाओं से गुजरती है, उनकी जाँच करती है git checkout $branch और के साथ विलय हो रहा है git merge main --strategy-option ours सभी शाखाओं में रणनीति लागू करना।

विशिष्ट फ़ाइलों को मर्ज करने से रोकने के लिए Git विशेषताओं का उपयोग करना

शेल स्क्रिप्ट और गिट कॉन्फ़िगरेशन

#!/bin/bash
# Set up .gitattributes to prevent merging specific files
echo 'path/to/logo.png merge=ours' >> .gitattributes
echo 'path/to/style.css merge=ours' >> .gitattributes
# Configure Git to use "ours" merge strategy
git config merge.ours.driver true
echo ".gitattributes set up successfully."
echo "Git configured to prevent merge conflicts for specific files."

विशिष्ट फ़ाइलों को संभालने के लिए कस्टम मर्ज ड्राइवर

शेल स्क्रिप्ट और गिट कॉन्फ़िगरेशन

#!/bin/bash
# Define a custom merge driver
git config merge.keepBranchResources.name "Keep Brand Resources"
git config merge.keepBranchResources.driver "true"
# Set up .gitattributes to use the custom merge driver
echo 'path/to/logo.png merge=keepBranchResources' >> .gitattributes
echo 'path/to/style.css merge=keepBranchResources' >> .gitattributes
echo "Custom merge driver configured."
echo ".gitattributes updated with custom merge strategy."

एकाधिक शाखाओं के लिए स्वचालित मर्ज रणनीति सेटअप

स्वचालन के लिए शैल स्क्रिप्ट

#!/bin/bash
# List of branches to set up
branches=("brand1" "brand2" "brand3")
# Loop through branches and apply configurations
for branch in "${branches[@]}"; do
  git checkout $branch
  git merge main --strategy-option ours
  echo "Applied merge strategy to $branch"
done
echo "Merge strategy applied to all branches."

उदाहरण: लगातार मर्ज व्यवहार सुनिश्चित करने के लिए गिट हुक का उपयोग करना

गिट हुक के लिए शैल स्क्रिप्ट

#!/bin/bash
# Pre-merge hook script to set merge strategy
echo "Setting up pre-merge hook..."
HOOK_DIR=".git/hooks"
HOOK_FILE="$HOOK_DIR/pre-merge"
echo "#!/bin/bash" > $HOOK_FILE
echo 'git merge -X ours' >> $HOOK_FILE
chmod +x $HOOK_FILE
echo "Pre-merge hook set up successfully."

Git में विलय के लिए उन्नत रणनीतियाँ

मर्ज रणनीतियों और कस्टम ड्राइवरों का उपयोग करने के अलावा, विशिष्ट फ़ाइल मर्ज को प्रबंधित करने का एक और शक्तिशाली तरीका Git हुक का उपयोग करना है। हुक वे स्क्रिप्ट हैं जिन्हें Git कमिट और मर्ज जैसी घटनाओं से पहले या बाद में निष्पादित करता है। उदाहरण के लिए, विशिष्ट फ़ाइलों पर "हमारी" रणनीति को स्वचालित रूप से लागू करने के लिए एक प्री-मर्ज हुक स्थापित किया जा सकता है। यह सुनिश्चित करता है कि विलय संबंधी विवादों के बावजूद कुछ संसाधन अपरिवर्तित रहेंगे। हुक रिपॉजिटरी नीतियों को लागू करने के लिए एक उच्च अनुकूलन योग्य तरीका प्रदान करते हैं और इसे जटिल वर्कफ़्लो के अनुरूप बनाया जा सकता है।

विचार करने योग्य एक अन्य पहलू ब्रांड-विशिष्ट संसाधनों के लिए सबमॉड्यूल का उपयोग है। लोगो और शैलियों को सबमॉड्यूल में रखकर, इन्हें मुख्य भंडार से स्वतंत्र रूप से प्रबंधित किया जा सकता है। यह मुख्य एप्लिकेशन कोड को प्रभावित किए बिना ब्रांड संपत्तियों को अपडेट करने की अनुमति देता है। सबमॉड्यूल उन परियोजनाओं के लिए आदर्श हैं जहां रिपॉजिटरी के हिस्से स्वतंत्र रूप से विकसित होते हैं और संस्करण नियंत्रण अलगाव की आवश्यकता होती है।

गिट मर्ज मुद्दों के लिए सामान्य प्रश्न और समाधान

  1. मैं कस्टम मर्ज रणनीति कैसे स्थापित करूं?
  2. आदेश का प्रयोग करें git config merge.drivername.driver true और इसे परिभाषित करें .gitattributes.
  3. क्या मैं अनेक शाखाओं के लिए विलय प्रक्रिया को स्वचालित कर सकता हूँ?
  4. हां, प्रक्रिया का उपयोग करके स्क्रिप्टिंग करके git checkout और git merge एक लूप में आदेश.
  5. Git हुक क्या है और यह कैसे मदद कर सकता है?
  6. Git हुक Git इवेंट से पहले या बाद में चलने वाली स्क्रिप्ट हैं। प्री-मर्ज हुक मर्ज रणनीतियों को स्वचालित रूप से लागू कर सकता है।
  7. सबमॉड्यूल ब्रांड-विशिष्ट संसाधनों के प्रबंधन में कैसे मदद कर सकते हैं?
  8. सबमॉड्यूल आपको अपने रिपॉजिटरी के कुछ हिस्सों को स्वतंत्र रूप से प्रबंधित करने की अनुमति देते हैं, जो ब्रांड संपत्तियों के अलग-अलग अपडेट के लिए आदर्श है।
  9. "हमारी" विलय रणनीति क्या है?
  10. "हमारी" रणनीति विलय के दौरान फ़ाइल की वर्तमान शाखा के संस्करण को बनाए रखती है, अन्य शाखा के परिवर्तनों को अनदेखा करती है।
  11. मैं विशिष्ट मर्ज व्यवहार के लिए .gitattributes को कैसे कॉन्फ़िगर करूँ?
  12. उपयोग echo 'path/to/file merge=strategy' >> .gitattributes विशिष्ट फ़ाइलों के लिए कस्टम मर्ज व्यवहार को परिभाषित करने के लिए।
  13. क्या मैं Git में फ़ास्ट-फ़ॉरवर्ड मर्ज को रोक सकता हूँ?
  14. हाँ, प्रयोग करके git merge --no-ff, आप तेजी से आगे बढ़ना संभव होने पर भी मर्ज कमिट को बाध्य कर सकते हैं।
  15. मैं Git हुक को निष्पादन योग्य कैसे बना सकता हूँ?
  16. आदेश का प्रयोग करें chmod +x path/to/hook फ़ाइल की अनुमतियाँ बदलने और इसे निष्पादन योग्य बनाने के लिए।
  17. यदि कुछ गलत हो जाता है तो क्या मैं मर्ज को पूर्ववत कर सकता हूँ?
  18. हाँ, आप उपयोग कर सकते हैं git reset --hard HEAD~1 मर्ज से पहले पिछली प्रतिबद्धता पर वापस लौटने के लिए।

गिट मर्ज के प्रबंधन पर अंतिम विचार

कई Git शाखाओं में ब्रांड-विशिष्ट संसाधनों को बनाए रखना जटिल हो सकता है, लेकिन सही रणनीतियों के साथ इसे प्रबंधित किया जा सकता है। Git विशेषताओं और कस्टम मर्ज ड्राइवरों का उपयोग करके, आप यह सुनिश्चित कर सकते हैं कि मर्ज के दौरान लोगो और स्टाइलशीट जैसी फ़ाइलें अपरिवर्तित रहें। ऑटोमेशन स्क्रिप्ट और Git हुक नियंत्रण की एक अतिरिक्त परत जोड़ते हैं, जिससे प्रक्रिया अधिक कुशल और त्रुटि-प्रूफ बन जाती है। इन तरीकों को लागू करके, आप अपने वर्कफ़्लो को सुव्यवस्थित कर सकते हैं और अपने एप्लिकेशन के सभी ब्रांड संस्करणों में स्थिरता बनाए रख सकते हैं।