Reklam

Browsing Tag

git kullanım kılavuzu

Genel, Git/Github/Bitbucket

Git Kullanım Kılavuzu (Türkçe)

Git Nedir?

  • Proje geliştirirken, kodlarımızı bir klasörde yedekliyoruz. Ancak yedekler çoğaldıkça hem yedekler karışmaya başlıyor hem de alanımız azalıyor. Bu problemleri çözmeye yarayan yardımcı programlar var. Bunlar bizim çalışmalarımızın yedeğini bizim yerimize alarak hem yerden, zamandan hem de kargaşadan tasarruf etmemizi sağlıyor. Bu araçlara sürüm kontrol sistemleri ya da versiyon kontrol sistemleri deniyor.
  • Projemiz ya da herhangi bir klasör üzerinde yapılan değişiklikleri zamanları, kullanıcı bilgisi, versiyon numarası gibi bilgilerle birlikte tutuyorlar.
  • Projenin yayına çıkacak kısmının beklemesini istiyorsak ve üzerinde de bir şeyler denemek istiyorsak o zaman çalışan kopyamız belli bir dallanmayla (branching) ayrılarak diğer kopyalar üzerinde rahatça çalışmamız sağlanıyor.İstersek bu kopyayı çalışabilir durumdaki kopya ile birleştirebiliyoruz.
  • Grup halinde çalışmalarda herkesin yaptığı değişiklikleri görebiliyoruz.
  • Git dağıtık bir yapı kullanıyor.Diğer versiyon kontrol sistemleri merkezi bir yapı kullanırken ve bu yapıya sürekli bağlı olmak gerekirken git’te her kullanıcıda bütün bir kopya mevcuttur ve internet olmayan ortamlarda dahi proje geliştirilmeye devam edilebiliyor.
  • 1.Git gerçekten çok hızlı 2.Git kaynak depoları disk üzerinde çok az yer kaplıyor. 3.Git ile dallanma (branching) ve birleştirme(merging) işlemleri kolay ve hızlı 4.Git offline olarak kullanılabiliyor. 5.Git dağıtık (distributed) olduğu için her bir geliştiricinin makinesinde proje bütün geçmişi ile birlikte tutulabiliyor. İlk başta bunun işlemleri yavaşlattığı ve disk israfı olduğu düşünülebilir. Fakat git’in oldukça etkin algoritmalar kullanması sayesinde bu sorunlar hiç yaşanmıyor.

Git Kurulumu

Git kurulum paketi depoda mevcut.Oradan paketi kuruyoruz.

  • sudo apt-get install git-core

Paketi kurduktan sonra git yapılandırmasına geçiyoruz. (Bu kısmı isterseniz yapmazsınız.Ama buradaki isim ve mail bilgilerini vermediğiniz zaman proje üzerinde commit yaptığınızda, commit mesajlarınızda github kullanıcı adınız değil de commiti yaptığınız bilgisayarın kullanıcı adı görünüyor.)

  • git config - -global user.name “isim,soyisim”
  • git config – -global user.email “email adresi”

(*Bu ayarlar kurulumdan sonra da yapılabiliyor.)

Bilgisayarımız ve Github arasında güvenli bir bağlantı sağlayabilmek için ssh-key kullanmalıyız. Bunun için bilgisayarımızda ssh-key oluşturmamız gerek.Önce var olan bir key var mı diye bakalım.

  • cd ~/.ssh
  • ls # config id_rsa id_rsa.pub known_hosts

Daha önce oluşturulmuş bir key’imiz varsa onu silip yeni oluşturabiliriz.

  • mkdir key_backup
  • cp id_rsa*
  • rm id_rsa*

Yeni bir ssh key oluşturmak için :

  • ssh-keygen

Creates a new ssh key using the provided email

Generating public/private rsa key pair.

Enter file in which to save the key (/home/you/.ssh/id_rsa):

(Karşımıza yukarıdaki kısım geliyor ve onu enter ile geçiyoruz…)

  • Enter passphrase (empty for no passphrase): [Type a passphrase]
  • Enter same passphrase again: [Type passphrase again]

