วิธีใช้การผสาน Git

เผยแพร่แล้ว: 2023-01-03
ทางเท้าสองทางรวมกันเป็นหนึ่งเดียวในสวนสาธารณะที่มีหญ้า
มาสเตอร์แฮนด์/Shutterstock.com
หากต้องการรวมสาขาการพัฒนาเข้ากับสาขาปัจจุบัน ให้ใช้ "git merge dev-branch-name" หากคุณได้รับคำเตือนข้อขัดแย้งเกี่ยวกับการผสาน ให้ใช้ "git merge --abort" เพื่อถอยกลับ หรือแก้ไขไฟล์ที่ได้รับผลกระทบแล้วยืนยัน

Git ใช้ Branch เพื่อแยกกระแสการพัฒนา เพื่อป้องกันไม่ให้ Branch Release ที่เสถียรกลายเป็นมลพิษ การนำงานในสาขาเข้าสู่กระแสหลักหมายถึงการรวมสาขา นี่คือวิธีที่คุณทำ

สารบัญ

การผสานใน Git คืออะไร?
กำลังเตรียมที่จะรวมสาขาใน Git
ทำการผสาน
ดำเนินการผสานไปข้างหน้าอย่างรวดเร็วใน Git
วิธีแก้ปัญหา Merge Conflicts ใน Git
ทุกอย่างผสานเข้าด้วยกันในที่สุด

การผสานใน Git คืออะไร?

Git ได้รับการออกแบบมาเพื่อทำให้การแตกแขนงง่ายและรวดเร็ว ตรงกันข้ามกับระบบควบคุมเวอร์ชันอื่นๆ การแตกสาขาบน Git เป็นเรื่องเล็กน้อย โดยเฉพาะในโครงการที่มีนักพัฒนาหลายคน การแตกสาขาเป็นหนึ่งในเครื่องมือหลักขององค์กรของ Git

ความพยายามในการพัฒนา Sandbox ของ Branches เพื่อให้สามารถแก้ไขหรือเพิ่มรหัสได้โดยไม่ส่งผลกระทบต่อรหัสในสาขาอื่นๆ โดยเฉพาะสาขาหลักหรือสาขาหลัก โดยปกติจะมีรหัสฐานเวอร์ชันเสถียรของคุณ

การแยกการเปลี่ยนแปลงเหล่านี้ออกจากเวอร์ชันโค้ดที่เสถียรของคุณเหมาะสมอย่างยิ่ง แต่ไม่ช้าก็เร็วรหัสใหม่จะได้รับการทดสอบ ตรวจทาน และตรายางเพื่อนำไปใช้ในสาขาหลัก ณ จุดนั้น คุณต้องรวมสาขาของคุณเข้ากับสาขาหลัก

Git Branches ทำงานอย่างไร
ที่เกี่ยวข้อง Git Branches ทำงานอย่างไร

ที่จริงแล้ว สาขาสามารถมีสาขาย่อยได้ ดังนั้นคุณอาจรวมสาขาของคุณเข้ากับสาขาอื่นแทนสาขาหลัก เพียงจำไว้ว่าการผสานจะใช้หนึ่งสาขาและรวมเข้ากับสาขา เป้าหมาย เสมอ ไม่ว่าสาขานั้นจะเป็นสาขาใดก็ตาม หากคุณต้องการรวมสาขาหลักของคุณเข้ากับสาขาอื่น คุณสามารถทำได้เช่นกัน

เช่นเดียวกับการดำเนินการส่วนใหญ่ใน Git คุณดำเนินการผสานในที่เก็บในเครื่องของคุณและพุชไปยังที่เก็บระยะไกลของคุณ

กำลังเตรียมที่จะรวมสาขาใน Git

เรามีโครงการพัฒนาขนาดเล็กที่มีที่เก็บ Git ในเครื่องและที่เก็บ Git ระยะไกล เราได้สร้างสาขาที่ชื่อว่า "bugfix14" จากสาขา "master" และดำเนินการแก้ไขจุดบกพร่อง

งานนั้นเสร็จสมบูรณ์และเราได้ทดสอบโค้ดของเราแล้ว ทุกอย่างทำงานได้ตามที่คาดไว้ เราต้องการรวมการเปลี่ยนแปลงเหล่านั้นไว้ในสาขาหลักเพื่อให้การแก้ไขของเราเป็นส่วนหนึ่งของซอฟต์แวร์รุ่นถัดไป

