Apa perbedaan antara cabang git, fork, fetch, merge, rebase, dan clone?


502

Saya ingin memahami perbedaan antara cabang, garpu, dan klon di Git?

Demikian pula, apa artinya ketika saya melakukan yang git fetchbertentangan dengan git pull?

Juga, apa rebaseartinya dibandingkan dengan merge?

Bagaimana saya bisa meremas individu melakukan sendiri bersama?

Bagaimana mereka digunakan, mengapa mereka digunakan dan apa yang mereka wakili?

Bagaimana cara GitHub masuk?


19
dapatkah Anda mengubah jawaban yang diterima menjadi jawaban Michael Durrant?
siride

11
Dia tentu saja bisa , tetapi ini harus menjadi pilihannya, dan terus terang sebagian besar orang yang tiba di sini (seperti saya) menginginkan sesuatu yang lebih ringkas, persis seperti jawaban yang dia pilih, yang saat ini adalah satu-satunya sendiri =)
user1271772

Jawaban:


366

Klon hanyalah salinan dari repositori. Di permukaan, hasilnya sama dengan di svn checkoutmana Anda mengunduh kode sumber dari beberapa repositori lainnya. Perbedaan antara VCS terpusat seperti Subversion dan DVCS seperti Git adalah bahwa di Git, ketika Anda mengkloning, Anda sebenarnya menyalin seluruh repositori sumber, termasuk semua sejarah dan cabang. Anda sekarang memiliki repositori baru di mesin Anda dan setiap komitmen yang Anda buat masuk ke repositori itu. Tidak ada yang akan melihat perubahan apa pun sampai Anda mendorong komit ke repositori lain (atau yang asli) atau sampai seseorang menarik komit dari repositori Anda, jika itu dapat diakses secara publik.

Cabang adalah sesuatu yang ada di dalam repositori. Secara konseptual, ini mewakili benang pembangunan. Anda biasanya memiliki cabang master, tetapi Anda juga dapat memiliki cabang tempat Anda mengerjakan beberapa fitur xyz, dan cabang lainnya untuk memperbaiki bug abc. Ketika Anda telah memeriksa cabang, komitmen apa pun yang Anda buat akan tetap berada di cabang itu dan tidak akan dibagikan dengan cabang lain sampai Anda menggabungkannya atau menebangnya kembali ke cabang yang dimaksud. Tentu saja, Git tampak sedikit aneh ketika datang ke cabang sampai Anda melihat model yang mendasari bagaimana cabang diimplementasikan. Daripada menjelaskannya sendiri (saya sudah mengatakan terlalu banyak, metinks), saya akan menautkan ke penjelasan "ilmu komputer" tentang bagaimana model Git bercabang dan melakukan, diambil dari situs web Git:

http://eagain.net/articles/git-for-computer-scientists/

Garpu sebenarnya bukan konsep Git, itu lebih merupakan ide sosial / politik. Artinya, jika beberapa orang tidak senang dengan cara proyek berjalan, mereka dapat mengambil kode sumber dan mengerjakannya sendiri terpisah dari pengembang asli. Itu akan dianggap sebagai garpu. Git memudahkan forking karena semua orang sudah memiliki salinan "master" sendiri dari kode sumber, jadi semudah memutus ikatan dengan pengembang proyek asli dan tidak memerlukan ekspor riwayat dari repositori bersama seperti yang mungkin harus Anda lakukan dengan SVN .

EDIT: karena saya tidak mengetahui definisi "garpu" modern seperti yang digunakan oleh situs-situs seperti GitHub, silakan lihat komentar dan juga jawaban Michael Durrant di bawah tambang untuk informasi lebih lanjut.


125
Garpu tidak selalu berarti pengembang tidak puas dengan repo utama. Biasanya, itu berarti bahwa pengembang lain telah membaca, tetapi tidak menulis, akses ke repo itu. Pengembang dapat melakukan foro repo, membuat perubahan, tetapi karena ia tidak dapat menulis ke repo utama, ia harus mengirimkan perubahannya sebagai tambalan. Jadi, forking juga merupakan cara untuk mendorong kolaborasi tanpa memberikan akses tulis.
brycemcd

