git - 'गिट पुल' और 'गिट फ़ेच' के बीच क्या अंतर है?




git-pull git-fetch (20)

मॉडरेटर नोट: यह देखते हुए कि इस प्रश्न में पहले से ही साठ-सात उत्तर पोस्ट किए गए हैं (उनमें से कुछ हटा दिए गए हैं), इस पर विचार करें कि आप किसी और को पोस्ट करने से पहले कुछ नया योगदान दे रहे हैं या नहीं।

git pull और git fetch बीच अंतर क्या हैं?

https://code.i-harness.com


बीच क्या अंतर है git pullऔर git fetch?

इसे समझने के लिए, आपको सबसे पहले यह समझने की आवश्यकता है कि आपका स्थानीय गिट न केवल आपके स्थानीय भंडार को बनाए रखता है, बल्कि यह रिमोट रिपोजिटरी की स्थानीय प्रति भी बनाए रखता है।

git fetchरिमोट रिपोजिटरी की अपनी स्थानीय प्रति अद्यतित लाता है। उदाहरण के लिए, यदि आपका रिमोट रिपोजिटरी गिटहब है - तो आप रिमोट रिपॉजिटरी में रिमोट रिपोजिटरी की अपनी स्थानीय प्रतिलिपि में किए गए किसी भी बदलाव को प्राप्त करना चाह सकते हैं। यह आपको तुलना या विलय जैसे संचालन करने की अनुमति देगा।

git pullदूसरी तरफ रिमोट रिपोजिटरी में बदलावों को नीचे लाएगा जहां आप अपना कोड रखते हैं। आम तौर पर, रिमोट रिपोजिटरी की स्थानीय प्रतिलिपि को अद्यतित करने के लिए पहला git pullऐसा करेगा git fetch, और फिर यह आपके कोड संग्रह और संभवतः आपकी कार्यशील प्रति में परिवर्तनों को विलय करेगा।


बोनस:

उपरोक्त उत्तरों में पुल और लाने की बात करते हुए, मैं एक दिलचस्प चाल साझा करना चाहता हूं,

git pull --rebase

यह उपरोक्त आदेश मेरे गिट जीवन में सबसे उपयोगी कमांड है जो बहुत समय बचाता है।

अपने नए काम सर्वर पर धक्का देने से पहले, इस कमांड को आज़माएं और यह स्वचालित रूप से नवीनतम सर्वर परिवर्तनों को सिंक करेगा (एक fetch + विलय के साथ) और गिट लॉग में शीर्ष पर अपनी प्रतिबद्धता रखेगा। मैन्युअल पुल / विलय के बारे में चिंता करने की आवश्यकता नहीं है।

यहां विवरण प्राप्त करें: http://gitolite.com/git-pull--rebase


एसवीएन जैसे अधिक पारंपरिक स्रोत नियंत्रण उपकरण के दर्शन के साथ गिट के डिजाइन दर्शन को अलग करना महत्वपूर्ण है।

सबवर्सन को क्लाइंट / सर्वर मॉडल के साथ डिज़ाइन और बनाया गया था। एक एकल भंडार है जो सर्वर है, और कई क्लाइंट सर्वर से कोड ला सकते हैं, उस पर काम कर सकते हैं, फिर उसे सर्वर पर वापस ले जा सकते हैं। धारणा यह है कि क्लाइंट ऑपरेशन करने की आवश्यकता होने पर हमेशा सर्वर से संपर्क कर सकता है।

गिट को एक केंद्रीय वितरक की आवश्यकता के बिना एक अधिक वितरित मॉडल का समर्थन करने के लिए डिज़ाइन किया गया था (हालांकि यदि आप चाहें तो निश्चित रूप से एक का उपयोग कर सकते हैं)। इसके अलावा गिट डिज़ाइन किया गया था ताकि क्लाइंट और "सर्वर" को एक ही समय में ऑनलाइन होने की आवश्यकता न हो। गिट को डिज़ाइन किया गया था ताकि अविश्वसनीय लिंक पर लोग ईमेल के माध्यम से कोड का आदान-प्रदान कर सकें। पूरी तरह से डिस्कनेक्ट करना और गिट के माध्यम से कोड का आदान-प्रदान करने के लिए सीडी जला देना संभव है।

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

  • git fetch वह आदेश है जो कहता है "रिमोट रिपोजिटरी की मेरी स्थानीय प्रतिलिपि अद्यतित करें।"

  • git pull कहता है "रिमोट रिपोजिटरी में बदलाव लाने के लिए जहां मैं अपना कोड रखता हूं।"

