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

Shell Script and Git Configuration

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*) सेट करती है। चलाकर , हम यह सुनिश्चित करते हैं कि मर्ज के दौरान ये फ़ाइलें अधिलेखित न हों। आदेश "हमारी" रणनीति को पहचानने के लिए Git को कॉन्फ़िगर करें, जो मर्ज के दौरान फ़ाइल के वर्तमान शाखा संस्करण को रखता है।

दूसरी स्क्रिप्ट "keepBranchResources" नाम का एक कस्टम मर्ज ड्राइवर पेश करती है . यह ड्राइवर "हमारी" रणनीति के समान कार्य करता है लेकिन इसे विशेष रूप से ब्रांड संसाधनों के लिए तैयार किया गया है। स्क्रिप्ट *.gitattributes* के साथ अपडेट होती है , यह सुनिश्चित करना कि मर्ज के दौरान ब्रांड-विशिष्ट फ़ाइलें संरक्षित हैं। स्वचालन स्क्रिप्ट अनेक शाखाओं से गुजरती है, उनकी जाँच करती है और के साथ विलय हो रहा है 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. आदेश का प्रयोग करें और इसे परिभाषित करें .
  3. क्या मैं अनेक शाखाओं के लिए विलय प्रक्रिया को स्वचालित कर सकता हूँ?
  4. हां, प्रक्रिया का उपयोग करके स्क्रिप्टिंग करके और एक लूप में आदेश.
  5. Git हुक क्या है और यह कैसे मदद कर सकता है?
  6. Git हुक Git इवेंट से पहले या बाद में चलने वाली स्क्रिप्ट हैं। प्री-मर्ज हुक मर्ज रणनीतियों को स्वचालित रूप से लागू कर सकता है।
  7. सबमॉड्यूल ब्रांड-विशिष्ट संसाधनों के प्रबंधन में कैसे मदद कर सकते हैं?
  8. सबमॉड्यूल आपको अपने रिपॉजिटरी के कुछ हिस्सों को स्वतंत्र रूप से प्रबंधित करने की अनुमति देते हैं, जो ब्रांड संपत्तियों के अलग-अलग अपडेट के लिए आदर्श है।
  9. "हमारी" विलय रणनीति क्या है?
  10. "हमारी" रणनीति विलय के दौरान फ़ाइल की वर्तमान शाखा के संस्करण को बनाए रखती है, अन्य शाखा के परिवर्तनों को अनदेखा करती है।
  11. मैं विशिष्ट मर्ज व्यवहार के लिए .gitattributes को कैसे कॉन्फ़िगर करूँ?
  12. उपयोग विशिष्ट फ़ाइलों के लिए कस्टम मर्ज व्यवहार को परिभाषित करने के लिए।
  13. क्या मैं Git में फ़ास्ट-फ़ॉरवर्ड मर्ज को रोक सकता हूँ?
  14. हाँ, प्रयोग करके , आप तेजी से आगे बढ़ना संभव होने पर भी मर्ज कमिट को बाध्य कर सकते हैं।
  15. मैं Git हुक को निष्पादन योग्य कैसे बना सकता हूँ?
  16. आदेश का प्रयोग करें फ़ाइल की अनुमतियाँ बदलने और इसे निष्पादन योग्य बनाने के लिए।
  17. यदि कुछ गलत हो जाता है तो क्या मैं मर्ज को पूर्ववत कर सकता हूँ?
  18. हाँ, आप उपयोग कर सकते हैं मर्ज से पहले पिछली प्रतिबद्धता पर वापस लौटने के लिए।

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

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