5
Saya kira itu benar. Saya hanya pernah melihat "garpu" yang digunakan dalam konteks menciptakan versi proyek baru yang berpotensi bersaing.
siride

32
Anda bisa mengatakan bahwa garpu adalah cabang yang tidak diharapkan untuk digabungkan ke hulu
masonk

6
Git hub menggunakan "garpu" karena garpu dimaksudkan. Ini adalah repositori baru yang disimpan di github, terpisah dari aslinya. Namun, github juga membuatnya sangat mudah untuk menerapkan permintaan tarik. Tarik permintaan pada dasarnya meminta pemilik repositori asli untuk "menarik" perubahan dari garpu repo Anda kembali ke asal. Dengan begitu, semua orang dapat menggunakan kontrol sumber dan memiliki riwayat semua perubahan, termasuk perubahannya, tetapi tidak semua orang perlu akses tulis ke repo asli.
mklauber

4
Saya telah memperbarui jawaban saya untuk memberi tahu orang-orang untuk melihat jawaban Michael Durrant untuk lebih lanjut tentang model github.
siride

531

Git

Jawaban ini termasuk GitHub karena banyak orang bertanya tentang itu juga.

Repositori lokal

Git (lokal) memiliki direktori ( .git) tempat Anda mengkomit file Anda dan ini adalah 'repositori lokal' Anda. Ini berbeda dari sistem seperti SVN tempat Anda menambahkan dan langsung berkomitmen ke repositori jarak jauh.

Git menyimpan setiap versi file yang berubah dengan menyimpan seluruh file. Ini juga berbeda dari SVN dalam hal ini karena Anda dapat pergi ke versi individual apa pun tanpa 'membuat ulang' melalui perubahan delta.

Git tidak 'mengunci' file sama sekali dan dengan demikian menghindari fungsi 'kunci eksklusif' untuk diedit (sistem lama seperti pvc datang ke pikiran), sehingga semua file selalu dapat diedit, bahkan ketika offline. Ini sebenarnya melakukan pekerjaan yang luar biasa untuk menggabungkan perubahan file (dalam file yang sama!) Bersama selama menarik atau mengambil / mendorong ke repositori jarak jauh seperti GitHub. Satu-satunya waktu Anda perlu melakukan perubahan manual (sebenarnya mengedit file) adalah jika dua perubahan melibatkan baris kode yang sama.


Ranting

Cabang memungkinkan Anda untuk mempertahankan kode utama (cabang 'master'), membuat salinan (cabang baru) dan kemudian bekerja di dalam cabang baru itu. Jika pekerjaan memerlukan waktu atau master mendapatkan banyak pembaruan sejak cabang dibuat maka penggabungan atau rebasing (sering lebih disukai untuk sejarah yang lebih baik dan lebih mudah untuk menyelesaikan konflik) terhadap cabang master harus dilakukan. Setelah selesai, Anda menggabungkan perubahan yang dibuat di cabang kembali ke repositori master. Banyak organisasi menggunakan cabang untuk setiap karya apakah itu fitur, bug atau item tugas. Organisasi lain hanya menggunakan cabang untuk perubahan besar seperti peningkatan versi.

Fork: Dengan cabang Anda mengontrol dan mengelola cabang, sedangkan dengan garpu orang lain mengontrol menerima kode kembali.

