Gitలో మల్టిపుల్ కమిట్‌లను ఎలా రివర్ట్ చేయాలి

Git Command Line

Git కమిట్ రివర్షన్‌లను అర్థం చేసుకోవడం

ప్రాజెక్ట్ యొక్క చరిత్రను మార్చకుండా మునుపటి మార్పులను రద్దు చేయవలసి వచ్చినప్పుడు Git రిపోజిటరీలో బహుళ కమిట్‌లను తిరిగి మార్చడం సాధారణ పని. మీ గత పని యొక్క సమగ్రతను కాపాడుతూ మార్పులను వెనుకకు తీసుకోవడానికి ఇది సురక్షితమైన పద్ధతి. మీరు మీ మార్పులను ఇతరులతో పంచుకున్నప్పుడు ఈ విధానం చాలా ఉపయోగకరంగా ఉంటుంది మరియు రీబేస్ ఇకపై ఆచరణీయమైన ఎంపిక కాదు.

మీరు కమిట్‌ల శ్రేణిని తిరిగి మార్చాల్సిన అవసరం వచ్చినప్పుడు సవాలు ఎదురవుతుంది-కమిట్ D వద్ద ఉన్న HEAD నుండి Aకి తిరిగి వెళ్లడం, B, C మరియు D కమిట్‌లను సమర్థవంతంగా విస్మరించడం వంటివి. ఈ కమిట్‌లను తిరిగి మార్చడానికి సరైన పద్ధతి మరియు క్రమాన్ని అర్థం చేసుకోవడం చాలా కీలకం క్లీన్ మరియు ఫంక్షనల్ రిపోజిటరీ.

ఆదేశం వివరణ
git reset --hard A ప్రస్తుత శాఖ యొక్క HEADని పేర్కొన్న కమిట్‌కి రీసెట్ చేస్తుంది (ఈ సందర్భంలో A), ఆ కమిట్ నుండి పని చేసే డైరెక్టరీ మరియు ఇండెక్స్‌లోని అన్ని మార్పులను విస్మరిస్తుంది.
git push --force రిమోట్ రిపోజిటరీకి పుష్‌ను బలవంతం చేస్తుంది, ప్రస్తుత శాఖ స్థితితో రిమోట్‌లో మార్పులను ఓవర్‌రైట్ చేస్తుంది. మార్పులు గతంలో పుష్ చేయబడితే హార్డ్ రీసెట్ తర్వాత ఇది అవసరం.
git revert <commit> --no-commit పేర్కొన్న కమిట్ ద్వారా ప్రవేశపెట్టబడిన మార్పులను తిరిగి పొందకుండానే తిరిగి మార్చుతుంది. ఇది బహుళ రివర్ట్‌లను ఒకే కమిట్‌గా వర్గీకరించడానికి అనుమతిస్తుంది.
git commit -m "Message" అందించిన సందేశంతో ప్రస్తుత స్టేజింగ్ ఏరియా కంటెంట్‌లను రిపోజిటరీకి కమిట్ చేస్తుంది, రివర్ట్ లేదా రీసెట్ ప్రక్రియను ఖరారు చేస్తుంది.

Git కమాండ్ స్క్రిప్ట్‌ల వివరణ

అందించిన స్క్రిప్ట్‌లు Git రిపోజిటరీలో మార్పులను నిర్వహించడానికి మరియు తిరిగి మార్చడానికి రూపొందించబడ్డాయి, బ్రాంచ్‌ను మునుపటి స్థితికి రీసెట్ చేయడం ద్వారా లేదా కమిట్‌లను ఎంపిక చేసి తిరిగి మార్చడం ద్వారా. ది కమాండ్ కీలకమైనది ఎందుకంటే ఇది శాఖ యొక్క హెడ్‌ని నేరుగా 'A'గా గుర్తించబడిన మునుపటి కమిట్‌కి పునర్నిర్వచిస్తుంది. ఈ చర్య కమిట్ A తర్వాత బ్రాంచ్‌లో చేసిన అన్ని మార్పులను విస్మరిస్తుంది, రిపోజిటరీ స్థితిని కమిట్ A వద్ద సమర్ధవంతంగా సమానంగా చేస్తుంది. ఈ కమాండ్ శక్తివంతంగా ఉంటుంది, అయితే ఇది మార్పులను శాశ్వతంగా తొలగిస్తుంది, మీకు క్లీన్ రివర్ట్ అవసరమైనప్పుడు ఇది అనుకూలంగా ఉంటుంది కాబట్టి జాగ్రత్తగా ఉపయోగించాలి. తెలిసిన మంచి స్థితికి.

