Sayfa Reklamı

Browsing Tag

bitbucket

Git/Github/Bitbucket

Host Üzerinde Git Clone Uygulamak – 2

İlk yazımızda birçok arkadaşımız hata almış olabilir, o yazının devamı olarak bunu devam ettiriyorum. Bunda kesin çözüme ulaşmış olabiliyoruz. Eğer ki problemleriniz vs. olursa yorum olarak belirtiniz. Herhangi bir panel kullanıyorsanız eğer (Plesk, cPanel, DirectAdmin vs.) bitbucket yada github üzerinde bir repodan dosyalarınızı hostunuza direkt olarak aktarım yapmakta sıkıntı çekiyorsanız bu makalemde tam sizin sorunuza çözüm bulacağız. Öncelikle hostunuzdaki tüm dosyaları silin ve ardından SSH üzerinde hostunuzun bulduğu kısma gelin.

Yukarıdaki ilk komutumuzu uyguladığımızda boş bir .git dosyası açmış olduk ve içerisini şimdi dolduracağız. Ardından bitbucket yada github üzerinde bir repoya sahipseniz clone adresini kopyalayın sıradaki komutumuz için gerekli olacak.

Eğer ki ana branch master ise boş bırakınız. Yukarıdaki repo_url kısmına sizin SSH destekli reponuzun clone adresini yapıştrın ve enterlayın. Eğer bir hata çıkmaz ise, bir sonraki adımda repomuzda bulunan dosyaları çektireceğiz.

Yukarıdaki branch_name genel olarak master olur ama değiştirdiyseniz siz kendinizin adı ile değiştiriniz. Ve sitemizi kontrol ettiğimizde dosyalarımızın gelmiş olduğunu göreceksiniz.

Eğer uygulama işleminde sorunlarınız olursa lütfen yorum olarak yada mail atarak belirtiniz, müsait olduğum süre boyuncu cevaplamaya çalışacağım. 24-48 saat içerisinde kesin dönüş yapıyorum.

Git/Github/Bitbucket

OpenSSH Change a Passphrase With ssh-keygen command

Merhabalar,

 

Versiyonlama sistemlerinizi yaparken ssh-keygen isteyen github yada bitbucket hesabınızın önceden oluşturduğunuz bir ssh keyiniz var ise ve şifresini boş bırakmak istiyorsanız tabi bu herkese göre değişir ben autoupdate yaptığım için şifreyi boş bırakıyorum sizler şifre girebilirsiniz.

Değiştirmek için öncelikle şu dosyaya girelim;

cd ~/.ssh/

Daha sonra düzenlemek için yazacağımız kodu girelim;

ssh-keygen -f id_rsa -p

Yazıp enter’ladıktan sonra size öncelikle eski parolanızı soracaktır (eğer eski parolanız boş ise enterlayınız.) girip devam ediniz. Daha sonrasında yeni parolanızı yazıp tekrar yeni parolanızı onaylayıp işlemin tamamlanmış olduğunu göreceksiniz. Başarılı mesajınız ise aşağıdaki gibidir.

Your identification has been saved with the new passphrase.

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.

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:



“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



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



“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



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:

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:

Ö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:

Ö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.