Secara umum, ada dua pendekatan utama untuk melakukan cabang. Yang pertama adalah menjaga sebagian besar perubahan pada cabang master, hanya menggunakan cabang untuk hal-hal yang lebih besar dan berjalan lebih lama seperti perubahan versi di mana Anda ingin memiliki dua cabang tersedia untuk kebutuhan yang berbeda. Yang kedua adalah di mana Anda pada dasarnya membuat cabang untuk setiap permintaan fitur, memperbaiki bug atau tugas dan kemudian secara manual memutuskan kapan untuk benar-benar menggabungkan cabang-cabang tersebut ke cabang master utama. Walaupun ini terdengar membosankan, ini adalah pendekatan yang umum dan merupakan salah satu yang saat ini saya gunakan dan rekomendasikan karena ini membuat master branch cleaner dan master yang kami promosikan untuk produksi, jadi kami hanya ingin menyelesaikan, menguji kode, melalui rebasing dan penggabungan cabang.

Cara standar untuk membawa cabang 'dalam' untuk dikuasai adalah dengan melakukan a merge. Cabang-cabang juga bisa "diubah" menjadi 'membersihkan' sejarah. Ini tidak memengaruhi kondisi saat ini dan dilakukan untuk memberikan riwayat 'bersih'.

Pada dasarnya, idenya adalah Anda bercabang dari titik tertentu (biasanya dari master). Sejak Anda bercabang, 'master' itu sendiri telah bergerak maju dari titik percabangan itu. Ini akan menjadi 'lebih bersih' (lebih mudah untuk menyelesaikan masalah dan sejarah akan lebih mudah dipahami) jika semua perubahan yang Anda lakukan di cabang dimainkan melawan kondisi master saat ini dengan semua perubahan terbaru. Jadi, prosesnya adalah: menyimpan perubahan; dapatkan master 'baru', dan kemudian terapkan kembali (ini adalah bagian rebase) perubahan lagi terhadap itu. Sadarilah bahwa rebase, seperti penggabungan, dapat menghasilkan konflik yang harus Anda selesaikan secara manual (yaitu, edit dan perbaiki).

Satu pedoman yang perlu diperhatikan:
Hanya rebase jika cabang lokal dan Anda belum mendorongnya ke jauh!
Ini terutama karena rebasing dapat mengubah sejarah yang dilihat orang lain yang mungkin termasuk komitmen mereka sendiri.

Cabang pelacakan

Ini adalah cabang-cabang yang dinamai origin/branch_name(sebagai lawan dari adil branch_name). Ketika Anda mendorong dan menarik kode ke / dari repositori jarak jauh ini sebenarnya adalah mekanisme yang melaluinya. Misalnya, ketika Anda git pushcabang dipanggil building_groups, cabang Anda pergi pertama ke origin/building_groupsdan kemudian pergi ke repositori jarak jauh. Demikian pula, jika Anda melakukan git fetch building_groups, file yang diambil ditempatkan di origin/building_groupscabang Anda . Anda kemudian dapat memilih untuk menggabungkan cabang ini ke salinan lokal Anda. Praktik kami adalah untuk selalu melakukan a git fetchdan manual menggabungkan daripada hanya git pull(yang melakukan kedua hal di atas dalam satu langkah).

Mengambil cabang baru.

Mendapatkan cabang baru: Pada titik awal kloning, Anda akan memiliki semua cabang. Namun, jika pengembang lain menambahkan cabang dan mendorong mereka ke jarak jauh, perlu ada cara untuk 'mengetahui' tentang cabang-cabang dan nama-nama mereka untuk dapat menarik mereka secara lokal. Ini dilakukan melalui git fetchyang akan mendapatkan semua cabang baru dan yang diubah ke repositori lokal menggunakan cabang pelacakan (misalnya, origin/). Setelah fetchdiedit, Anda dapat git branch --remotemendaftar cabang pelacakan dan git checkout [branch]untuk benar-benar beralih ke cabang tertentu.

Penggabungan