आम तौर पर git pull रिमोट रिपोजिटरी की स्थानीय प्रतिलिपि को अद्यतित करने के लिए git fetch करके ऐसा करता है, और उसके बाद परिवर्तनों को अपने कोड भंडार में और संभवतः आपकी कार्यशील प्रति में विलय कर देता है।

दूर लेना यह ध्यान में रखना है कि आपके वर्कस्टेशन पर अक्सर परियोजना की कम से कम तीन प्रतियां होती हैं। एक प्रतिलिपि आपके स्वयं के प्रतिबद्ध इतिहास के साथ आपकी खुद की भंडार है। दूसरी प्रति आपकी कार्यशील प्रति है जहां आप संपादन और निर्माण कर रहे हैं। तीसरी प्रतिलिपि एक दूरस्थ भंडार की आपकी स्थानीय "कैश" प्रति है।


कभी-कभी एक दृश्य प्रतिनिधित्व मदद करता है।



संक्षिप्त और आसान जवाब यह है कि git pull बस git merge बाद git fetch

यह ध्यान रखना बहुत महत्वपूर्ण है कि git pull स्वचालित रूप से विलय हो जाएगा चाहे आप इसे पसंद करते हैं या नहीं । यह निश्चित रूप से, संघर्ष विलय में परिणाम हो सकता है। मान लें कि आपका रिमोट origin और आपकी शाखा master । यदि आप खींचने से पहले git diff origin/master , तो आपको संभावित विलय संघर्षों का कुछ विचार होना चाहिए और तदनुसार अपनी स्थानीय शाखा तैयार कर सकते हैं।

खींचने और धक्का देने के अलावा, कुछ वर्कफ़्लो में git rebase शामिल है, जैसे कि यह एक, जिसे मैं लिंक किए गए आलेख से समझाता हूं:

git pull origin master
git checkout foo-branch
git rebase master
git push origin foo-branch

यदि आप खुद को ऐसी परिस्थिति में पाते हैं, तो आप git pull --rebase को git pull --rebase करने के लिए लुभाने वाले हो सकते हैं। जब तक आप वास्तव में नहीं जानते, आप वास्तव में जानते हैं कि आप क्या कर रहे हैं, मैं इसके खिलाफ सलाह दूंगा। यह चेतावनी man पेज से git-pull , संस्करण 2.3.5 :

यह ऑपरेशन का एक संभावित खतरनाक तरीका है। यह इतिहास को फिर से लिखता है, जो पहले से ही उस इतिहास को प्रकाशित करते समय अच्छी तरह से नहीं बढ़ता है। इस विकल्प का उपयोग न करें जब तक कि आपने गिट-रीबेस (1) सावधानीपूर्वक पढ़ा न हो।


git fetch का एक उपयोग केस यह है कि निम्नलिखित आपको अंतिम शाखा के बाद से दूरस्थ शाखा में कोई भी परिवर्तन बताएगा ... ताकि आप वास्तविक खींच करने से पहले जांच सकें, जो आपकी वर्तमान शाखा और कार्यशील प्रतिलिपि में फ़ाइलों को बदल सकता है।

git fetch
git diff ...origin

git fetchअपने स्थानीय भंडार में रिमोट सर्वर से कोड को अपनी ट्रैकिंग शाखाओं में खींचता है। अपने रिमोट का नाम है, तो origin(डिफ़ॉल्ट) तो इन शाखाओं के भीतर हो जाएगा origin/, उदाहरण के लिए origin/master, origin/mybranch-123आदि ये आपके मौजूदा शाखाओं वे कर रहे हैं नहीं कर रहे हैं, स्थानीय सर्वर से उन शाखाओं की प्रतियां।

git pullएक करता है git fetch, लेकिन फिर भी उस शाखा के अपने वर्तमान स्थानीय संस्करण में ट्रैकिंग शाखा से कोड विलीन हो जाती है। यदि आप अभी तक उन परिवर्तनों के लिए तैयार नहीं हैं, तो बस git fetchपहले।


