Git (yazılım)
Git, yazılım geliştirme süreçlerinde kullanılan, hız odaklı, dağıtık çalışan bir sürüm kontrol ve kaynak kod yönetim sistemidir. İlk sürümü Linux çekirdeği'nin geliştirilmesinde kullanılmak üzere 2005 yılında bizzat Linus Torvalds tarafından tasarlanıp geliştirilmiş, son Eclipse kullanıcı topluluğu anketi verilerine göre 2013 yılı itibarıyla %30 pazar payına ulaşmıştır.[1]
Git dahili Grafiksel kullanıcı arayüzü ekran görüntüsü. | |
Geliştirici(ler) | Linus Torvalds, Junio Hamano |
---|---|
İlk yayınlanma | 7 Nisan 2005 |
Güncel sürüm | 2.27.0 / 1 Haziran 2020 |
Geliştirme durumu | Aktif olarak devam ediyor |
Programlama dili | C, Tcl, Perl |
Platform | Çapraz Platform |
Tür | Sürüm Kontrol Sistemi |
Lisans | GNU Genel Kamu Lisansı v2 |
Resmî sitesi | http://git-scm.com/ |
Kod deposu |
Git sürüm kontrol sistemini kullanan her bir çalışma dizini (proje), internet erişimi ya da merkezi bir depo olmaksızın tüm tarihçeyi tutan ve sürüm kontrol sisteminin tamamını içinde barındıran tam yetkili birer depodur. Ayni çalışma dizininin birçok depodan birindeki kopyasında yapılan değişiklikler diğerlerine güven temelli bir değerlendirmeyle kabul edilir; Güvenilmeyenden değişiklik alınmaz, o kendi ayrı sürümünü geliştirmeye devam eder.
Git'in şu anki yazılım bakıcılığını Junio Hamano üstlenmiş durumda. Git, GNU Genel Kamu Lisansı'nın 2. sürümüyle lisanslanmış bir özgür yazılımdır. 2.26.0 sürümünden itibaren Türkçe dil desteği sunmaktadır.
Tarihçe
Git'in ortaya çıkışı, çok sayıda Linux çekirdeği geliştiricisinin proje yönetimi için bir önceki sürüm kontrol sistemi olan BitKeeper'ı tercih etmesiyle başlamıştır. Andrew Tridgell, bir takım tersine-mühendislik yöntemleriyle BitKeeper protokolüne müdahalelerde bulunmuş, ancak BitKeeper'ın telif haklarını elinde bulunduran Larry McVoy, BitKeeper'ın ücretsiz kullanımını reddederek konuyu hukuki platforma taşıyınca BitKeeper'ın kullanımından vazgeçilmiş, böylece Git'in temelleri atılmıştır.[2]
O günlerde Linus Torvalds, BitKeeper uygulamasında olduğu gibi dağıtık çalışan bir sürüm kontrol sistemi istiyordu ancak piyasadaki mevcut özgür çözümlerin hiçbiri özellikle performans konusunda Torvalds'ın beklentilerini karşılamıyordu. Torvalds bu konuyu piyasadaki mevcut sürüm kontrol sistemlerini ele alarak örneklemişti; bir yamanın uygulanarak ilgili tüm veri yapılarının güncellenmesinin 30 saniye sürmesi ve tüm bu değişikliklerin ilgili diğer geliştiricilere iletilebilmesi için aynı işlemin 250 defa tekrarlanmasının Linux çekirdeğinin geliştirilmesi yönünde engel teşkil ettiğinin altını çiziyordu. Torvalds'ın hedefi bu süreyi üç saniyeye düşürmekti.[3]
Bunun dışında Torvalds'ın başka tasarım kriterleri de vardı:[4][5]
- Ne yapılmaması gerektiği konusunda CVS örneği ele alınmalı, şayet kararsız kalınırsa CVS'in sunuduğu çözümün tam tersini yapmalı.
- BitKeeper'a benzer, ağ üzerinde dağıtık çalışmaya izin veren bir iş akışını desteklemeli.
- Zararlı kodlar veya yanlış kullanım nedeniyle veri kaybını öneleyecek çok sıkı güvenlik yapıları bulunmalı.
Bu üç kriteri, Monotone dışında o gün piyasada varolan hiçbir sürüm kontrol sistemi yerine getiremiyordu, performans söz konusu olduğunda ise Monotone da eleniyordu. Böylece 2.6.12-rc2 sürümlü linux çekirdeğinin yayınlanmasının hemen ardından Torvalds, kendi sürüm kontrol sistemini yazmaya karar verdi.
Tasarım
Git tasarımında BitKeeper ve Monotone'dan esinlenilmiştir. Git, aslında Cogito veya StGIT gibi düşük seviyeli bir sürüm kontrol sistem motoru üzerine diğerleri tarafından arayüz yazılabilecek şekilde tasarlanmıştır. Ancak çekirdek git projesi doğrudan kullanılabilecek tam bir sürüm kontrol sistemi haline gelmiştir.
Kısaca Git kavramları ve işlemleri
Genellikle terminal konsolundan kumandalarla kullanılsa da temelinde git olan birçok grafik arayüzü de bulunmaktadır. En bilinenleri şunlardır: masaüstü uygulaması olarak Sourcetree, IDE içinde menü seçeneği olarak Visual Studio, IntelliJ IDEA, intranet web sitesi olarak Bitbucket, ve internet web sitesi olarak GitHub ve GitLab.
Git, dağıtık bir sürüm kontrol sistemidir. Herhangi bir klasör, init veya clone kumandaları ile bir git repository, yani bir git dosya deposu haline getirilebilir. Her git dosya deposunda .git isimli bir alt klasör vardır ve kullanıcının o klasörde ve alt klasörlerdeki dosyalarının yerel kopyaları ve daha eski versiyonları orada saklanır. Depodaki kararlı gövde kümeye master denir, bu kümeden geçici dal kümeler branch kumandası ile oluşturulabilir. Kullanıcı, geliştirmek istediği kümeyi geri getirip (checkout), dosyalar üzerinde değişiklikler yapıp, bunları o kümenin yeni bir sürümü şeklinde depolayarak çalışır (add ve peşinden commit). Üzerinde çalışılan kümeye head denir.
Git dosyalar arasında değişenleri ( modified denenler), otomatik algılayabilir. Gitin takip ettiği dosyalar vardır (tracked), hala sürüm kontrolü altında olmayan başka dosyalar vardır (untracked). Dosyalar ekleme komutu add ile takibe alınabilir, mv ile klasörler arasında taşınabilir, rm ile silinebilirler. Bazı dosyaları git'in umursamaması gerekir, bunların adları .gitignore dosyasına yazılır. Dosyalar add ile depolanmaya hazır gruba eklenir (staged), commit ile o andaki halleri açıklama mesajı ekli bir şekilde depolanır, degişiklikler save ve stash ile kenara konulup, daha sonra, belki başka kümede kullanılabilir (pop, drop, apply, clear), clean ile silinebiir. Klasörlerdeki metinler grep ile arattırılabilir.
Sürümler commit işlemi sırasında üretilmiş uzun hash sayısının ilk 6-7 rakamı ile tanınabilir. Dosyalardaki değişiklikler listelenebilir (status, log, reflog), görüntülenebilir (diff), vaz geçilebilir (undo), baştan alınabilir (reset), bir evvelki haline dönülebilir (revert), yazarı belirtilebilir (blame), her hangi bir dosyanın depodaki herhangi bir sürümü tekrar getirilebilir (checkout), belli kümelere isim verilebilir (tag).
Bu yerel kümeler arasında eşitleme gerçekleştirilebilir (merge, rebase). Bunlar bağımsız depolar arasında teslimat olarak kabul edilebilir. Uzaktaki ana (origin) depodaki kümelerle güncelleme / senkronizasyon gerçekleştirilebilir (fetch, remote add, pull, pull-request, push), ya da oradan gelen yama uygulanabilir (am).
Kaynakça
- "Haziran 2013 tarihli eclipse kullanıcı topluluğu anketi". Slideshare. Haziran 2013. 15 Kasım 2015 tarihinde kaynağından arşivlendi. Erişim tarihi: 1 Eylül 2013.
- "How Tridge reverse engineered BitKeeper (İngilizce)". 16 Ekim 2015 tarihinde kaynağından arşivlendi. Erişim tarihi: 1 Eylül 2013.
- "Linus Torvald'sın Kernel SCM saga başlıklı e-posta grubu tartışmasında yazdıkları (İngilizce)". Erişim tarihi: 1 Eylül 2013.
- "Linus Torvald'sın Git e-posta grubuna veri kaybı konusunda yazdıkları (İngilizce)". Erişim tarihi: 1 Eylül 2013.
- "Linus Torvald'sın Mayıs 2007 tarihli Google Tech Talk konuşması (İngilizce)". 23 Aralık 2015 tarihinde kaynağından arşivlendi. Erişim tarihi: 1 Eylül 2013.