Penggabungan adalah proses menggabungkan perubahan kode dari cabang yang berbeda, atau dari versi yang berbeda dari cabang yang sama (misalnya ketika cabang lokal dan remote tidak sinkron). Jika seseorang telah mengembangkan pekerjaan di cabang dan pekerjaan itu selesai, siap dan diuji, maka itu dapat digabungkan ke dalam mastercabang. Ini dilakukan dengan git checkout masterberalih ke mastercabang, lalu git merge your_branch. Penggabungan akan menyatukan semua file yang berbeda dan bahkan perubahan yang berbeda untuk file yang sama. Ini berarti bahwa itu benar-benar akan mengubah kode di dalam file untuk menggabungkan semua perubahan.

Ketika melakukan checkoutdari masteritu juga dianjurkan untuk melakukan git pull origin masteruntuk mendapatkan versi paling terakhir dari master terpencil digabung menjadi tuan setempat. Jika master jarak jauh berubah, yaitu moved forward, Anda akan melihat informasi yang mencerminkan itu selama itu git pull. Jika itu masalahnya (master berubah) Anda disarankan untuk git checkout your_branchkemudian rebasemenguasainya sehingga perubahan Anda benar-benar 'diputar ulang' di atas master 'baru'. Kemudian Anda akan terus mendapatkan master yang terbaru seperti yang ditunjukkan pada paragraf berikutnya.

Jika tidak ada konflik, maka master akan menambahkan perubahan baru. Jika ada konflik, ini berarti bahwa file yang sama memiliki perubahan di sekitar baris kode yang sama yang tidak dapat digabungkan secara otomatis. Dalam hal ini git merge new_branchakan melaporkan bahwa ada konflik yang harus diselesaikan. Anda 'menyelesaikannya' dengan mengedit file (yang akan memiliki kedua perubahan di dalamnya), memilih perubahan yang Anda inginkan, menghapus baris-baris dari perubahan yang tidak Anda inginkan dan kemudian menyimpan file. Perubahan ditandai dengan pemisah seperti ========dan <<<<<<<<.

Setelah Anda menyelesaikan konflik apa pun, Anda akan sekali lagi git adddan git commitperubahan itu untuk melanjutkan penggabungan (Anda akan mendapatkan umpan balik dari git selama proses ini untuk memandu Anda).

Ketika proses tidak bekerja dengan baik, Anda akan menemukan bahwa git merge --abortsangat berguna untuk mengatur ulang berbagai hal.

Rebasing interaktif dan squashing / pemesanan ulang / menghapus komitmen

Jika Anda telah melakukan pekerjaan dalam banyak langkah kecil, misalnya, Anda mengkomit kode sebagai 'work-in-progress' setiap hari, Anda mungkin ingin 'menghancurkan' banyak komit kecil menjadi beberapa komit yang lebih besar. Ini bisa sangat berguna ketika Anda ingin melakukan review kode dengan rekan kerja. Anda tidak ingin memutar ulang semua 'langkah' yang Anda ambil (melalui komit), Anda hanya ingin mengatakan di sini adalah efek akhir (beda) dari semua perubahan saya untuk pekerjaan ini dalam satu komit.

Faktor kunci untuk mengevaluasi ketika mempertimbangkan apakah akan melakukan ini adalah apakah banyak komit terhadap file yang sama atau lebih dari sekali (lebih baik untuk squash melakukan dalam kasus itu). Ini dilakukan dengan alat rebasing interaktif. Alat ini memungkinkan Anda menekan komit, menghapus komit, menulis ulang pesan, dll. Misalnya, git rebase -i HEAD~10( perhatikan: itu a ~, bukan a- ) menampilkan hal-hal berikut:

rebasing interaktif di Git

Berhati-hatilah dan gunakan alat ini 'dengan hati-hati'. Lakukan satu squash / delete / reorder pada satu waktu, keluar dan simpan komit itu, kemudian masukkan kembali alat. Jika komit tidak bersebelahan, Anda dapat memesan ulang (dan kemudian squash sesuai kebutuhan). Anda sebenarnya dapat menghapus komit di sini juga, tetapi Anda benar-benar harus yakin dengan apa yang Anda lakukan saat melakukannya!

Garpu