गिट लाओच

आप अपने स्थानीय शाखा में लाने से मूल रूप से परिवर्तन डाउनलोड करते हैं। Fetch रिमोट रेपो से पूछता है कि दूसरों ने जो कुछ भी किया है, उसके लिए आपके पास आपके स्थानीय रेपो पर नहीं है। इन्हें डाउनलोड करने के लिए लाता है और उन्हें स्थानीय भंडार में जोड़ता है।

गिट मर्ज

आप मर्ज कमांड का उपयोग करके fetch के माध्यम से डाउनलोड किए गए परिवर्तनों को लागू कर सकते हैं। विलय प्राप्त करने से प्राप्त रिट्रीव ले जाएगा और उन्हें अपनी स्थानीय शाखा में जोड़ने का प्रयास करें। विलय आपके स्थानीय परिवर्तनों का प्रतिबद्ध इतिहास रखेगा ताकि जब आप अपनी शाखा को पुश के साथ साझा करेंगे, तो गिट को पता चलेगा कि अन्य आपके परिवर्तन कैसे विलय कर सकते हैं।

गिट पुल

एक साथ चलाने और विलय करना अक्सर पर्याप्त होता है कि एक आदेश जो दो को जोड़ता है, खींचता है, बनाया गया था। खींचें एक लाता है और फिर डाउनलोड की गई अपनी स्थानीय शाखा में जोड़ने के लिए एक विलय करता है।


ठीक है , यहां git pull और git fetch बारे में कुछ जानकारी दी गई है, ताकि आप वास्तविक मतभेदों को समझ सकें ... कुछ सरल शब्दों में, लाने के लिए नवीनतम डेटा प्राप्त होता है, लेकिन कोड में परिवर्तन नहीं होता है और आपके वर्तमान स्थानीय शाखा कोड के साथ गड़बड़ नहीं होता है , लेकिन कोड परिवर्तन प्राप्त करें और इसे अपनी स्थानीय शाखा में विलय करें, प्रत्येक के बारे में अधिक जानकारी प्राप्त करने के लिए पढ़ें:

गिट fetch

यह आपके स्थानीय रिपोजिटरी में सभी रेफरी और ऑब्जेक्ट्स और कोई भी नई शाखा डाउनलोड करेगा ...

अपने इतिहास को पूरा करने के लिए आवश्यक वस्तुओं के साथ, एक या अधिक अन्य भंडारों से शाखाएं और / या टैग (सामूहिक रूप से, "रेफरी") प्राप्त करें। रिमोट-ट्रैकिंग शाखाएं अपडेट की गई हैं (इस व्यवहार को नियंत्रित करने के तरीकों के लिए नीचे दिए गए विवरण देखें)।

डिफ़ॉल्ट रूप से, किसी भी टैग जो इतिहास में इंगित किया जाता है उसे भी लाया जाता है; प्रभाव उन टैग्स को लाने के लिए है जो आपकी रुचि रखने वाली शाखाओं पर इंगित करते हैं। यह डिफ़ॉल्ट व्यवहार --tags या --no-tag विकल्पों का उपयोग करके या दूरस्थ..tagOpt को कॉन्फ़िगर करके बदला जा सकता है। एक रेफस्पेक का उपयोग करके जो टैग को स्पष्ट रूप से लाता है, आप टैग ला सकते हैं जो आपकी रुचि रखने वाली शाखाओं में इंगित नहीं करते हैं।

गिट फ़ेच एक या तो नामित भंडार या यूआरएल से प्राप्त हो सकता है, या कई रिपोजिटरी से एक बार में दिया जा सकता है और एक रिमोट होता है। विन्यास फाइल में प्रवेश। (गिट-कॉन्फ़िगर 1 देखें)।

जब कोई रिमोट निर्दिष्ट नहीं किया जाता है, डिफ़ॉल्ट रूप से मूल रिमोट का उपयोग किया जाएगा, जब तक कि वर्तमान शाखा के लिए अपस्ट्रीम शाखा कॉन्फ़िगर नहीं की जाती है।