ది ఆదేశాలతో కలిపి ఎంపిక, మీరు కమిట్‌లు B, C మరియు D ద్వారా ప్రవేశపెట్టబడిన నిర్దిష్ట మార్పులను రద్దు చేయాలనుకున్నప్పుడు ఉపయోగించబడుతుంది, కానీ ఏమి రద్దు చేయబడిందో రికార్డ్‌ను ఉంచుకోవాలనుకున్నప్పుడు. ఈ పద్ధతి చరిత్రను నిర్వహిస్తుంది, ఇది మార్పుల పరిణామాన్ని అర్థం చేసుకోవడం ముఖ్యం అయిన షేర్డ్ రిపోజిటరీలకు ప్రయోజనకరంగా ఉంటుంది. అవసరమైన కమిట్‌లను మార్చిన తర్వాత, ఒక సింగిల్ అన్ని రివర్షన్‌లను ఒక స్నాప్‌షాట్‌గా సమూహపరచడానికి ఉపయోగించబడుతుంది, ఇది ప్రాజెక్ట్ చరిత్రను సులభతరం చేస్తుంది మరియు రివర్షన్ సందర్భాన్ని అర్థం చేసుకోవడం సులభం చేస్తుంది. దాని యొక్క ఉపయోగం 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 రిపోజిటరీతో వ్యవహరించేటప్పుడు, ఆధునిక వినియోగదారులకు తరచుగా ప్రాథమిక కమిట్ రివర్షన్‌లు లేదా రీసెట్‌ల కంటే ఎక్కువ అవసరం. అటువంటి సాంకేతికత మరింత నియంత్రిత చరిత్ర సవరణ కోసం ఇంటరాక్టివ్ రీబేస్‌ని ఉపయోగించడం. ఇంటరాక్టివ్ రీబేస్ మిమ్మల్ని రీబేస్ సెషన్‌లో వివరణాత్మక జాబితా నుండి కమిట్‌లను ఎంచుకోవడానికి, స్క్వాష్ చేయడానికి, సవరించడానికి లేదా వదిలివేయడానికి అనుమతిస్తుంది, ఇది కమిట్ చరిత్రపై చక్కటి నియంత్రణను అందిస్తుంది. సంక్లిష్ట చరిత్రలను ఒక ప్రధాన శాఖలో విలీనం చేయడానికి ముందు వాటిని సిద్ధం చేసేటప్పుడు ఈ పద్ధతి ప్రత్యేకంగా ఉపయోగపడుతుంది, ప్రాజెక్ట్ చరిత్ర శుభ్రంగా మరియు అర్థమయ్యేలా ఉంటుంది.