Ada dua pendekatan utama untuk kolaborasi dalam repositori Git. Yang pertama, dirinci di atas, adalah langsung melalui cabang yang ditarik dan didorong orang dari / ke. Kolaborator ini memiliki kunci SSH mereka yang terdaftar di repositori jarak jauh. Ini akan membiarkan mereka mendorong langsung ke repositori itu. Kelemahannya adalah Anda harus mempertahankan daftar pengguna. Pendekatan lain - forking - memungkinkan siapa saja untuk 'fork' repositori, pada dasarnya membuat salinan lokal di akun repositori Git mereka sendiri. Mereka kemudian dapat melakukan perubahan dan ketika selesai mengirim 'permintaan tarik' (sebenarnya itu lebih merupakan 'dorongan' dari mereka dan permintaan 'tarik' untuk pengelola repositori yang sebenarnya) untuk mendapatkan kode yang diterima.

Metode kedua ini, menggunakan garpu, tidak mengharuskan seseorang untuk mempertahankan daftar pengguna untuk repositori.


GitHub

GitHub (repositori jarak jauh) adalah sumber jarak jauh yang biasanya Anda tekan dan tarik perubahan yang dilakukan jika Anda memiliki (atau ditambahkan ke) repositori tersebut, sehingga lokal dan jarak jauh sebenarnya cukup berbeda. Cara lain untuk memikirkan repositori jarak jauh adalah bahwa itu adalah .gitstruktur direktori yang hidup di server jauh.

Ketika Anda 'bercabang' - di GUI browser web GitHub Anda dapat mengklik tombol ini Gambar tombol garpu- Anda membuat salinan ('klon') dari kode di akun GitHub Anda . Ini bisa menjadi sedikit halus pertama kali Anda melakukannya, jadi tetap pastikan Anda melihat repositori yang basis kode-nya terdaftar di bawah - baik pemilik asli atau 'bercabang dari' dan Anda, misalnya, seperti ini:

Gambar nama repositori bercabang

Setelah memiliki salinan lokal, Anda dapat membuat perubahan sesuai keinginan (dengan menarik dan mendorongnya ke mesin lokal). Ketika Anda selesai maka Anda mengirimkan 'tarik permintaan' ke pemilik / admin repositori asli (terdengar mewah tetapi sebenarnya Anda cukup mengklik ini Gambar tombol tarik permintaan:) dan mereka 'menariknya'.

Yang lebih umum untuk tim yang mengerjakan kode bersama adalah 'mengkloning' repositori (klik ikon 'salin' di layar utama repositori). Kemudian, ketik git clonedan tempel secara lokal . Ini akan mengatur Anda secara lokal dan Anda juga dapat mendorong dan menarik ke lokasi GitHub (dibagi).

Klon

Seperti yang ditunjukkan di bagian GitHub, klon adalah salinan dari repositori. Ketika Anda memiliki repositori jarak jauh, Anda mengeluarkan git cloneperintah terhadap URL-nya dan Anda kemudian berakhir dengan salinan lokal, atau kloning, dari repositori. Klon ini memiliki segalanya , file, cabang master, cabang lainnya, semua komit yang ada, seluruh shebang. Klon inilah yang membuat Anda melakukan penambahan dan komit, lalu repositori jarak jauh itu sendiri yang mendorongnya. Konsep lokal / jarak jauh inilah yang menjadikan Git (dan sistem yang serupa dengannya seperti Mercurial) menjadi DVCS ( Sistem Kontrol Versi Terdistribusi ) yang bertentangan dengan CVS (Sistem Versi Kode) yang lebih tradisional seperti SVN, PVCS, CVS, dll. Anda komit langsung ke repositori jarak jauh.

Visualisasi

Visualisasi konsep inti dapat dilihat di
http://marklodato.github.com/visual-git-guide/index-en.html dan
http://ndpsoftware.com/git-cheatsheet.html#loc=index