มีการเตรียมการเล็กน้อยก่อนที่จะทำการผสาน เราจำเป็นต้องตรวจสอบให้แน่ใจว่าสาขาเป้าหมาย—ในกรณีนี้คือสาขา “หลัก”—และสาขาที่เราจะรวมเข้าด้วยกันนั้นเป็นปัจจุบันทั้งคู่

ในการทำเช่นนี้ เราจะใช้คำสั่ง git status

 สถานะคอมไพล์ 

การใช้ git status เพื่อดูสถานะของสาขา

  • ในสาขา bugfix14 : นี่คือสาขาปัจจุบันของเรา
  • สาขาของคุณเป็นปัจจุบันด้วย 'origin/bugfix' : สาขาในที่เก็บในเครื่องของเรามีประวัติคอมมิชชันเหมือนกับสาขาในที่เก็บระยะไกล นั่นหมายความว่าพวกมันเหมือนกัน
  • ไม่มีอะไรที่จะกระทำ ไม่มีการเปลี่ยนแปลงในพื้นที่การจัดเตรียมที่ยังไม่ได้กระทำ
  • working tree clean : ไม่มีการเปลี่ยนแปลงที่ไม่ได้จัดลำดับในไดเร็กทอรีการทำงาน

ข้อมูลทั้งหมดระบุว่าสาขาเป็นปัจจุบัน และเราพร้อมที่จะดำเนินการต่อ หากสิ่งเหล่านี้บ่งชี้ว่ามีการเปลี่ยนแปลง เราจะต้องจัดลำดับ ยอมรับ และส่งต่อไปยังรีโมต หากมีคนอื่นทำงานในไฟล์เหล่านี้ เราอาจต้องดึงการเปลี่ยนแปลงจากที่เก็บระยะไกล

ตรวจสอบสาขาที่เราจะรวมเข้าด้วยกันทำให้กระบวนการรวมง่ายขึ้น นอกจากนี้ยังช่วยให้เราสามารถตรวจสอบได้ว่าเป็นปัจจุบัน มาดูสาขาต้นแบบกัน

 คอมไพล์เช็คเอาต์มาสเตอร์
 สถานะคอมไพล์ 

ตรวจสอบสาขาหลักและใช้สถานะคอมไพล์เพื่อดูสถานะ

เราได้รับการยืนยันเช่นเดียวกันว่าสาขา "หลัก" เป็นปัจจุบัน

ที่เกี่ยวข้อง: วิธีเลือก Git Workflow & Branching Model ที่เหมาะกับทีมของคุณ

ทำการผสาน

ก่อนที่เราจะรวมเข้าด้วยกัน คอมมิชชันของเราจะมีลักษณะดังนี้

ประวัติการกระทำก่อนการรวมสาขา

สาขา "bugfix14" ถูกแยกออกจากสาขา "master" มีการคอมมิตไปยังสาขา "หลัก" หลังจากสร้างสาขา "bugfix14" มีการคอมมิตสองสามครั้งกับสาขา "bugfix14"

เราตรวจสอบแล้วว่าสาขาทั้งสองของเราเป็นปัจจุบัน และเราได้ตรวจสอบสาขา "หลัก" แล้ว เราสามารถออกคำสั่งเพื่อรวมสาขา "bugfix14" เข้ากับสาขา "master"

 git ผสาน bugfix14 

การรวมสาขาด้วยคำสั่ง git merge

การผสานเกิดขึ้น สาขา "bugfix14" ยังคงมีอยู่ แต่ตอนนี้การเปลี่ยนแปลงที่เกิดขึ้นในสาขานั้นถูกรวมเข้ากับสาขา "หลัก"

ประวัติการกระทำหลังจากการรวมสาขา

ในกรณีนี้ คำสั่งผสานจะทำการผสาน สามทาง มีเพียงสองสาขา แต่มีสามสาขาที่เกี่ยวข้อง พวกเขาเป็นหัวหน้าของสาขาใดสาขาหนึ่ง และการกระทำที่สามที่แสดงถึงการดำเนินการผสานเอง

หากต้องการอัปเดตพื้นที่เก็บข้อมูลระยะไกล เราสามารถใช้คำสั่ง git push

 คอมไพล์กด 

พุชการเปลี่ยนแปลงไปยังที่เก็บระยะไกล

บางคนชอบที่จะลบสาขาด้านข้างเมื่อรวมเข้าด้วยกันแล้ว คนอื่นดูแลเพื่อรักษาไว้เป็นบันทึกของประวัติศาสตร์การพัฒนาที่แท้จริงของโครงการ

หากคุณต้องการลบ branch คุณสามารถทำได้โดยใช้คำสั่ง git branch พร้อมกับตัวเลือก -d (delete)

 git branch -d bugfix14 