రిపోజిటరీలోని బ్రాంచ్‌ల చిట్కాలు మరియు ఇతర రిఫరెన్స్‌లకు అప్‌డేట్‌లను రికార్డ్ చేసే Gitలో ఒక మెకానిజం రిఫ్లాగ్‌ని ఉపయోగించడం మరొక అధునాతన పద్ధతి. దూకుడుగా క్లీనింగ్ చేయడం లేదా హిస్టరీ మానిప్యులేషన్‌లో ఎర్రర్‌ల కారణంగా బ్రాంచ్ చిట్కాల ద్వారా నేరుగా యాక్సెస్ చేయలేని ప్రాజెక్ట్ యొక్క మునుపటి స్థితులను మీరు మళ్లీ సందర్శించి, పునరుద్ధరించాల్సిన పునరుద్ధరణ దృశ్యాల కోసం రిఫ్లాగ్ అమూల్యమైనది.

  1. ఏమి చేస్తుంది ఆజ్ఞాపించాలా?
  2. ఇది ప్రస్తుత శాఖ యొక్క హెడ్‌ని పేర్కొన్న కమిట్‌కి రీసెట్ చేస్తుంది, ఆ కమిట్ నుండి స్టేజింగ్ ఏరియా మరియు వర్కింగ్ డైరెక్టరీలో అన్ని మార్పులను విస్మరిస్తుంది.
  3. నేను విలీన ఒప్పందాన్ని తిరిగి పొందవచ్చా?
  4. అవును, మీరు ప్రత్యేకంగా ఉపయోగించి విలీన నిబద్ధతను తిరిగి మార్చవచ్చు , ఇక్కడ "1" నిలుపుకోవడానికి విలీనానికి సంబంధించిన పేరెంట్ నిబద్ధతను నిర్దేశిస్తుంది.
  5. పాత్ర ఏమిటి ?
  6. రిపోజిటరీలోని శాఖల చిట్కాలు మరియు ఇతర సూచనలకు మార్పులను ట్రాక్ చేయడానికి రిలాగ్ ఉపయోగించబడుతుంది, కోల్పోయిన కమిట్‌లను తిరిగి పొందడంలో లేదా రెపోలో చేసిన మార్పులను అన్వేషించడంలో సహాయపడుతుంది.
  7. ఎలా చేస్తుంది విలీనం నుండి భిన్నంగా ఉందా?
  8. రీబేస్ ఒక బ్రాంచ్ యొక్క ఆధారాన్ని కొత్త కమిట్‌గా మార్చడం ద్వారా ప్రాజెక్ట్ చరిత్రను తిరిగి వ్రాస్తుంది, ఇది విలీనంతో పోలిస్తే చరిత్రను మరింత క్లీనర్‌గా చేస్తుంది.
  9. శాఖను రీసెట్ చేసిన తర్వాత బలవంతంగా నెట్టడం సురక్షితమేనా?
  10. మార్పులు ఇప్పటికే పుష్ చేయబడితే రీసెట్ చేసిన తర్వాత ఫోర్స్-పుషింగ్ అవసరం, కానీ ఇది రిమోట్ మార్పులను ఓవర్‌రైట్ చేయగలదు మరియు జాగ్రత్తగా ఉపయోగించాలి.

బహుళ కమిట్‌లను తిరిగి మార్చాల్సిన అవసరం వచ్చినప్పుడు Git రిపోజిటరీని విజయవంతంగా నిర్వహించడం అనేది అందుబాటులో ఉన్న చిక్కులు మరియు సాంకేతికతలను అర్థం చేసుకోవడం. నిర్దిష్ట కమిట్‌కి హార్డ్ రీసెట్‌ల ద్వారా లేదా ప్రతి కమిట్‌కు రివర్ట్ కమాండ్‌లను జాగ్రత్తగా ఉపయోగించడం ద్వారా అయినా, రిపోజిటరీ శుభ్రంగా మరియు చరిత్ర అర్థమయ్యేలా చూసుకోవడమే లక్ష్యం. సహకార ప్రాజెక్ట్‌ల కోసం, ఈ మార్పులను తెలియజేయడం మరియు అంతరాయాలను నివారించడానికి రిమోట్ రిపోజిటరీని జాగ్రత్తగా నిర్వహించడం చాలా కీలకం. అంతిమంగా, ఈ ఆదేశాలను మాస్టరింగ్ చేయడం వల్ల డెవలపర్‌లు తమ ప్రాజెక్ట్ టైమ్‌లైన్‌లపై నియంత్రణను సమర్థవంతంగా నిర్వహించగలుగుతారు.