Jika Anda ingin tampilan visual tentang bagaimana perubahan bekerja, Anda tidak bisa mengalahkan alat visual gitg( gitxuntuk macOS) dengan GUI yang saya sebut 'peta kereta bawah tanah' (terutama London Underground), bagus untuk menunjukkan siapa yang melakukan apa, bagaimana hal berubah, menyimpang dan bergabung, dll.

Anda juga dapat menggunakannya untuk menambah, melakukan, dan mengelola perubahan Anda!

Gambar antarmuka gitg / gitx

Meskipun gitg / gitx cukup minim, jumlah alat GUI terus berkembang. Banyak pengguna Mac menggunakan forb gitx fork dan untuk Linux, opsi yang bagus adalah smart-git dengan antarmuka yang intuitif namun kuat:

Gambar dari GUI smart-git

Perhatikan bahwa bahkan dengan alat GUI, Anda mungkin akan melakukan banyak perintah di baris perintah.

Untuk ini, saya memiliki alias berikut di ~/.bash_aliasesfile saya (yang dipanggil dari ~/.bashrcfile saya untuk setiap sesi terminal):

# git
alias g='git status'
alias gcob='git checkout -b '
alias gcom='git checkout master'
alias gd='git diff'
alias gf='git fetch'
alias gfrm='git fetch; git reset --hard origin/master'
alias gg='git grep '
alias gits='alias | grep "^alias g.*git.*$"'
alias gl='git log'
alias gl1='git log --oneline'
alias glf='git log --name-status'
alias glp='git log -p'
alias gpull='git pull '
alias gpush='git push '

DAN saya memiliki "alias git" berikut dalam ~/.gitconfigfile saya - mengapa memilikinya?
Sehingga penyelesaian cabang (dengan kunci TAB) berfungsi!

Jadi ini adalah:

[alias]
  co = checkout
  cob = checkout -b

Contoh penggunaan: git co [branch]<- penyelesaian tab untuk cabang akan berfungsi.

Alat Belajar GUI

Anda dapat menemukan https://learngitbranching.js.org/ berguna dalam mempelajari beberapa konsep dasar. Cuplikan layar: Video: https://youtu.be/23JqqcLPss0masukkan deskripsi gambar di sini

Akhirnya, 7 penyelamat utama!

  1. Anda membuat perubahan, menambah dan mengkomitnya (tetapi jangan mendorong) dan kemudian oh! Anda sadar bahwa Anda adalah master!

    git reset [filename(s)]
    git checkout -b [name_for_a_new_branch]
    git add [file(s)]
    git commit -m "A useful message"
    
    Voila!  You've moved that 'master' commit to its own branch !
  2. Anda mengacaukan beberapa file saat bekerja di cabang lokal dan hanya ingin kembali ke apa yang terakhir kali Anda lakukan git pull:

    git reset --hard origin/master  # You will need to be comfortable doing this!
  3. Anda mulai membuat perubahan secara lokal, Anda mengedit setengah lusin file dan kemudian, oh sial, Anda masih di cabang master (atau yang lain):

    git checkout -b new_branch_name  # just create a new branch
    git add .                      # add the changes files
    git commit -m"your message"    # and commit them
  4. Anda mengacaukan satu file tertentu di cabang Anda saat ini dan pada dasarnya ingin 'mereset' file itu (kehilangan perubahan) menjadi bagaimana itu terakhir kali Anda menariknya dari repositori jarak jauh:

    git checkout your/directories/filename

    Ini sebenarnya me-reset file (seperti banyak perintah Git itu tidak bernama dengan baik untuk apa yang dilakukannya di sini).

  5. Anda membuat beberapa perubahan secara lokal, Anda ingin memastikan Anda tidak kehilangan mereka saat Anda melakukan git resetatau rebase: Saya sering membuat salinan manual dari seluruh proyek ( cp -r ../my_project ~/) ketika saya tidak yakin apakah saya mungkin mengacaukan Git atau kehilangan penting perubahan.

  6. Anda rebasing tetapi hal-hal menjadi kacau:

    git rebase --abort # To abandon interactive rebase and merge issues
  7. Tambahkan cabang Git Anda ke PS1prompt Anda (lihat https://unix.stackexchange.com/a/127800/10043 ), mis.

    Gambar prompt

    Cabang itu selenium_rspec_conversion.


1
2/20/12 Menambahkan info tentang penggabungan vs. rebase
Michael Durrant

1
6/16/12 Menambahkan bagian pada klon untuk membuatnya lebih lengkap.
Michael Durrant

4
Begitu banyak teks !! Saya akan tetap berpegang pada Subversi sederhana saya :-)
Jonny