การลบสาขาในที่เก็บโลคัล

หากต้องการลบสาขาในที่เก็บระยะไกลให้ใช้คำสั่งนี้:

 git push origin -- ลบ bugfix14 

การลบสาขาในที่เก็บระยะไกล

คุณจะมีประวัติการกระทำเชิงเส้น แต่จะไม่ใช่ประวัติที่แท้จริง

ที่เกี่ยวข้อง: วิธีลบ Git Branches บน Local และ Remote Repositories

ดำเนินการผสานไปข้างหน้าอย่างรวดเร็วใน Git

หากคุณยังไม่ได้ตกลงกับสาขา "หลัก" ประวัติของคุณจะมีลักษณะดังนี้ นอกจากนี้ยังจะมีลักษณะเช่นนี้หากคุณปรับสาขาการพัฒนาของคุณใหม่เพื่อให้แนบกับส่วนท้ายของสาขา "หลัก"

ประวัติการกระทำก่อนการรวมแบบกรอไปข้างหน้า

เนื่องจากไม่มีการคอมมิตในแบรนช์ “master” หากต้องการรวมแบรนช์ “bugfix15” สิ่งที่ Git ต้องทำคือชี้เฮดพอยน์เตอร์ “master” ไปที่คอมมิชชันสุดท้ายของแบรนช์ “bugfix15”

เราสามารถใช้คำสั่ง git merge ตามปกติ:

 git ผสาน bugfix15

ที่ทำให้เราได้ผลลัพธ์นี้

วิธีหนึ่งในการดูผลลัพธ์ของการรวมแบบกรอไปข้างหน้า

ซึ่งเหมือนกับสิ่งนี้:

อีกวิธีหนึ่งในการดูผลลัพธ์ของการรวมแบบกรอไปข้างหน้า

ซึ่งก็เหมือนกับสิ่งนี้:

อีกวิธีหนึ่งในการดูผลลัพธ์ของการรวมแบบกรอไปข้างหน้า

Git จะทำการรวมแบบกรอไปข้างหน้า เมื่อใดก็ตามที่ทำได้ หากคอมมิชชันกับสาขา "หลัก" หมายความว่าไม่สามารถผสานแบบกรอไปข้างหน้าได้ Git จะใช้การ ผสานแบบสามทาง

คุณไม่สามารถ บังคับการ รวมแบบกรอไปข้างหน้าได้ ท้ายที่สุดแล้วอาจเป็นไปไม่ได้ แต่คุณสามารถประกาศว่าจะเป็นการผสานแบบกรอไปข้างหน้าหรือไม่ก็ได้ มีตัวเลือกที่สั่งให้ Git ใช้การรวมแบบกรอไปข้างหน้าหากทำได้ แต่จะไม่ทำการผสานแบบสามทางหากไม่สามารถทำได้ ตัวเลือกคือ --ff-only (รวมกรอไปข้างหน้าเท่านั้น)

สิ่งนี้จะรวมสาขา "bugfix15" เข้ากับสาขา "master" แต่เฉพาะในกรณีที่สามารถรวมแบบกรอไปข้างหน้าได้

 git merge --ff-only bugfix15.dll 

การใช้ตัวเลือก --ff-only เพื่อป้องกันไม่ให้ใช้การผสานแบบสามทางหากไม่สามารถผสานแบบกรอไปข้างหน้าได้

Git จะบ่นและออกหากไม่สามารถทำได้

 git merge --ff-only bugfix16.dll 

Git ไม่ทำการรวมใด ๆ เนื่องจากไม่สามารถรวมกรอไปข้างหน้าได้และมีการใช้ตัวเลือก --ff-only

ในกรณีนี้ มีการคอมมิตไปยังสาขา "หลัก" ดังนั้นจึงไม่สามารถรวมกรอไปข้างหน้าได้

วิธีแก้ปัญหา Merge Conflicts ใน Git

หากส่วนเดียวกันของไฟล์เดียวกันถูกเปลี่ยนในทั้งสองสาขา จะไม่สามารถรวมสาขาได้ จำเป็นต้องมีปฏิสัมพันธ์ของมนุษย์เพื่อแก้ไขการแก้ไขที่ขัดแย้งกัน

ที่นี่ เราได้ทำการเปลี่ยนแปลงไฟล์ชื่อ “rot.c” ในสาขาชื่อ “bugfix17” ที่เราต้องการรวมเข้ากับสาขา “master” แต่ “rot.c” ก็เปลี่ยนไปในสาขา “master” ด้วย

 git ผสาน bugfix17 

