$lang['tuto'] = "பயிற்சிகள்"; ?>$lang['tuto'] = "பயிற்சிகள்"; ?> 'ஜிட் புஷ் -எஃப்'

'ஜிட் புஷ் -எஃப்' தவறுக்குப் பிறகு எப்படி மீள்வது

Git Commands

Git தவறுகளிலிருந்து மீள்வது:

தற்செயலாக 'git push -f' கட்டளையைப் பயன்படுத்துவது முக்கியமான கமிட்களை இழக்க வழிவகுக்கும், பீதியையும் குழப்பத்தையும் ஏற்படுத்துகிறது, குறிப்பாக GitHub டெஸ்க்டாப்பைப் பயன்படுத்துவதில் அதிகப் பழக்கம் உள்ளவர்களுக்கு.

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

கட்டளை விளக்கம்
git fetch --all அனைத்து கிளைகளையும் பெற்று தொலை களஞ்சியத்தில் இருந்து உறுதிசெய்து, உள்ளூர் களஞ்சியத்தில் அனைத்து புதுப்பிப்புகளும் உள்ளன.
git reflog show origin/main ரிமோட் மெயின் கிளைக்கான reflogஐக் காட்டுகிறது, இது கிளைகளின் முனையில் புதுப்பிப்புகளைப் பதிவு செய்கிறது.
git reset --hard [commit_hash] தற்போதைய கிளையை குறிப்பிட்ட உறுதிக்கு மீட்டமைக்கிறது, அந்த உறுதிப்பாட்டிலிருந்து அனைத்து மாற்றங்களையும் நிராகரிக்கிறது.
git push -f origin main ஃபோர்ஸ் தற்போதைய கிளையை தொலை களஞ்சியத்திற்கு தள்ளுகிறது, தொலைநிலை கிளையை உள்ளூர் மாநிலத்துடன் மேலெழுதுகிறது.
subprocess.run(command, shell=True, capture_output=True, text=True) பைதான் ஸ்கிரிப்ட்டிலிருந்து ஷெல் கட்டளையை இயக்குகிறது, மேலும் பயன்படுத்த அதன் வெளியீட்டைப் பிடிக்கிறது.
read -p ஷெல் ஸ்கிரிப்ட்டில் உள்ளீடு செய்ய பயனரைத் தூண்டுகிறது, பின்னர் பயன்படுத்துவதற்காக உள்ளீட்டை மாறியில் சேமிக்கிறது.

'ஜிட் புஷ் -எஃப்' பிழையிலிருந்து மீட்டெடுக்கிறது

மேலே உருவாக்கப்பட்ட ஸ்கிரிப்ட்கள் பயனர்கள் தவறான பயன்பாட்டிலிருந்து மீட்க உதவும் வகையில் வடிவமைக்கப்பட்டுள்ளன கட்டளை, தொலை களஞ்சியத்தின் வரலாற்றை மேலெழுத முடியும். பாஷ் ஸ்கிரிப்ட் முதலில் ரிமோட் ரிபோசிட்டரியில் இருந்து அனைத்து புதுப்பிப்புகளையும் பெறுகிறது , உள்ளூர் நகல் புதுப்பித்த நிலையில் இருப்பதை உறுதி செய்தல். இது தொலைநிலை பிரதான கிளையின் மறுபிரதியைக் காட்டுகிறது , பயனர் முந்தைய உறுதி நிலைகளைக் காணவும், இழந்த கமிட்களைக் கண்டறியவும் அனுமதிக்கிறது. விரும்பிய கமிட் ஹாஷ் அடையாளம் காணப்பட்டவுடன், ஸ்கிரிப்ட் உள்ளூர் கிளையை அந்த கமிட் பயன்படுத்தி மீட்டமைக்கிறது git reset --hard [commit_hash], மற்றும் சக்தி இந்த நிலையை ரிமோட் களஞ்சியத்திற்கு தள்ளுகிறது .

பைதான் ஸ்கிரிப்ட் பைத்தானில் இருந்து ஷெல் கட்டளைகளை இயக்குவதன் மூலம் இந்த படிகளை தானியங்குபடுத்துகிறது. இது பயன்படுத்துகிறது கட்டளைகளை இயக்குவதற்கான செயல்பாடு, மேலும் பயன்பாட்டிற்கு அவற்றின் வெளியீட்டைக் கைப்பற்றுகிறது. ஸ்கிரிப்ட் பயனரை அவர்கள் மீட்டெடுக்க விரும்பும் கமிட் ஹாஷை உள்ளிட தூண்டுகிறது, பின்னர் கிளையை மீட்டமைத்து பாஷ் ஸ்கிரிப்டில் உள்ள மாற்றங்களைத் தள்ளுகிறது. இந்த ஸ்கிரிப்டுகள் ஒரு சக்தி உந்துதல் மற்றும் இழந்த கமிட்களை திறம்பட மீட்டெடுப்பதால் ஏற்படும் சேதத்தைத் தணிக்க அவசியம்.

ஒரு 'ஜிட் புஷ் -எஃப்' தவறுக்குப் பிறகு இழந்த கமிட்களை மீட்டமைத்தல்

கட்டளை வரி இடைமுகத்தில் (CLI) Git கட்டளைகளைப் பயன்படுத்துதல்