6
Hah? Seorang pengguna subversi juga bisa menulis buku tentang menggunakan subversi. Saya berpendapat bahwa subversi adalah teknologi yang lebih tua dengan fungsionalitas yang lebih sedikit. Saya pribadi menemukan git sangat mudah digunakan. ymmv
Michael Durrant

3
Wow, Micheal! SO adalah tentang berbagi pengetahuan. Terima kasih atas kerja yang luar biasa, pasti +1
Michiel

143

Berikut ini adalah gambar Oliver Steele tentang bagaimana semuanya cocok:

masukkan deskripsi gambar di sini


6
Gambar ini dapat diperbarui untuk menambahkan "git clone" yang saya yakin kebanyakan orang sudah terbiasa dengan hal apa pun.
Contango

3
@ Gravitas, saya sangat suka gambar ini, tetapi tidak memberi tahu saya kapan file ditimpa dan kapan mereka digabung. Bisakah Anda memberi tahu saya yang mana untuk perintah ini? Mungkin perintah menimpa di atas dan perintah menggabungkan di bawah drive? Terima kasih.
zylstra

Dari apa yang saya mengerti, git pull akan menarik turun dari jarak jauh apa pun yang Anda minta (jadi, batang apa pun yang Anda minta) dan langsung menggabungkannya ke cabang tempat Anda berada saat Anda mengajukan permintaan. Tarik adalah permintaan tingkat tinggi yang menjalankan 'ambil' lalu 'gabungan' secara default, atau rebase dengan '–rebase'. Anda bisa melakukannya tanpa itu, itu hanya kenyamanan.
Contango

Di mana tepatnya git klon akan pergi dalam diagram ini? Juga git bergabung? Saya sangat baru git tapi saya suka gambar ini.
Mishelle

2
Saya akan melihat apakah saya dapat melakukan versi diagram yang diperbarui.
Contango

8

Fork Vs. Klon - dua kata yang keduanya berarti salinan

