गिट कमिट डिलीशन को समझना
एक स्वच्छ और संगठित परियोजना को बनाए रखने के लिए अपनी Git शाखा के इतिहास को प्रभावी ढंग से प्रबंधित करना महत्वपूर्ण है। कभी-कभी, आपको परिवर्तनों को पूर्ववत करने या अपने प्रतिबद्ध इतिहास को साफ़ करने के लिए अपनी शाखा से एक विशिष्ट प्रतिबद्धता को हटाने की आवश्यकता हो सकती है।
इस गाइड में, हम Git शाखा से किसी कमिट को सुरक्षित रूप से हटाने के चरणों का पता लगाएंगे, जिसमें आमतौर पर संदर्भित `git रीसेट --हार्ड HEAD` सहित विभिन्न Git कमांड के उपयोग पर चर्चा की जाएगी। अंत तक, आपको अपनी प्रतिबद्धताओं को कुशलतापूर्वक प्रबंधित करने की स्पष्ट समझ हो जाएगी।
आज्ञा | विवरण |
---|---|
git log | रिपॉजिटरी के लिए प्रतिबद्ध इतिहास प्रदर्शित करता है। |
git reset --hard <commit_hash> | वर्तमान शाखा को निर्दिष्ट कमिट पर रीसेट करता है, उस कमिट के बाद सभी परिवर्तनों को त्याग देता है। |
git push origin HEAD --force | स्थानीय रिपॉजिटरी से मिलान करने के लिए रिमोट रिपॉजिटरी को जबरन अपडेट करता है। |
git reset --hard HEAD~1 | नवीनतम कमिट से ठीक पहले, परिवर्तनों को त्यागते हुए, वर्तमान शाखा को कमिट में रीसेट करता है। |
git revert <commit_hash> | एक नई कमिट बनाता है जो निर्दिष्ट कमिट द्वारा किए गए परिवर्तनों को पूर्ववत करता है। |
गिट कमिट रिमूवल तकनीकों को समझना
ऊपर दी गई स्क्रिप्ट Git शाखा से कमिट को हटाने या वापस लाने के लिए दो प्राथमिक तरीकों को प्रदर्शित करती है। पहली विधि का उपयोग करता है git reset --hard इतिहास से प्रतिबद्धताओं को पूरी तरह से हटाने के लिए। का उपयोग करके git log, आप उस विशिष्ट कमिट हैश की पहचान कर सकते हैं जिस पर आप रीसेट करना चाहते हैं। आदेश git reset --hard <commit_hash> फिर आपकी शाखा को उस प्रतिबद्धता पर रीसेट कर देगा, बाद के सभी परिवर्तनों को प्रभावी ढंग से हटा देगा। यह विधि अवांछित परिवर्तनों को स्थायी रूप से हटाने के लिए विशेष रूप से उपयोगी है और इसका पालन किया जाता है git push origin HEAD --force दूरस्थ रिपॉजिटरी को अद्यतन करने के लिए, यह सुनिश्चित करते हुए कि परिवर्तन सभी क्लोन रिपॉजिटरी में परिलक्षित होते हैं।
दूसरी विधि का उपयोग करता है git revert एक नई कमिट बनाने के लिए जो पिछली कमिट द्वारा किए गए परिवर्तनों को पूर्ववत कर देती है। यह दृष्टिकोण अधिक रूढ़िवादी है क्योंकि यह अवांछित प्रतिबद्धता के प्रभावों को समाप्त करते हुए प्रतिबद्ध इतिहास को संरक्षित करता है। कमिट हैश की पहचान करके git log और उपयोग कर रहे हैं git revert <commit_hash>, आप मौजूदा प्रतिबद्ध इतिहास में बदलाव किए बिना परिवर्तनों को प्रभावी ढंग से उलट सकते हैं। इस विधि का अनुसरण सरल तरीके से किया जाता है git push origin main दूरस्थ रिपॉजिटरी के साथ परिवर्तनों को सिंक्रनाइज़ करने के लिए। स्वच्छ और प्रबंधनीय परियोजना इतिहास को बनाए रखने के लिए दोनों विधियाँ महत्वपूर्ण हैं।
Git ब्रांच से कमिट कैसे हटाएं
Git कमांड का उपयोग करना
# Navigate to your repository
cd /path/to/your/repo
# Use git log to find the commit hash you want to remove
git log
# Reset to the commit just before the one you want to remove
git reset --hard <commit_hash>
# Push the changes to the remote repository
git push origin HEAD --force
# If you only want to remove the last commit
git reset --hard HEAD~1
# Verify the commit has been removed
git log
किसी प्रतिबद्धता को वापस करने का वैकल्पिक तरीका
गिट रिवर्ट का उपयोग करना
# Navigate to your repository
cd /path/to/your/repo
# Use git log to find the commit hash you want to revert
git log
# Revert the commit by creating a new commit that undoes the changes
git revert <commit_hash>
# Push the changes to the remote repository
git push origin main
# Verify the changes
git log
अतिरिक्त गिट कमिट प्रबंधन तकनीकों की खोज
Git में कमिट प्रबंधित करने की एक अन्य विधि में इंटरैक्टिव रिबेस कमांड का उपयोग करना शामिल है। git rebase -i कमांड आपको अपने शाखा इतिहास में कमिट्स को फिर से ऑर्डर करने, स्क्वैश करने या संपादित करने की अनुमति देता है। यह विशेष रूप से उपयोगी हो सकता है जब आप कई छोटी प्रतिबद्धताओं को एक एकल, अधिक सार्थक प्रतिबद्धता में जोड़ना चाहते हैं, या जब आपको इतिहास से किसी विशिष्ट प्रतिबद्धता को हटाने की आवश्यकता होती है। एक इंटरैक्टिव रिबेस शुरू करने के लिए, आप इसका उपयोग करेंगे git rebase -i HEAD~n, जहां "एन" उन प्रतिबद्धताओं की संख्या है जिनकी आप समीक्षा करना चाहते हैं। यह एक संपादक खोलता है जहां आप आवश्यकतानुसार कमिट को संशोधित कर सकते हैं।
इंटरएक्टिव रिबेस एक शक्तिशाली उपकरण है, लेकिन टकराव से बचने और आपके प्रतिबद्ध इतिहास की अखंडता को बनाए रखने के लिए इसे सावधानीपूर्वक संभालने की आवश्यकता है। इंटरैक्टिव रिबेस का उपयोग करते समय, यह याद रखना महत्वपूर्ण है कि किसी साझा शाखा के प्रतिबद्ध इतिहास को बदलने से अन्य सहयोगी प्रभावित हो सकते हैं। हमेशा अपनी टीम के साथ संवाद करें और केवल स्थानीय या फीचर शाखाओं पर ही पुनः आधार बनाने पर विचार करें। रिबेस पूरा करने के बाद आप उपयोग कर सकते हैं git push origin branch-name --force रिमोट रिपॉजिटरी को अपडेट करने के लिए।
गिट कमिट मैनेजमेंट के बारे में सामान्य प्रश्न
- के बीच क्या अंतर है git reset और git revert?
- git reset जबकि, शाखा इतिहास से कमिट हटा देता है git revert एक नई प्रतिबद्धता बनाता है जो परिवर्तनों को पूर्ववत करता है।
- मैं परिवर्तनों को खोए बिना अंतिम प्रतिबद्धता को कैसे पूर्ववत कर सकता हूं?
- उपयोग git reset --soft HEAD~1 अंतिम प्रतिबद्धता को पूर्ववत करने के लिए लेकिन परिवर्तनों को अपनी कार्यशील निर्देशिका में रखें।
- क्या यह उपयोग करने के लिए सुरक्षित है git reset --hard?
- यदि आप सुनिश्चित हैं कि आप किसी विशिष्ट प्रतिबद्धता के बाद सभी परिवर्तनों को छोड़ना चाहते हैं तो यह सुरक्षित है, लेकिन इसका उपयोग सावधानी से करें, विशेष रूप से साझा शाखाओं पर।
- क्या करता है git rebase -i करना?
- यह आपको कमिट इतिहास को अंतःक्रियात्मक रूप से संपादित करने की अनुमति देता है, जिसमें कमिट को पुन: व्यवस्थित करना, स्क्वैश करना या हटाना शामिल है।
- मैं रिबेस के दौरान विवादों का समाधान कैसे करूँ?
- आप अपने संपादक में विवादों को मैन्युअल रूप से हल कर सकते हैं और फिर उपयोग कर सकते हैं git rebase --continue आगे बढ़ने के लिए।
- क्या मैं पूर्ववत कर सकता हूँ? git reset?
- केवल यदि आप अभी तक नहीं दौड़े हैं git gc या git prune, आप इसका उपयोग करके खोई हुई प्रतिबद्धताओं को पुनर्प्राप्त करने में सक्षम हो सकते हैं git reflog.
Git प्रतिबद्धताओं के प्रबंधन पर अंतिम विचार
स्वच्छ और कुशल रिपॉजिटरी बनाए रखने के लिए Git में कमिट का उचित प्रबंधन आवश्यक है। चाहे आप कमिट्स को हटाना चाहें git reset, के साथ परिवर्तन पूर्ववत करें git revert, या इंटरैक्टिव रिबेस के साथ अपने इतिहास को परिष्कृत करें, प्रत्येक विधि के अपने उपयोग के मामले हैं। साझा शाखाओं को बदलते समय अपनी टीम के साथ संवाद करना और इन शक्तिशाली आदेशों का जिम्मेदारी से उपयोग करना महत्वपूर्ण है। इन तकनीकों में महारत हासिल करके, आप एक अधिक संगठित और विश्वसनीय संस्करण नियंत्रण प्रणाली सुनिश्चित कर सकते हैं, जिससे अंततः सुचारू विकास कार्यप्रवाह हो सकेगा।