#!/bin/bash
# This script assumes you have the repository cloned and you are in the repository directory
# Step 1: Fetch all branches and commits from the remote repository
git fetch --all
# Step 2: Check the reflog of the remote repository to find the lost commits
git reflog show origin/main
# Step 3: Identify the commit hash you want to restore
# Example: 7a7a940
# Step 4: Reset the local branch to the desired commit
git reset --hard 7a7a940
# Step 5: Force push the corrected branch to the remote repository
git push -f origin main

ஷெல் ஸ்கிரிப்ட் மூலம் இழந்த கமிட்களை மீட்டெடுத்தல்

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

#!/bin/bash
# This script helps restore lost commits by automating the process
# Fetch all updates from the remote repository
git fetch --all
# Display the reflog of the remote main branch to find the lost commits
echo "Remote reflog for main branch:"
git reflog show origin/main
# Prompt the user to enter the commit hash to restore
read -p "Enter the commit hash to restore: " commit_hash
# Reset the local branch to the specified commit
git reset --hard $commit_hash
# Force push the changes to the remote repository
git push -f origin main

பைதான் ஸ்கிரிப்டைப் பயன்படுத்தி கமிட்களை மீட்டமைத்தல்

Git கட்டளைகளை இயக்க பைத்தானைப் பயன்படுத்துதல்

import os
import subprocess
# Function to execute shell commands
def run_command(command):
    result = subprocess.run(command, shell=True, capture_output=True, text=True)
    return result.stdout.strip()
# Fetch all updates from the remote repository
run_command("git fetch --all")
# Display the reflog of the remote main branch
reflog = run_command("git reflog show origin/main")
print("Remote reflog for main branch:")
print(reflog)
# Prompt the user to enter the commit hash to restore
commit_hash = input("Enter the commit hash to restore: ")
# Reset the local branch to the specified commit
run_command(f"git reset --hard {commit_hash}")
# Force push the changes to the remote repository
run_command("git push -f origin main")

Git Reflog மற்றும் Remote Recovery பற்றிய புரிதல்

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

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

  1. என்ன ?
  2. இது கிளைகள் மற்றும் HEAD இன் குறிப்புகளுக்கு புதுப்பிப்புகளைப் பதிவு செய்வதற்கான ஒரு பொறிமுறையாகும், இது இயக்கங்களைக் கண்காணிக்கவும், இழந்த கமிட்களை மீட்டெடுக்கவும் உங்களை அனுமதிக்கிறது.
  3. இதைப் பயன்படுத்தி இழந்த உறுதியை நான் எப்படிக் கண்டுபிடிப்பது ?
  4. ஓடு ரிமோட் மெயின் கிளையின் வரலாற்றைப் பார்க்கவும், உங்களுக்குத் தேவையான கமிட் ஹாஷைக் கண்டறியவும்.
  5. கமிட்களை மீட்டெடுக்க நான் GitHub இன் செயல்பாட்டுப் பதிவைப் பயன்படுத்தலாமா?
  6. ஆம், ஃபோர்ஸ் புஷ்கள் உள்ளிட்ட சமீபத்திய மாற்றங்களை செயல்பாட்டுப் பதிவு காட்டுகிறது, இது தேவையான கமிட் ஹாஷ்களைக் கண்டறிய உதவும்.
  7. என்ன செய்கிறது செய்?
  8. இது உங்கள் தற்போதைய கிளையை ஒரு குறிப்பிட்ட உறுதிக்கு மீட்டமைக்கிறது, அந்த உறுதிப்பாட்டிற்குப் பிறகு செய்யப்பட்ட அனைத்து மாற்றங்களையும் நிராகரிக்கிறது.
  9. பயன்படுத்துவது பாதுகாப்பானதா ?
  10. ஃபோர்ஸ் புஷ்சிங் ரிமோட் ஹிஸ்டரியை மேலெழுதலாம், எனவே இது கவனமாகவும் தேவைப்படும்போது மட்டுமே பயன்படுத்தப்பட வேண்டும்.
  11. கமிட்களை இழப்பதைத் தடுக்க சிறந்த வழி என்ன?
  12. உங்கள் களஞ்சியத்தை தொடர்ந்து காப்புப் பிரதி எடுத்து பயன்படுத்துவதைத் தவிர்க்கவும் முற்றிலும் தேவைப்படாவிட்டால்.
  13. நான் மீட்பு செயல்முறைகளை தானியங்குபடுத்த முடியுமா?
  14. ஆம், Bash அல்லது Python போன்ற ஸ்கிரிப்ட்கள் மீட்புப் படிகளை தானியக்கமாக்கி, நிலைத்தன்மையை உறுதிசெய்து பிழைகளின் வாய்ப்பைக் குறைக்கும்.
  15. ஒரு தவறுக்குப் பிறகு நான் பீதியடைந்தால் நான் என்ன செய்ய வேண்டும்?
  16. அமைதியாக இருங்கள், போன்ற கருவிகளைப் பயன்படுத்தி உங்கள் விருப்பங்களை மதிப்பாய்வு செய்யவும் மற்றும் செயல்பாடு பதிவுகள், மற்றும் தேவைப்பட்டால் சமூகத்தின் உதவியை நாடுங்கள்.

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