Silakan lihat diagram ini . (Asalnya dari http://www.dataschool.io/content/images/2014/Mar/github1.png ).

.-------------------------.     1. Fork     .-------------------------.
| Your GitHub repo        | <-------------- | Joe's GitHub repo       |
| github.com/you/coolgame |                 | github.com/joe/coolgame |
| ----------------------- | 7. Pull Request | ----------------------- |
| master -> c224ff7       | --------------> | master -> c224ff7 (c)   |
| anidea -> 884faa1 (a)   |                 | anidea -> 884faa1 (b)   |
'-------------------------'                 '-------------------------'
    |                 ^
    | 2. Clone        |
    |                 |
    |                 |
    |                 |
    |                 |
    |                 | 6. Push (anidea => origin/anidea)
    v                 |
.-------------------------.
| Your computer           |  3. Create branch 'anidea'
| $HOME/coolgame          |
| ----------------------- |  4. Update a file
| master -> c224ff7       |
| anidea -> 884faa1       |  5. Commit (to 'anidea')
'-------------------------'

(a) - after you have pushed it
(b) - after Joe has accepted it
(c) - eventually Joe might merge 'anidea' (make 'master -> 884faa1')

Garpu

  • Salinan ke repo jarak jauh Anda (cloud) yang menautkannya dengan Joe
  • Salinan Anda kemudian dapat mengkloning ke repo lokal Anda dan F *% $ - up
  • Setelah selesai, Anda dapat mendorong kembali ke remote
  • Anda kemudian dapat bertanya kepada Joe apakah ia ingin menggunakannya dalam proyeknya dengan mengeklik pull-request

Klon

  • salinan ke repo lokal Anda (harddisk)

Perhatikan bahwa keuntungan DVCS yang sebenarnya adalah bahwa Anda tidak memerlukan izin akses khusus untuk repo Joe untuk melakukan ini. Jika Joe ingin Anda berkontribusi lebih sering, ia bisa memberi Anda hak akses: mereka bisa mendorong Anda anideake repo dan menyelamatkan Anda dari tugas-tugas menjaga agar garpu Anda selalu terbarui. OTOH jika Anda tidak akan berhasil mencapai kesepakatan dengan Joe, Anda bisa terus mengembangkan dan menggunakan garpu Anda (dan lihat apakah Anda dapat membuatnya berubah pikiran nanti).
Alois Mahdal

6

Hanya untuk menambah yang lain, catatan khusus untuk forking.

Adalah baik untuk menyadari bahwa secara teknis, kloning repo dan forking repo adalah hal yang sama. Melakukan:

git clone $some_other_repo

dan Anda dapat menekan diri Anda di bagian belakang --- Anda baru saja memotong beberapa repo lainnya.

Git, sebagai VCS, sebenarnya semua tentang kloning forking. Selain dari "hanya menjelajah" menggunakan UI jarak jauh seperti cgit, ada sangat sedikit hubungannya dengan git repo yang tidak melibatkan forking kloning repo di beberapa titik.

Namun,

  • ketika seseorang mengatakan saya bercabang repo X , mereka berarti bahwa mereka telah membuat klon repo di tempat lain dengan maksud untuk mengeksposnya kepada orang lain, misalnya untuk menunjukkan beberapa eksperimen, atau untuk menerapkan mekanisme kontrol akses yang berbeda (misalnya untuk memungkinkan orang tanpa Akses Github tetapi dengan akun internal perusahaan untuk berkolaborasi).

    Fakta bahwa: repo kemungkinan besar dibuat dengan perintah selain daripada git clone, bahwa itu kemungkinan besar di-host di suatu tempat di server sebagai lawan dari laptop seseorang, dan kemungkinan besar memiliki format yang sedikit berbeda (itu adalah "bare repo", yaitu. Tanpa pohon kerja) semua hanya detail teknis.

    Fakta bahwa itu kemungkinan besar akan berisi kumpulan cabang, tag, atau commit yang berbeda kemungkinan besar merupakan alasan mengapa mereka melakukannya pada awalnya.

    (Apa yang dilakukan Github ketika Anda mengklik "garpu", hanya mengkloning dengan gula tambahan: itu mengkloning repo untuk Anda, meletakkannya di akun Anda, mencatat "bercabang dari" suatu tempat, menambahkan remote bernama "hulu", dan yang paling penting, memainkan animasi yang bagus.)

  • Ketika seseorang mengatakan saya mengkloning repo X , artinya mereka telah membuat klon repo secara lokal di laptop atau desktop mereka dengan niat mempelajarinya, bermain dengannya, berkontribusi padanya, atau membangun sesuatu dari kode sumber di dalamnya.

Keindahan Git adalah bahwa ia membuat ini semua sangat cocok bersama: semua repo ini memiliki bagian yang sama dari rantai blok komit sehingga memungkinkan untuk secara aman (lihat catatan di bawah) menggabungkan perubahan bolak-balik antara semua repo yang Anda inginkan.


Catatan: "aman" selama Anda tidak menulis ulang bagian umum dari rantai, dan selama perubahannya tidak saling bertentangan.

Dengan menggunakan situs kami, Anda mengakui telah membaca dan memahami Kebijakan Cookie dan Kebijakan Privasi kami.
Licensed under cc by-sa 3.0 with attribution required.