Git rebase: Semua yang Perlu Anda Ketahui
Diterbitkan: 2022-12-15 Perintah Git rebase
menggabungkan dua cabang kode sumber menjadi satu. Perintah merge
Git juga melakukan itu. Kami menjelaskan apa yang dilakukan rebase
, bagaimana penggunaannya, dan kapan harus menggunakan merge
.
Ledakan Git
Apa itu gabungan Git?
Apa itu rebase Git?
Cara Rebase Ke Cabang Lain
Git Rebase vs. Merge: Yang Mana Yang Harus Anda Gunakan?
Untuk Rebase, atau Tidak Rebase?
Ledakan Git
Frustrasi dengan sistem kontrol versi lain dan pembaruan serta komitmennya yang lambat, Linus Torvalds, dari ketenaran kernel Linux, menyisihkan satu bulan di tahun 2005 untuk menulis sendiri. Dia menamakannya Git.
Situs seperti GitHub, GitLab, dan BitBucket telah mempromosikan dan memanfaatkan Git secara simbiosis. Saat ini Git digunakan secara global, dengan 98 persen dari 71 ribu responden dalam survei tahun 2022 menggunakan Git sebagai sistem kontrol versi.
Salah satu keputusan desain utama Git adalah kecepatan. Secara khusus, bekerja dengan cabang harus secepat mungkin. Cabang adalah bagian mendasar dari sistem kontrol versi. Repositori proyek akan memiliki cabang utama atau master. Di sinilah basis kode proyek berada. Pengembangan, seperti fitur baru, berlangsung di cabang samping yang terpisah. Ini menghentikan pekerjaan yang dilakukan di cabang dari mengacaukan cabang master, dan memungkinkan pengembangan simultan terjadi di berbagai bagian basis kode.
Saat pengembangan di cabang samping selesai, perubahan dipindahkan ke cabang master dengan menggabungkan cabang pengembangan ke cabang master. Di sistem kontrol versi lain yang bekerja dengan cabang sulit dan mahal secara komputasi. Bekerja dengan cabang di Git sangat cepat, dan sangat ringan. Apa yang dulunya merupakan latihan yang membosankan dan sering dihindari di sistem lain, menjadi sepele di Git.
Perintah Git rebase
adalah cara lain untuk mentransfer perubahan dari satu cabang ke cabang lain. Perintah merge
dan rebase
memiliki tujuan yang serupa, tetapi mereka mencapai tujuannya dengan cara yang berbeda dan menghasilkan hasil yang sedikit berbeda.
Apa itu gabungan Git?
Jadi untuk apa perintah merge
Git? Katakanlah Anda telah membuat cabang bernama dev-branch
untuk mengerjakan fitur baru.
Anda membuat beberapa komitmen, dan menguji fitur baru Anda. Semuanya bekerja dengan baik. Sekarang Anda ingin mengirimkan fitur baru Anda ke cabang master
. Anda harus berada di cabang master
untuk menggabungkan yang lain dengannya.
Kami dapat memastikan kami berada di cabang master
dengan memeriksanya secara eksplisit sebelum kami bergabung.
master checkout git
Kami sekarang dapat memberi tahu Git untuk menggabungkan dev-branch
saat ini, yang merupakan cabang master
.
git menggabungkan cabang dev
merge
kami selesai untuk kami. Jika Anda memeriksa cabang master
dan mengompilasinya, itu akan memiliki fitur yang baru dikembangkan di dalamnya. Apa yang sebenarnya dilakukan Git adalah penggabungan tiga arah. itu membandingkan komit terbaru di cabang master
dan dev-branch
, dan komit di cabang master
segera sebelum dev-branch
dibuat. Itu kemudian melakukan komit pada cabang master
.
Penggabungan dianggap tidak merusak karena tidak menghapus apa pun dan tidak mengubah riwayat Git apa pun. Cabang dev-branch
masih ada, dan tidak ada komit sebelumnya yang diubah. Komit baru dibuat yang menangkap hasil penggabungan tiga arah.
Setelah penggabungan, repositori Git kita terlihat seperti garis waktu dengan garis alternatif bercabang dan kemudian kembali ke garis waktu utama.
Cabang dev-branch
telah dimasukkan ke dalam cabang master
.
Jika Anda memiliki banyak cabang dalam satu proyek, riwayat proyek dapat menjadi membingungkan. Ini sering terjadi jika sebuah proyek memiliki banyak kontributor. Karena upaya pengembangan terbagi menjadi banyak jalur yang berbeda, riwayat pengembangan menjadi non-linier. Mengurai riwayat komit menjadi lebih sulit jika cabang memiliki cabangnya sendiri.
Perhatikan bahwa jika Anda memiliki perubahan yang tidak dikomit di cabang master
, Anda harus melakukan sesuatu dengan perubahan ini sebelum Anda dapat menggabungkan apa pun ke dalamnya. Anda bisa membuat cabang baru dan melakukan perubahan di sana, lalu melakukan penggabungan. Anda kemudian perlu menggabungkan cabang sementara Anda kembali ke cabang master.
Itu berhasil, tetapi Git memiliki perintah yang mencapai hal yang sama, tanpa harus membuat cabang baru. Perintah stash
menyimpan perubahan yang belum dikomit untuk Anda, dan memungkinkan Anda memanggilnya kembali dengan stash pop
.
Anda akan menggunakannya seperti ini:
menyimpan git menggabungkan cabang dev simpanan pop
Hasil akhirnya adalah cabang gabungan, dengan perubahan yang belum disimpan dipulihkan.
Apa itu rebase Git?
Perintah Git rebase
mencapai tujuannya dengan cara yang sama sekali berbeda. Dibutuhkan semua komit dari cabang yang akan Anda rebase dan memutarnya kembali ke ujung cabang tempat Anda melakukan rebase.
Mengambil contoh kami sebelumnya, sebelum kami melakukan tindakan apa pun, repositori Git kami terlihat seperti ini. Kami memiliki cabang bernama dev-branch
dan kami ingin memindahkan perubahan tersebut ke cabang master
.
Setelah rebase
, sepertinya satu garis waktu perubahan yang sepenuhnya linier.
Cabang dev-branch
telah dihapus, dan komit di dev-branch
telah ditambahkan ke cabang master. Hasil akhirnya sama seperti jika komit di dev-branch
sebenarnya telah langsung dikomit ke cabang master
. Komit tidak hanya ditempelkan ke cabang master
, tetapi juga "diputar ulang" dan ditambahkan segar.
Inilah mengapa perintah rebase
dianggap merusak. Cabang yang diubah basisnya tidak lagi ada sebagai cabang terpisah, dan riwayat Git proyek Anda telah ditulis ulang. Anda tidak dapat menentukan di beberapa titik selanjutnya komit mana yang awalnya dibuat untuk dev-branch
.
Namun, itu meninggalkan Anda dengan sejarah yang disederhanakan, linier. Dibandingkan dengan repositori dengan lusinan atau bahkan ratusan cabang dan penggabungan, membaca log Git atau menggunakan GUI grafis git untuk melihat grafik repositori, repositori yang dibuat ulang sangat mudah untuk dipahami.
Cara Rebase Ke Cabang Lain
Mari kita coba contoh git rebase
. Kami punya proyek dengan cabang bernama new-feature
. Kami akan mengubah rebase
itu menjadi cabang master
seperti ini.
Pertama, kami memeriksa bahwa cabang master
tidak memiliki perubahan yang luar biasa.
status git
Kami memeriksa cabang new-feature
.
git checkout fitur baru
Kami memberi tahu rebase
untuk mengubah basis cabang saat ini ke cabang master.
git rebase master
Kita dapat melihat bahwa kita masih memiliki dua cabang.
cabang git
Kami bertukar kembali ke cabang master
master checkout git
Kami menggabungkan cabang fitur baru ke cabang saat ini, yang dalam kasus kami adalah cabang master
.
git menggabungkan fitur baru
Menariknya, kami masih memiliki dua cabang setelah penggabungan terakhir.
Perbedaannya adalah, sekarang kepala cabang new-feature
dan kepala cabang master
diatur untuk menunjuk ke komit yang sama, dan sejarah Git tidak menunjukkan dulu ada cabang new-feature
terpisah, selain dari label cabang.
Git Rebase vs. Merge: Yang Mana Yang Harus Anda Gunakan?
Ini bukan kasus rebase
vs. merge
. Keduanya adalah perintah yang kuat dan Anda mungkin akan menggunakan keduanya. Yang mengatakan, ada kasus penggunaan di mana rebase
tidak berfungsi dengan baik. Kesalahan unpicking yang disebabkan oleh kesalahan menggunakan merge
memang tidak menyenangkan, tetapi unpicking error yang disebabkan oleh rebase
adalah neraka.
Jika Anda adalah satu-satunya pengembang yang menggunakan repositori, kecil kemungkinan Anda melakukan sesuatu dengan rebase
yang membawa malapetaka. Anda masih bisa melakukan rebase
ke arah yang salah misalnya, dan rebase
cabang master Anda ke cabang new-feature
Anda. Untuk mendapatkan kembali cabang master
Anda, Anda perlu melakukan rebase
lagi, kali ini dari cabang new-feature
ke cabang master
Anda. Itu akan memulihkan cabang master
Anda, meskipun dengan riwayat yang tampak aneh.
Jangan gunakan rebase
pada cabang bersama tempat orang lain cenderung bekerja. Perubahan Anda pada repositori Anda akan menyebabkan masalah bagi banyak orang saat Anda memasukkan kode rebased Anda ke repositori jarak jauh Anda.
Jika proyek Anda memiliki banyak kontributor, hal yang aman untuk dilakukan hanyalah menggunakan rebase
di repositori lokal Anda, bukan di cabang publik. Demikian pula, jika permintaan penarikan merupakan bagian dari tinjauan kode Anda, jangan gunakan rebase
. Atau setidaknya, jangan gunakan rebase
setelah membuat pull request. Pengembang lain cenderung melihat komit Anda, yang berarti bahwa perubahan itu ada di cabang publik, meskipun tidak di cabang master
.
Bahayanya adalah Anda akan melakukan rebase
komit yang telah didorong ke repositori jarak jauh, dan pengembang lain mungkin sudah mendasarkan pekerjaan pada komit tersebut. rebase
lokal Anda akan membuat komitmen yang ada menghilang. Jika Anda mendorong perubahan itu ke repositori, Anda tidak akan populer.
Kontributor lain harus melalui merge
yang berantakan agar pekerjaan mereka didorong kembali ke repositori. Jika Anda kemudian menarik perubahan mereka kembali ke repositori lokal Anda, Anda kemudian dihadapkan pada penghapusan perubahan duplikat yang berantakan.
Untuk Rebase, atau Tidak Rebase?
Rebase
mungkin dilarang dalam proyek Anda. Mungkin ada keberatan lokal dan budaya. Beberapa proyek atau organisasi menganggap rebase
sebagai bentuk bid'ah, dan tindakan penodaan. Beberapa orang percaya sejarah Git harus menjadi catatan permanen yang tidak dapat diganggu gugat tentang apa yang telah terjadi. Jadi, rebase
mungkin tidak dapat dilakukan.
Tapi, digunakan secara lokal, di cabang pribadi, rebase
adalah alat yang berguna.
Dorong setelah Anda melakukan rebase, dan batasi ke cabang tempat Anda satu-satunya pengembang. Atau setidaknya, di mana semua pengembangan telah berhenti, dan tidak ada orang lain yang mendasarkan pekerjaan lain dari komitmen cabang Anda.
Lakukan itu dan Anda akan terhindar dari masalah apa pun.
TERKAIT: Cara Memeriksa dan Memperbarui Versi Git Anda