Git இல் பல பொறுப்புகளை எவ்வாறு மாற்றுவது

Git இல் பல பொறுப்புகளை எவ்வாறு மாற்றுவது
Git Command Line

Git கமிட் மாற்றங்களைப் புரிந்துகொள்வது

திட்ட வரலாற்றை மாற்றாமல் முந்தைய மாற்றங்களைச் செயல்தவிர்க்க வேண்டியிருக்கும் போது, ​​Git களஞ்சியத்தில் பல கமிட்களை மாற்றுவது பொதுவான பணியாகும். உங்கள் கடந்தகால வேலையின் நேர்மையைப் பாதுகாக்கும் அதே வேளையில் மாற்றங்களைத் திரும்பப் பெற இது ஒரு பாதுகாப்பான முறையாகும். உங்கள் மாற்றங்களை மற்றவர்களுடன் பகிர்ந்து கொள்ளும்போது இந்த அணுகுமுறை மிகவும் பயனுள்ளதாக இருக்கும் மற்றும் மறுசீரமைப்பு இனி சாத்தியமான விருப்பமாக இருக்காது.

நீங்கள் தொடர்ச்சியான கமிட்களை மாற்றியமைக்க வேண்டியிருக்கும் போது சவால் எழுகிறது - கமிட் D இல் உள்ள ஒரு தலையிலிருந்து A க்கு திரும்புவது, B, C மற்றும் D கமிட்களை திறம்பட புறக்கணிப்பது போன்றது. சுத்தமான மற்றும் செயல்பாட்டு களஞ்சியம்.

கட்டளை விளக்கம்
git reset --hard A தற்போதைய கிளையின் HEAD ஐ குறிப்பிட்ட கமிட்டிற்கு மீட்டமைக்கிறது (இந்த விஷயத்தில் A), அந்த உறுதிப்பாட்டிலிருந்து செயல்படும் அடைவு மற்றும் குறியீட்டில் உள்ள அனைத்து மாற்றங்களையும் நிராகரிக்கிறது.
git push --force ரிமோட் ரிபோசிட்டரிக்கு அழுத்தத்தை கட்டாயப்படுத்துகிறது, ரிமோட்டில் மாற்றங்களை தற்போதைய கிளை நிலையுடன் மேலெழுதும். மாற்றங்கள் முன்பு தள்ளப்பட்டிருந்தால், கடின மீட்டமைப்பிற்குப் பிறகு இது அவசியம்.
git revert <commit> --no-commit குறிப்பிட்ட கமிட் மூலம் அறிமுகப்படுத்தப்பட்ட மாற்றங்களை மாற்றியமைக்காமல் மாற்றியமைக்கிறது. இது பல மாற்றங்களை ஒரே உறுதிப்பாட்டில் தொகுக்க அனுமதிக்கிறது.
git commit -m "Message" தற்போதைய நிலைப் பகுதி உள்ளடக்கங்களை, வழங்கப்பட்ட செய்தியுடன் களஞ்சியத்தில் ஒப்படைத்து, மாற்றியமைக்கும் அல்லது மீட்டமைக்கும் செயல்முறையை இறுதி செய்கிறது.

Git கட்டளை ஸ்கிரிப்ட்களின் விளக்கம்

வழங்கப்பட்ட ஸ்கிரிப்டுகள், கிளையை முந்தைய நிலைக்கு மீட்டமைப்பதன் மூலம் அல்லது கமிட்களைத் தேர்ந்தெடுத்து மாற்றுவதன் மூலம், Git களஞ்சியத்தில் மாற்றங்களை நிர்வகிக்கவும் மாற்றியமைக்கவும் வடிவமைக்கப்பட்டுள்ளன. தி git reset --hard A 'A' என அடையாளம் காணப்பட்ட முந்தைய உறுதிப்பாட்டிற்கு கிளையின் தலையை நேரடியாக மறுவரையறை செய்வதால் கட்டளை முக்கியமானது. இந்தச் செயல், கமிட் A க்குப் பிறகு கிளையில் செய்யப்பட்ட அனைத்து மாற்றங்களையும் நிராகரிக்கிறது, திறம்பட களஞ்சிய நிலையை கமிட் A இல் உள்ளதை ஒத்ததாக ஆக்குகிறது. இந்தக் கட்டளை சக்தி வாய்ந்தது ஆனால் எச்சரிக்கையுடன் பயன்படுத்தப்பட வேண்டும், ஏனெனில் இது மாற்றங்களை நிரந்தரமாக அழித்துவிடும், உங்களுக்கு சுத்தமான மறுபரிசீலனை தேவைப்படும்போது இது பொருத்தமானது. தெரிந்த நல்ல நிலைக்கு.