Burada ise bizden, ssh-key oluşturmak için(belli bir algoritma ile oluşturulur) anahtar bir kelime yazmamız isteniyor.

  • our identification has been saved in /home/you/.ssh/id_rsa.
  • Your public key has been saved in /home/you/.ssh/id_rsa.pub.
  • The key fingerprint is:
  • 01:0f:f4:3b:ca:85:d6:17:a1:7d:f0:68:9d:f0:a2:db [email protected] `

    Buna benzer bir ekran çıktısı aldıysak işlemi doğru tamamlamışız demektir.

  • Şimdi ~/.ssh/id_rsa.pub ‘ da oluşmuş olan ssh-key ‘imizi github’a eklememiz gerekli.
  • Github’ta Account settings’te sol taraftaki add ssh key bölümüne girip oraya ssh keyimizi ekliyoruz.

Sıra geldi github’taki projemizi bilgisayarımıza çekmeye. Git üç ağaç kolu şeklinde çalışıyor diyebiliriz.İlk kısım çalıştığımız dizin,ikinci kısım yereldeki depomuz,diğer kısım ise uzak depodur.Şimdi clone komutu ile uzaktaki projeyi çekeceğiz.


git clone uzak_sunucu_adresi

Git Kullanımı

Depoya Dosya Ekleme

Projemize ilk commit’i yapalım:

Öncelikle depoya eklemek istediğimiz veya daha önce eklenmiş,değişiklik yapılmış dosyayı index denilen git geçici alanına eklemeliyiz.


git add dosya_ismi


Şimdi bu dosyanın geçici alandan alınıp yerel depoya gönderilebilmesi için commit edilmesi gerekli.


git commit -m"commitin içeriğini anlatan mesajımız"


Böylece dosyamız yerel depoya atıldı.Ancak henüz uzak depoya ulaşmadı.Uzak depoya atabilmemiz için ise:


git push origin bulunduğumuz_branch_dalı


  • Bu komut ile beraber yaptığımız değişiklikler uzak depoya gönderilmiş oldu.
    • Bu şekilde proje arkadaşlarımızın yaptığı değişiklikleri kendi yerl depomuza çekmek için ise:

git pull


Dallar (Branches)

Git’te default olarak master dalı gelir.İstersek başka dallar oluşturabiliriz ve silebiliriz.

  • git branch yeni_dal_ismi (yeni dal oluşturmamızı sağlar.)
  • git checkout yeni_dal_ismi (o dala geçmemizi sağlar.)
  • git branch -D branch_adı (dalı siler.)

Birden fazla dalımız varken iki daldaki değişiklikleri birleştirmek için merge komutunu kullanıyoruz.

  • git merge dal_adı

Bu komut ile bulunduğumuz branch, burada ismini verdiğimiz branch ile birleşmiş oluyor. Merge işlemi iki farklı geliştirici ortak değşiklikleri commitlemiş ise çakışmalara yol açabilir.Buna dikkat etmek gerekir.

Dosya Silme

Commitlediğimiz bir dosyayı silmek için :


git rm dosya_adı git push origin bulunduğumuz_dal_ismi (bu adım yapılan her değişikliğin uzak depoya gönderilebilmesi için yapılmalıdır.)


Ancak bu komut ile dosya silinir.Dosyayı geri döndürmek mümkündür.Ve dosya silindikten sonra commit mesajları tutulmaya devam eder.Dosyayı geri döndürme ise dosyanın loglarının tutuluyor olması ile mümkündür.


git revert silinen_dosya_log_id


Son Kayıt İşlemini Değiştirmek

Eğer kaydı çok erken yapmışsanız, bazı dosyaları eklemeyi unutmuşsanız ya da kayıt mesajında hata yapmışsanız, sık rastlanan düzeltme işlemlerinden birini kullanabilirsiniz. Kaydı değiştirmek isterseniz, commit komutunu –amend seçeneğiyle çalıştırabilirsiniz:

$ git commit --amend

Bu komut, hazırlık alanındaki değişiklikleri alıp bunları kaydı değiştirmek için kullanır. Eğer son kaydınızdan beri hiçbir değişiklik yapmamışsanız o zaman kaydınızın bellek kopyası aynı kalacak ve değiştireceğiniz tek şey kayıt mesajı olacaktır.

Kayda Hazırlanmış Bir Dosyayı Hazırlık Alanından Kaldırmak

benchmarks.rb dosyasını bu öneriye uygun olarak hazırlık alanından kaldıralım:


$ git reset HEAD benchmarks.rb
  benchmarks.rb: locally modified
  $ git status
  # On branch master
  # Changes to be committed:
  # (use "git reset HEAD <file>..." to unstage)
  # modified: README.txt
  # Changed but not updated:
  # (use "git add <file>..." to update what will be committed)
  # (use "git checkout -- <file>..." to discard changes in working directory)
  # modified: benchmarks.rb

“benchmarks.rb” dosyası hazırlık alanından kaldırıldı ama hâlâ değişmiş olarak görünüyor.

Değişmiş Durumdaki Bir Dosyayı Değişmemiş Duruma Geri Getirmek


$ git checkout -- benchmarks.rb
 $ git status
 # On branch master
 # Changes to be committed:
 # (use "git reset HEAD <file>..." to unstage)
 # modified: README.txt

Gördüğünüz gibi değişiklikler çöpe atıldı. Bunun tehlikeli bir komut olduğunu aklınızdan çıkarmayın: o dosyaya yaptığınız bütün değişiklikler şimdi yok oldu.

Tüm Kayıttan Bir Dosyayı Kaldırma


> $ git filter-branch --tree-filter 'rm -f passwords.txt' HEAD
Rewrite 6b9b3cf04e7c5686a9cb838c3f36a8cb6a0fc2bd (21/21)
Ref 'refs/heads/master' was rewritten

“passwords.txt” adlı dosyayı tüm geçmişten kaldırmak için filter-branch seçeneği olan “–tree-filter” kullanılabilir.

Git’de Eski Sürüme Geri Dönme


> $git log
commit a867b4af366350be2e7c21b8de9cc6504678a61b`
Author: Me 
Date:   Thu Nov 4 18:59: 41 2010 -0400