รับข้อขัดแย้งในการรายงานและหยุดการผสาน

เมื่อเราพยายามผสาน เราได้รับคำเตือนว่ามีข้อขัดแย้ง Git แสดงรายการไฟล์ที่ขัดแย้งกัน และบอกเราว่าการรวมล้มเหลว เราสามารถถอยกลับได้อย่างสมบูรณ์โดยใช้ --abort ตัวเลือก:

 git ผสาน - ยกเลิก

แต่การแก้ไขการผสานไม่น่ากลัวอย่างที่คิด Git ได้ทำงานบางอย่างเพื่อช่วยเรา หากเราแก้ไขหนึ่งในไฟล์ที่ขัดแย้งกัน—ในกรณีของเรา เรามีเพียงหนึ่งไฟล์—เราจะพบส่วนรหัสที่ขัดแย้งกันซึ่งไฮไลต์ไว้สำหรับเรา

git ระบุข้อขัดแย้งภายในไฟล์อย่างไร

ข้อขัดแย้งแต่ละข้อล้อมรอบด้วยอักขระที่น้อยกว่าเจ็ดตัว “ <<<<<<< ” และอักขระที่มากกว่าเจ็ดตัว “ >>>>>>> “ โดยมีเครื่องหมายเท่ากับเจ็ดตัว “ ======= ” คั่นกลาง .

  • โค้ดที่อยู่เหนือเครื่องหมายเท่ากับมาจากสาขาที่คุณกำลังผสาน เข้าไป
  • โค้ดด้านล่างเครื่องหมายเท่ากับคือโค้ดจากสาขาที่คุณกำลังพยายาม ผสาน

คุณสามารถค้นหาหนึ่งในชุดของอักขระเจ็ดตัวและย้ายจากข้อขัดแย้งไปยังข้อขัดแย้งผ่านไฟล์ของคุณได้อย่างง่ายดาย สำหรับข้อขัดแย้งแต่ละข้อ คุณต้องเลือกว่าจะเก็บการแก้ไขชุดใดไว้ คุณต้องแก้ไขโค้ดที่คุณปฏิเสธและบรรทัดเจ็ดอักขระที่ Git เพิ่ม

เราจะเก็บโค้ดจากสาขา “bugfix17” หลังจากแก้ไขแล้วไฟล์ของเราจะมีลักษณะดังนี้

ข้อความที่แก้ไขแก้ไขข้อขัดแย้งในการผสาน

ตอนนี้เราสามารถดำเนินการต่อด้วยการผสาน แต่โปรดทราบว่าเราใช้คำสั่ง commit เพื่อทำเช่นนั้น ไม่ใช่คำสั่ง merge

เรายอมรับการเปลี่ยนแปลงโดยจัดเตรียมไฟล์และยอมรับตามปกติ เราจะตรวจสอบสถานะก่อนที่จะดำเนินการขั้นสุดท้าย

 git เพิ่ม rot.c
 สถานะคอมไพล์
 git commit -m "ผสาน bugfix17" 

การใช้คำสั่ง commit เพื่อทำการผสานให้เสร็จสิ้นหลังจากแก้ไขข้อขัดแย้ง

การผสานเสร็จสมบูรณ์ ตอนนี้เราสามารถส่งสิ่งนี้ไปยังที่เก็บระยะไกลของเรา

ที่เกี่ยวข้อง: วิธีแก้ไข แก้ไข หรือเลิกทำ Git Commits (เปลี่ยนประวัติ Git)

ทุกอย่างผสานเข้าด้วยกันในที่สุด

ในที่สุดสาขาทั้งหมดจะต้องถูกรวมเข้าด้วยกันเพื่อไม่ให้การเปลี่ยนแปลงในสาขานั้นกลายเป็นกำพร้าและถูกลืม

การรวมสาขาเป็นเรื่องง่าย แต่การจัดการกับข้อขัดแย้งอาจซับซ้อนขึ้นในทีมที่ยุ่งและใหญ่ขึ้น การแก้ไขข้อขัดแย้งอาจต้องการข้อมูลจากผู้พัฒนาแต่ละรายเพื่ออธิบายว่ารหัสของพวกเขาทำอะไรและทำไมพวกเขาจึงทำการเปลี่ยนแปลง คุณต้องเข้าใจเรื่องนั้นก่อนจึงจะสามารถตัดสินใจได้อย่างมีข้อมูลว่าจะเก็บการแก้ไขใดไว้

น่าเศร้าที่ Git ไม่สามารถช่วยได้

ที่เกี่ยวข้อง: คุณควรใช้ GUI Git Client หรือไม่