रेफरी के नाम जो प्राप्त किए जाते हैं, साथ ही ऑब्जेक्ट नामों के साथ वे इंगित करते हैं, .git / FETCH_HEAD पर लिखे गए हैं। यह जानकारी स्क्रिप्ट या अन्य गिट कमांड, जैसे गिट-पुल द्वारा उपयोग की जा सकती है।

गिट खींचो

यह स्थानीय से स्थानीय शाखा में रिमोट से परिवर्तन लागू करेगा ...

एक रिमोट रिपोजिटरी से मौजूदा शाखा में परिवर्तन शामिल है। अपने डिफ़ॉल्ट मोड में, गिट पुल गिट फ़ेच के लिए शॉर्टेंड होता है जिसके बाद गिट विलय FETCH_HEAD होता है।

अधिक सटीक रूप से, गिट पुल दिए गए पैरामीटर के साथ गिट फ़ेच चलाता है और पुनर्प्राप्त शाखा प्रमुखों को वर्तमान शाखा में विलय करने के लिए गिट विलय को कॉल करता है। --Rebase के साथ, यह गिट विलय के बजाय गिट रिबेस चलाता है।

गिट-फ़ेच 1 को पास किए गए रिमोट रिपोजिटरी का नाम होना चाहिए। एक मनमानी रिमोट रेफ (उदाहरण के लिए, टैग का नाम) या यहां तक ​​कि संबंधित रिमोट-ट्रैकिंग शाखाओं (जैसे, रेफ / हेड / : रेफ / रिमोट / मूल / ) के साथ रेफरी का संग्रह भी हो सकता है, लेकिन आमतौर पर यह नाम है रिमोट रिपोजिटरी में एक शाखा का।

गिट-शाखा --track द्वारा निर्धारित वर्तमान शाखा के लिए "दूरस्थ" और "विलय" कॉन्फ़िगरेशन से डिफ़ॉल्ट मान और पढ़े जाते हैं।

मैं आपको यह दिखाने के लिए नीचे दिया गया दृश्य भी बनाता हूं कि कैसे git fetch और git pull एक साथ काम कर रहा है ...

1


असल में गिट आपके अपने कोड और रिमोट रिपोजिटरी की एक प्रति रखता है।

आदेश git fetchरिमोट रिपोजिटरी से डेटा प्राप्त करके आपकी स्थानीय प्रतिलिपि को अद्यतित करता है। कारण हमें इसकी आवश्यकता है क्योंकि किसी और ने कोड में कुछ बदलाव किए हैं और आप स्वयं को अद्यतन रखना चाहते हैं।

आदेश git pullरिमोट रिपोजिटरी में परिवर्तन लाता है जहां आप अपना कोड रखते हैं। आम तौर पर, git pullयह रिमोट रिपोजिटरी की स्थानीय प्रतिलिपि को अद्यतित करने के लिए पहले 'गिट फ़ेच' कर कर करता है, और फिर यह आपके स्वयं के कोड भंडार और संभवतः आपकी कार्यशील प्रति में परिवर्तन विलय करता है।


गिट दो संस्करणों का उपयोग कर रिमोट से स्थानीय संस्करण के नवीनतम संस्करण की शाखा प्राप्त करता है:

  1. गिट फ़ेच: गिट को दूरस्थ संस्करण से नवीनतम संस्करण प्राप्त करने जा रहा है, लेकिन यह स्वचालित रूप से विलय नहीं होता है। git fetch origin master git log -p master..origin/master git merge origin/master

    उपर्युक्त आदेशों का अर्थ है कि मुख्य शाखा का नवीनतम संस्करण दूरस्थ से मूल मास्टर शाखा तक मूल से डाउनलोड करें। और फिर स्थानीय मास्टर शाखा और मूल मास्टर शाखा की तुलना करता है। अंत में, विलय करें।

  2. गिट पुल: गिट को रिमोट से नवीनतम संस्करण मिल जाएगा और स्थानीय में विलय हो जाएगा।

    git pull origin master

    उपरोक्त आदेश बराबर है git fetchऔर git merge। अभ्यास में, git fetchशायद अधिक सुरक्षित क्योंकि विलय से पहले हम परिवर्तन देख सकते हैं और निर्णय ले सकते हैं कि क्या विलय करना है।