தி git revert கட்டளைகள், உடன் இணைந்து --no-commit விருப்பம், நீங்கள் B, C, மற்றும் D ஆகிய கமிட்களால் அறிமுகப்படுத்தப்பட்ட குறிப்பிட்ட மாற்றங்களை செயல்தவிர்க்க விரும்பும்போது பயன்படுத்தப்படும், ஆனால் செயல்தவிர்க்கப்பட்டது பற்றிய பதிவை வைத்திருக்க வேண்டும். இந்த முறை வரலாற்றைப் பராமரிக்கிறது, இது மாற்றங்களின் பரிணாமத்தைப் புரிந்துகொள்வது முக்கியமாக இருக்கும் பகிரப்பட்ட களஞ்சியங்களுக்கு நன்மை பயக்கும். தேவையான கமிட்களை மாற்றிய பின், ஒரு ஒற்றை git commit அனைத்து மாற்றங்களையும் ஒரு ஸ்னாப்ஷாட்டில் தொகுக்கப் பயன்படுகிறது, இது திட்ட வரலாற்றை எளிதாக்குகிறது மற்றும் மாற்றியமைப்பின் சூழலைப் புரிந்துகொள்வதை எளிதாக்குகிறது. பயன்பாடு git push --force கிளையின் வரலாற்றில் இத்தகைய கடுமையான மாற்றங்களுக்குப் பிறகு ரிமோட் களஞ்சியத்தை புதுப்பிக்க வேண்டியது அவசியம்.

Git கிளையை ஒரு குறிப்பிட்ட உறுதிக்கு மீட்டமைத்தல்

Git கட்டளை வரியைப் பயன்படுத்துதல்

git checkout your-branch-name
git reset --hard A
git push origin your-branch-name --force

Git இல் பல மாற்றங்களை மாற்றுகிறது

Git செயல்பாடுகளுக்கான பாஷுடன் ஸ்கிரிப்டிங்

git checkout your-branch-name
git revert D --no-commit
git revert C --no-commit
git revert B --no-commit
git commit -m "Reverted commits B, C, and D"
git push origin your-branch-name

Git வரலாறுகளை நிர்வகிப்பதற்கான மேம்பட்ட நுட்பங்கள்

ஒரு Git களஞ்சியத்தை கையாளும் போது, ​​மேம்பட்ட பயனர்களுக்கு பெரும்பாலும் அடிப்படை பொறுப்பு மாற்றங்கள் அல்லது மீட்டமைப்புகளை விட அதிகமாக தேவைப்படும். அத்தகைய ஒரு நுட்பம், மேலும் கட்டுப்படுத்தப்பட்ட வரலாறு திருத்துவதற்கு ஊடாடும் மறுதளத்தைப் பயன்படுத்துவதாகும். மறுசீரமைப்பு அமர்வின் போது விரிவான பட்டியலிலிருந்து கமிட்களை எடுக்க, ஸ்குவாஷ் செய்ய, திருத்த அல்லது தவிர்க்க இண்டராக்டிவ் ரீபேஸ் உங்களை அனுமதிக்கிறது, இது கமிட் வரலாற்றின் மீது சிறந்த கட்டுப்பாட்டை வழங்குகிறது. சிக்கலான வரலாறுகளை ஒரு முக்கிய கிளையாக இணைக்கும் முன், திட்டத்தின் வரலாறு சுத்தமாகவும் புரிந்துகொள்ளக்கூடியதாகவும் இருப்பதை உறுதிசெய்யும் போது இந்த முறை மிகவும் பயனுள்ளதாக இருக்கும்.

மற்றொரு மேம்பட்ட முறையானது reflog ஐப் பயன்படுத்துவதாகும், இது Git இல் உள்ள ஒரு பொறிமுறையாகும், இது கிளைகளின் குறிப்புகள் மற்றும் களஞ்சியத்தில் உள்ள பிற குறிப்புகளுக்கான புதுப்பிப்புகளைப் பதிவு செய்கிறது. ஆக்கிரோஷமான சுத்தம் அல்லது வரலாற்றைக் கையாளும் பிழைகள் காரணமாக கிளை உதவிக்குறிப்புகள் மூலம் நேரடியாக அணுக முடியாத திட்டத்தின் முந்தைய நிலைகளை நீங்கள் மறுபரிசீலனை செய்து மீட்டெடுக்க வேண்டிய மீட்புக் காட்சிகளுக்கு reflog மதிப்புமிக்கதாக இருக்கும்.

