Git - Konsep Dasar
Sistem Kontrol Versi
Version Control System (VCS) adalah perangkat lunak yang membantu pengembang perangkat lunak untuk bekerja sama dan memelihara riwayat lengkap pekerjaan mereka.
Di bawah ini adalah fungsi dari VCS -
- Memungkinkan pengembang bekerja secara bersamaan.
- Tidak memungkinkan menimpa perubahan satu sama lain.
- Mempertahankan sejarah setiap versi.
Berikut adalah jenis-jenis VCS -
- Sistem kontrol versi terpusat (CVCS).
- Sistem kontrol versi terdistribusi / terdesentralisasi (DVCS).
Dalam bab ini, kita akan berkonsentrasi hanya pada sistem kontrol versi terdistribusi dan terutama pada Git. Git berada di bawah sistem kontrol versi terdistribusi.
Sistem Kontrol Versi Terdistribusi
Sistem kontrol versi terpusat (CVCS) menggunakan server pusat untuk menyimpan semua file dan memungkinkan kolaborasi tim. Namun kelemahan utama CVCS adalah titik kegagalannya, yaitu kegagalan server pusat. Sayangnya, jika server pusat mati selama satu jam, maka selama jam itu, tidak ada yang bisa berkolaborasi sama sekali. Dan bahkan dalam kasus terburuk, jika disk dari server pusat rusak dan cadangan yang tepat belum diambil, maka Anda akan kehilangan seluruh riwayat proyek. Di sini, sistem kontrol versi terdistribusi (DVCS) muncul.
Klien DVCS tidak hanya memeriksa snapshot terbaru dari direktori tetapi juga sepenuhnya mencerminkan repositori. Jika server mati, maka repositori dari klien mana pun dapat disalin kembali ke server untuk memulihkannya. Setiap pembayaran adalah cadangan lengkap dari repositori. Git tidak bergantung pada server pusat dan itulah mengapa Anda dapat melakukan banyak operasi saat Anda offline. Anda dapat melakukan perubahan, membuat cabang, melihat log, dan melakukan operasi lain saat Anda offline. Anda hanya memerlukan koneksi jaringan untuk menerbitkan perubahan Anda dan mengambil perubahan terbaru.
Keuntungan dari Git
Gratis dan open source
Git dirilis di bawah lisensi open source GPL. Ini tersedia secara gratis melalui internet. Anda dapat menggunakan Git untuk mengelola proyek properti tanpa membayar sepeser pun. Karena ini adalah open source, Anda dapat mendownload kode sumbernya dan juga melakukan perubahan sesuai dengan kebutuhan Anda.
Cepat dan kecil
Karena sebagian besar operasi dilakukan secara lokal, ini memberikan keuntungan besar dalam hal kecepatan. Git tidak bergantung pada server pusat; itulah sebabnya, tidak perlu berinteraksi dengan server jarak jauh untuk setiap operasi. Bagian inti Git ditulis dalam C, yang menghindari overhead waktu proses yang terkait dengan bahasa tingkat tinggi lainnya. Meskipun Git mencerminkan seluruh repositori, ukuran data di sisi klien kecil. Ini menggambarkan efisiensi Git dalam mengompresi dan menyimpan data di sisi klien.
Cadangan implisit
Kemungkinan kehilangan data sangat jarang bila ada banyak salinannya. Data yang ada di sisi klien mana pun mencerminkan repositori, oleh karena itu dapat digunakan jika terjadi crash atau kerusakan disk.
Keamanan
Git menggunakan fungsi hash kriptografi umum yang disebut fungsi hash aman (SHA1), untuk memberi nama dan mengidentifikasi objek dalam database-nya. Setiap file dan komit dijumlahkan dan diambil oleh checksumnya pada saat pembayaran. Ini menyiratkan bahwa, tidak mungkin untuk mengubah file, tanggal, dan mengkomit pesan dan data lainnya dari database Git tanpa mengetahui Git.
Tidak perlu perangkat keras yang kuat
Dalam kasus CVCS, server pusat harus cukup kuat untuk melayani permintaan seluruh tim. Untuk tim yang lebih kecil, ini bukan masalah, tetapi seiring bertambahnya ukuran tim, batasan perangkat keras server dapat menjadi penghambat kinerja. Dalam kasus DVCS, pengembang tidak berinteraksi dengan server kecuali mereka perlu mendorong atau menarik perubahan. Semua pengangkatan berat terjadi di sisi klien, sehingga perangkat keras server bisa sangat sederhana.
Percabangan lebih mudah
CVCS menggunakan mekanisme copy yang murah, Jika kita membuat cabang baru maka akan menyalin semua kode ke cabang baru, sehingga memakan waktu dan tidak efisien. Selain itu, penghapusan dan penggabungan cabang di CVCS rumit dan memakan waktu. Tetapi manajemen cabang dengan Git sangat sederhana. Hanya perlu beberapa detik untuk membuat, menghapus, dan menggabungkan cabang.
Terminologi DVCS
Repositori Lokal
Setiap alat VCS menyediakan tempat kerja pribadi sebagai copy pekerjaan. Pengembang membuat perubahan di tempat kerja pribadi mereka dan setelah komit, perubahan ini menjadi bagian dari repositori. Git mengambil satu langkah lebih jauh dengan memberi mereka salinan pribadi dari seluruh repositori. Pengguna dapat melakukan banyak operasi dengan repositori ini seperti menambah file, menghapus file, mengganti nama file, memindahkan file, melakukan perubahan, dan banyak lagi.
Direktori Kerja dan Area Pementasan atau Indeks
Direktori kerja adalah tempat file-file diperiksa. Di CVCS lain, pengembang biasanya membuat modifikasi dan mengkomit perubahan mereka langsung ke repositori. Tapi Git menggunakan strategi yang berbeda. Git tidak melacak setiap file yang dimodifikasi. Setiap kali Anda melakukan suatu operasi, Git mencari file yang ada di area staging. Hanya file yang ada di area pementasan yang dipertimbangkan untuk komit dan tidak semua file yang dimodifikasi.
Mari kita lihat alur kerja dasar Git.
Step 1 - Anda mengubah file dari direktori kerja.
Step 2 - Anda menambahkan file ini ke area pementasan.
Step 3- Anda melakukan operasi komit yang memindahkan file dari area pementasan. Setelah operasi push, itu menyimpan perubahan secara permanen ke repositori Git.
Misalkan Anda memodifikasi dua file, yaitu "sort.c" dan "search.c" dan Anda menginginkan dua komit yang berbeda untuk setiap operasi. Anda dapat menambahkan satu file di staging area dan melakukan commit. Setelah komit pertama, ulangi prosedur yang sama untuk file lain.
# First commit
[bash]$ git add sort.c
# adds file to the staging area
[bash]$ git commit –m “Added sort operation”
# Second commit
[bash]$ git add search.c
# adds file to the staging area
[bash]$ git commit –m “Added search operation”
Blob
Blob adalah singkatan dari Binary Large Oblelucon. Setiap versi file diwakili oleh blob. Blob menyimpan data file tetapi tidak berisi metadata apa pun tentang file tersebut. Ini adalah file biner, dan dalam database Git, ini dinamai sebagai hash SHA1 dari file itu. Di Git, file tidak dialamatkan dengan nama. Semuanya ditujukan pada konten.
Pohon
Pohon adalah sebuah objek yang merepresentasikan sebuah direktori. Ini menampung blob serta sub-direktori lainnya. Pohon adalah file biner yang menyimpan referensi ke gumpalan dan pohon yang juga dinamai sebagaiSHA1 hash dari objek pohon.
Komit
Komit memegang status repositori saat ini. Komit juga dinamai olehSHA1hash. Anda dapat mempertimbangkan objek komit sebagai simpul dari daftar tertaut. Setiap objek komit memiliki penunjuk ke objek komit induk. Dari komit yang diberikan, Anda dapat melintasi kembali dengan melihat penunjuk induk untuk melihat riwayat komit. Jika komit memiliki beberapa komit induk, maka komit khusus itu telah dibuat dengan menggabungkan dua cabang.
Ranting
Cabang digunakan untuk membuat jalur pengembangan lain. Secara default, Git memiliki cabang master, yang sama dengan trunk di Subversion. Biasanya, cabang dibuat untuk mengerjakan fitur baru. Setelah fitur selesai, itu digabungkan kembali dengan cabang master dan kami menghapus cabang tersebut. Setiap cabang direferensikan oleh HEAD, yang menunjuk ke komit terbaru di cabang tersebut. Setiap kali Anda membuat komit, HEAD diperbarui dengan komit terbaru.
Tag
Tag memberikan nama yang bermakna dengan versi tertentu di repositori. Tag sangat mirip dengan cabang, tetapi perbedaannya adalah bahwa tag tidak dapat diubah. Artinya, tag adalah cabang, yang tidak ingin diubah oleh siapa pun. Setelah tag dibuat untuk komit tertentu, bahkan jika Anda membuat komit baru, itu tidak akan diperbarui. Biasanya, pengembang membuat tag untuk rilis produk.
Klon
Operasi klon membuat instance dari repositori. Operasi klon tidak hanya memeriksa copy pekerjaan, tetapi juga mencerminkan repositori lengkap. Pengguna dapat melakukan banyak operasi dengan repositori lokal ini. Satu-satunya saat jaringan terlibat adalah saat instance repositori sedang disinkronkan.
Tarik
Operasi pull menyalin perubahan dari instance repositori jarak jauh ke yang lokal. Operasi tarik digunakan untuk sinkronisasi antara dua instance repositori. Ini sama dengan operasi pembaruan di Subversion.
Dorong
Operasi push menyalin perubahan dari instance repositori lokal ke yang jauh. Ini digunakan untuk menyimpan perubahan secara permanen ke dalam repositori Git. Ini sama dengan operasi komit di Subversion.
KEPALA
HEAD adalah penunjuk, yang selalu menunjuk ke komit terbaru di cabang. Setiap kali Anda membuat komit, HEAD diperbarui dengan komit terbaru. Kepala cabang disimpan di.git/refs/heads/ direktori.
[CentOS]$ ls -1 .git/refs/heads/
master
[CentOS]$ cat .git/refs/heads/master
570837e7d58fa4bccd86cb575d884502188b0c49
Revisi
Revisi mewakili versi kode sumber. Revisi di Git diwakili oleh komit. Komit ini diidentifikasi olehSHA1 hash aman.
URL
URL mewakili lokasi repositori Git. Git URL disimpan dalam file config.
[tom@CentOS tom_repo]$ pwd
/home/tom/tom_repo
[tom@CentOS tom_repo]$ cat .git/config
[core]
repositoryformatversion = 0
filemode = true
bare = false
logallrefupdates = true
[remote "origin"]
url = [email protected]:project.git
fetch = +refs/heads/*:refs/remotes/origin/*