शुरुआती के लिए एक साधारण ग्राफिकल प्रतिनिधित्व,

यहाँ,

git pull  

भंडार से कोड लाएगा और आपके स्थानीय के साथ पुन: प्रयास करेगा ... गिट खींचने में नए कामों की संभावना है।

लेकीन मे ,

गिट fetch

भंडार से कोड लाएगा और हमें इसका उपयोग करके इसे मैन्युअल रूप से रीबेज करने की आवश्यकता है git rebase

उदाहरण: मैं सर्वर मास्टर से लाने और अपने स्थानीय मास्टर में इसे पुन: प्राप्त करने जा रहा हूं।

1) गिट पुल (रीबेस स्वचालित रूप से किया जाएगा):

git pull origin master

यहां मूल है आपका रिमोट रेपो मास्टर आपकी शाखा है

2) गिट fetch (मैन्युअल रूप से rebase की जरूरत है):

git fetch origin master

यह मूल से सर्वर परिवर्तन लाएगा। और यह आपके स्थानीय में तब तक होगा जब तक कि आप इसे अपने आप नहीं छोड़ देते। कोडों की जांच करके हमें मैन्युअल रूप से संघर्षों को ठीक करने की आवश्यकता है।

git rebase origin/master

यह कोड को स्थानीय में रीबेस कर देगा। इससे पहले कि आप सही शाखा में हैं सुनिश्चित करें।


स्पष्ट और सरल होने की कोशिश कर रहा है।

Git पुल आदेश वास्तव में एक है shortcutके लिए Git लाने के बाद Git मर्ज या Git rebase अपने कॉन्फ़िगरेशन के आधार पर आदेश। आप अपने गिट भंडार को कॉन्फ़िगर कर सकते हैं ताकि गिट पुल एक रिटर्न के बाद एक fetch हो।


यह इंटरैक्टिव ग्राफिकल प्रतिनिधित्व गिट को कम करने में बहुत मददगार है: http://ndpsoftware.com/git-cheatsheet.html

git fetch दूरस्थ रूप से आपके स्थानीय भंडार में परिवर्तनों को "डाउनलोड" करता है। git pull परिवर्तन डाउनलोड करता है और उन्हें आपकी वर्तमान शाखा में विलीन कर देता है। "इसके डिफ़ॉल्ट मोड में, git pull git fetch लिए git merge FETCH_HEAD जिसके बाद git merge FETCH_HEAD ।"


जीआईटी फ़ेच और जीआईटी पुल के बीच का अंतर निम्नलिखित परिदृश्य के साथ समझाया जा सकता है: (ध्यान रखें कि चित्र शब्दों से ज़ोर से बोलते हैं !, मैंने चित्रमय प्रतिनिधित्व प्रदान किया है)

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

तो, प्रारंभिक अवस्था दो शाखाओं के लिए जब आप अपने स्थानीय भंडार पर मुख्य परियोजना विभाजित है- तरह होगा ( A, Bऔर Cमॉड्यूल पहले से ही इस परियोजना के पूरा कर रहे हैं)

अब, आपने नए मॉड्यूल (मान लीजिए D) पर काम करना शुरू कर दिया है और जब आपने Dमॉड्यूल पूरा कर लिया है तो आप इसे मुख्य शाखा में धक्का देना चाहते हैं, लेकिन इस बीच क्या होता है कि आपके साथियों में से एक ने नया मॉड्यूल विकसित किया है E, Fऔर संशोधित किया है C
तो अब क्या हुआ है कि आपके स्थानीय भंडार में परियोजना की मूल प्रगति के पीछे कमी है और इस प्रकार मुख्य शाखा में आपके परिवर्तनों को धक्का देकर संघर्ष हो सकता है और आपके मॉड्यूल Dको खराब होने का कारण बन सकता है ।

इस तरह के मुद्दों से बचने के लिए और परियोजना की मूल प्रगति के साथ समानांतर काम करने के लिए उनके दो तरीके हैं:

1. गिट फ़ेच- यह मूल / मुख्य शाखा प्रोजेक्ट में किए गए सभी परिवर्तनों को डाउनलोड करेगा जो आपकी स्थानीय शाखा में मौजूद नहीं हैं। और आपके रिपोजिटरी या शाखा में किए गए परिवर्तनों को लागू करने के लिए गिट मर्ज कमांड की प्रतीक्षा करेगा।