முக்கியமான Git கேள்விகளுக்கு பதிலளிக்கப்பட்டது

  1. என்ன செய்கிறது git reset --hard செய்ய கட்டளையிடவா?
  2. இது தற்போதைய கிளையின் தலையை குறிப்பிட்ட உறுதிக்கு மீட்டமைக்கிறது, அந்த உறுதிப்பாட்டிலிருந்து ஸ்டேஜிங் ஏரியா மற்றும் வேலை செய்யும் கோப்பகத்தில் உள்ள அனைத்து மாற்றங்களையும் நிராகரிக்கிறது.
  3. ஒன்றிணைக்கும் உறுதிமொழியை நான் திரும்பப்பெற முடியுமா?
  4. ஆம், நீங்கள் ஒரு இணைப்பு உறுதியை குறிப்பாகப் பயன்படுத்தி மாற்றியமைக்கலாம் git revert -m 1 <commit>, "1" என்பது இணைப்பதற்கான பெற்றோரின் உறுதிப்பாட்டைக் குறிப்பிடுகிறது.
  5. பங்கு என்ன git reflog?
  6. reflog ஆனது கிளைகளின் குறிப்புகள் மற்றும் களஞ்சியத்தில் உள்ள பிற குறிப்புகளில் ஏற்படும் மாற்றங்களைக் கண்காணிக்கப் பயன்படுகிறது, இழந்த கமிட்களை மீட்டெடுக்க அல்லது ரெப்போவில் செய்யப்பட்ட மாற்றங்களை ஆராய உதவுகிறது.
  7. எப்படி செய்கிறது git rebase இணைப்பதில் இருந்து வேறுபட்டதா?
  8. ரீபேஸ் ஒரு கிளையின் அடிப்பகுதியை புதிய உறுதிப்பாட்டிற்கு மாற்றுவதன் மூலம் திட்ட வரலாற்றை மீண்டும் எழுதுகிறது, இது ஒன்றிணைப்புடன் ஒப்பிடும்போது வரலாற்றை தூய்மையாக்கும்.
  9. ஒரு கிளையை மீட்டமைத்த பிறகு கட்டாயப்படுத்தி தள்ளுவது பாதுகாப்பானதா?
  10. மாற்றங்கள் ஏற்கனவே தள்ளப்பட்டிருந்தால், அதை மீட்டமைத்த பிறகு வலுக்கட்டாயமாக தள்ளுவது அவசியம், ஆனால் இது தொலைநிலை மாற்றங்களை மேலெழுதலாம் மற்றும் எச்சரிக்கையுடன் பயன்படுத்தப்பட வேண்டும்.

Git கமிட் மாற்றங்களைப் பற்றிய இறுதி எண்ணங்கள்

ஒரு Git களஞ்சியத்தை வெற்றிகரமாக நிர்வகித்தல், பல கமிட்களை மாற்றியமைக்க வேண்டியிருக்கும் போது, ​​கிடைக்கும் தாக்கங்கள் மற்றும் நுட்பங்களைப் புரிந்துகொள்வதை உள்ளடக்குகிறது. ஒரு குறிப்பிட்ட நிச்சயத்திற்கு கடின மீட்டமைப்பின் மூலமாகவோ அல்லது ஒவ்வொரு கமிட்டிக்கும் revert கட்டளைகளை கவனமாகப் பயன்படுத்தினாலும், களஞ்சியம் சுத்தமாகவும், வரலாற்றைப் புரிந்துகொள்ளக்கூடியதாகவும் இருப்பதை உறுதிசெய்வதே குறிக்கோள். கூட்டுத் திட்டங்களுக்கு, இந்த மாற்றங்களைத் தெரிவிப்பதும், இடையூறுகளைத் தடுக்க ரிமோட் களஞ்சியத்தை கவனமாக நிர்வகிப்பதும் முக்கியம். இறுதியில், இந்த கட்டளைகளை மாஸ்டரிங் செய்வது டெவலப்பர்கள் தங்கள் திட்ட காலக்கெடுவை திறம்பட கட்டுப்படுத்த அனுமதிக்கிறது.