commit 25eee4caef46ae64aa08e8ab3f988bc917ee1ce4
Author: Me 
Date:   Thu Nov 4 05:13: 39 2010 -0400

commit 0766c053c0ea2035e90f504928f8df3c9363b8bd
Author: Me 
Date:   Thu Nov 4 00:55:06 2010 -0400

commit 0d1d7fc32e5a947fbd92ee598033d85bfc445a50
Author: Me 
Date:   Wed Nov 3 23:56:08 2010 -0400

Bu çıktıları gördükten sonra biz “Nov 3” deki eski sürüme dönmek isteyelim. Yapmamız gereken adımlar şunlardır:

$ git checkout 0d1d7fc32

ya da eğer geri döndüğümüzde commit yapmak istiyorsak, oraya gidip yeni bir dal oluşturmamız gerekir ki bunun için gereken komut:

$ git checkout -b old-state 0d1d7fc32

Öte yandan, eğer o zamana kadar yaptığımız her şeyden kurtulmak istiyorsak iki olasılık vardır. Birincisi; eğer henüz commit yayınlamadıysak, sıfırlamak basitçe:

#Bu yerel değişiklikleri yok eder
#Saklamak isteyip commit yapmadığımız iş varsa yapmayınız
$ git reset --hard 0d1d7fc32
#Alternatif olarak işi saklı tutmak için
$ git stash
$ git reset --hard 0d1d7fc32
$ git stash pop
#Bu değişiklikleri kaydeder, o halde sıfırlandıktan sonraki parçayı yeniden uygular
#Eğer bir şeyler değiştiyse çakışmaları birleştirebilirsin.

Öte yandan, eğer çalışması yayımlandıysa, dalın sıfırlanmasını istemezsin. Bu durumda gerçekte de commit’i eski haline döndürebilirsin. Git ile, geri dönme işleminin (revert)çok özel bir anlamı vardır: bu durumu dengelemek için ters bir düzeltmeyle yeni bir commit oluşturun. Bu şekilde yeniden bir tarih yazmamış oluruz.

#3 tane geri dönüş commitini oluştururuz
$ git revert 0766c053 25eee4ca a867b4af

# geri dönüş commitlerinden birine geçiş yapmamızı sağlar
$ git checkout 0d1d7fc32

#en sonda da ne yaptığınızı en iyi şekilde açıklayan bir mesaj yazınız
$ git commit