तो अब आप इसे अपने भंडार में विलय करने से पहले फ़ाइलों की सावधानीपूर्वक निगरानी कर सकते हैं। और संशोधित Dहोने के कारण यदि आप आवश्यक हो तो भी संशोधित कर सकते हैं C

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


गिट पुराने काम करने के बाद क्रोनोलॉजिकल रूप से पुराने काम करने की अनुमति देता है। इस वजह से, भंडारों के बीच स्थानांतरित करने का कार्य दो चरणों में विभाजित है:

  1. स्थानीय रिपो के अंदर इस रिमोट शाखा की प्रतिलिपि बनाने के लिए रिमोट शाखा से नई प्रतिबद्धताओं की प्रतिलिपि बनाना।

    (रेपो ऑपरेशन के लिए रेपो) [email protected] >> remote/origin/[email protected]

  2. स्थानीय शाखा में नए कामों को एकीकृत करना

    (अंदर-रेपो ऑपरेशन) remote/origin/[email protected] >> [email protected]

चरण 2 करने के दो तरीके हैं। आप कर सकते हैं:

  1. पिछले आम पूर्वजों के बाद कांटा स्थानीय शाखा और स्थानीय कामकाज के लिए अनूठे नए कामों को जोड़ते हैं, जो विलय को बंद करके, फोर्क बंद करके अंतिम रूप दिया जाता है।
  2. पिछले आम पूर्वजों के बाद नई प्रतिबद्धता डालें और फिर से स्थानीय भंडार के लिए अद्वितीय काम करता है।

में gitशब्दावली, चरण 1 है git fetch, चरण 2 है git mergeयाgit rebase

git pullहै git fetchऔरgit merge


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

                                         LOCAL SYSTEM
                  . =====================================================    
================= . =================  ===================  =============
REMOTE REPOSITORY . REMOTE REPOSITORY  LOCAL REPOSITORY     WORKING COPY
(ORIGIN)          . (CACHED)           
for example,      . mirror of the      
a github repo.    . remote repo
Can also be       .
multiple repo's   .
                  .
                  .
FETCH  *------------------>*
Your local cache of the remote is updated with the origin (or multiple
external sources, that is git's distributed nature)
                  .
PULL   *-------------------------------------------------------->*
changes are merged directly into your local copy. when conflicts occur, 
you are asked for decisions.
                  .
COMMIT            .                             *<---------------*
When coming from, for example, subversion, you might think that a commit
will update the origin. In git, a commit is only done to your local repo.
                  .
PUSH   *<---------------------------------------*
Synchronizes your changes back into the origin.

रिमोट के लेटे हुए दर्पण के लिए कुछ प्रमुख फायदे हैं:

  • प्रदर्शन (नेटवर्क के माध्यम से इसे निचोड़ने की कोशिश किए बिना सभी प्रतिबद्धताओं और संदेशों के माध्यम से स्क्रॉल करें)
  • अपने स्थानीय रेपो की स्थिति के बारे में प्रतिक्रिया (उदाहरण के लिए, मैं एटलसियन के स्रोत ट्री का उपयोग करता हूं, जो मुझे एक बल्ब देगा जो इंगित करता है कि क्या मैं मूल की तुलना में आगे या पीछे हूं। इस जानकारी को जीआईटी फ़ेच के साथ अपडेट किया जा सकता है)।

git-pull - Fetch from and merge with another repository or a local branch
SYNOPSIS

git pull   …
DESCRIPTION

Runs git-fetch with the given parameters, and calls git-merge to merge the 
retrieved head(s) into the current branch. With --rebase, calls git-rebase 
instead of git-merge.

Note that you can use . (current directory) as the <repository> to pull 
from the local repository — this is useful when merging local branches 
into the current branch.

Also note that options meant for git-pull itself and underlying git-merge 
must be given before the options meant for git-fetch.

अगर आप इतिहास को विलय करना चाहते हैं तो आप खींचेंगे, अगर आप सिर्फ 'कोडेज़ चाहते हैं' तो आप कुछ लोग यहां कुछ लेख टैग कर रहे हैं।


git pull = git fetch + git merge 






git-fetch