Daha önceki yazılarımızda Go programlama diline giriş yapmış ve ardından Go programlama dili ile örnek bir Rest API yaratmıştık. Bu yazımızda ise uygulamaya PostgreSQL bağlantısı sağlayacağız ve projeyi Heroku üzerine deploy edeceğiz. Go ile Heroku PostgreSQL entegrasyonu, üretime hazır bir REST API’yi buluta taşımanın hızlı ve ücretsiz bir yoludur.
İçindekiler
Heroku üzerinde gerçekleştireceğimiz işlemlere geçmeden önce, deployment için gereken Godep paketini Go projemize ekliyoruz:
TERMINAL
go get -u github.com/tools/godep
Ardından proje ana dizininde aşağıdaki komutu çalıştırıyoruz:
godep save
Öncelikle heroku.com üzerinden ücretsiz hesap ediniyoruz.
Hesabımızı aktive ettikten sonra Heroku CLI’yi buradan indirip kuruyoruz.
CLI’yi indirdikten sonra sırasıyla şu komutları çalıştırıyoruz:
heroku login
heroku create proje-adi
Heroku.com’dan login olup baktığımızda uygulamamızı dashboard’da görebiliriz.
Hesabımızı ve uygulamamızı yarattıktan sonra sırasıyla aşağıdaki adımları izleyerek uygulamamızı Heroku’ya deploy ediyoruz:
git init git add . git commit -m "first commit" git push heroku master
git remote –v komutu ile heroku reposu ile bağlantının sağlanıp sağlanmadığını kontrol edebilirsiniz. Heroku reposu görünmüyorsa, heroku create proje-adi komutunun yanıtında dönen URL’yi aşağıdaki şekilde ekleyebilirsiniz:
git remote –v
git remote add heroku https://git.heroku.com/proje-adi.git
Uygulama başarıyla deploy edildiyse, PostgreSQL add-on’unu kullanarak veri tabanımızı yaratıyoruz:
heroku addons:create heroku-postgresql:hobby-dev
Bu komuttaki hobby-dev kısmı ücretsiz Postgres planının ismidir. Diğer planları görmek için Heroku dashboard’unuzda Resources → Add-ons kısmına giderek PostgreSQL’i arayabilirsiniz.
hobby-dev
Heroku PostgreSQL hakkında daha fazla bilgi almak için resmi dokümantasyona göz atabilirsiniz.
Uygulamamızı deploy ettik ve PostgreSQL add-onu aracılığıyla veri tabanımızı yarattık. Şimdi veri tabanı ile projemizi bağlayacağız. Bunun için Heroku dashboard’dan uygulamamıza tıklayarak Settings → Config Vars → Reveal Config Vars butonunu tıklıyoruz.
Butona tıkladığımızda PostgreSQL URL’imizi göreceğiz.
Eğer projenizi önceki yazımızdaki adımları takip ederek yaptıysanız, base.go dosyasında yer alan aşağıdaki yorum satırını bulun:
base.go
GO
// Eğer Heroku üzerinde bir PostgreSQL'e sahipseniz, bu ayarlamaları yapmak yerine doğrudan // heroku tarafından verilen database url'i kullanabilirsiniz
Yukarıdaki kodların üst kısmındaki db değişkenlerini kapatıp alttaki dbUri değişkenini açıyor ve buraya az önce aldığımız DATABASE_URL değerini giriyoruz.
db
dbUri
DATABASE_URL
Her şey yolunda gittiyse, go run main.go komutunu çalıştırdığımızda database bağlantımızın sağlandığını ve migration’larımızın çalıştığını gösteren aşağıdaki sonucu göreceksiniz.
go run main.go
Şimdi bir kullanıcı hesabı yaratarak test edebiliriz:
Ardından login’i deneyelim:
Go & PostgreSQL projesini Heroku üzerinde deploy etmek işte bu kadar hızlı ve kolay! Sorularınız olursa bizimle iletişime geçebilirsiniz.
Heroku’nun ücretsiz planı PostgreSQL için hala geçerli mi?
Heroku 2022 yılında ücretsiz planını kaldırdı. Eski hobby-dev planı artık mevcut değil. Alternatif olarak Railway, Render veya Fly.io gibi platformlar Go uygulamaları için ücretsiz veya düşük maliyetli PostgreSQL destekli deployment seçenekleri sunmaktadır.
Heroku’ya deploy sırasında “no web processes running” hatası neden alınır?
Bu hata genellikle projenin kök dizininde bir Procfile dosyası olmadığında ya da dosyanın yanlış yapılandırıldığında oluşur. Procfile içeriği şu şekilde olmalıdır: web: ./proje-adi. Ayrıca heroku ps:scale web=1 komutu çalıştırarak web dynamo’yu aktive edebilirsiniz.
Procfile
web: ./proje-adi
heroku ps:scale web=1
Godep yerine Go modules kullanılabilir mi?
Evet. Godep eski bir bağımlılık yönetim aracıdır; Go 1.11’den itibaren standart go mod sistemi kullanılabilir. Heroku Go buildpack da go modules’u desteklemektedir. go.mod ve go.sum dosyalarınız varsa Heroku bunları otomatik olarak tanır.
go mod
go.mod
go.sum
DATABASE_URL değeri nasıl güvenli şekilde kullanılır?
DATABASE_URL’yi asla kaynak koduna sabit olarak yazmayın. Heroku’da bu değer Config Vars üzerinden otomatik olarak ortam değişkeni olarak enjekte edilir. Kodunuzda os.Getenv("DATABASE_URL") ile bu değeri okuyabilirsiniz. Bu şekilde hem lokal hem de üretim ortamında güvenli çalışır.
os.Getenv("DATABASE_URL")
Heroku PostgreSQL — Resmi Dokümantasyon Heroku CLI — Kurulum Rehberi Go Programlama Diline Giriş — MDP Group Go Dili ile Restful API Geliştirme — MDP Group
Web & Mobil Geliştirme Takım Lideri
Neden SAP Integration Suite Kullanmalısınız?
Başarılı bir şirketin temeli olan entegrasyon, şirketler için en önemli stratejik önceliğe sahiptir. Bunun nedeni ise, şirketlerin sahip...
Go Programlama Diline Giriş
Go Nedir? Go, Google mühendisleri tarafından 2007 yılında geliştirilmeye başlanan, kendi tabirleri ile basit, güvenilir ve verimli uygulamalar...
SAP Signavio Nedir?
Kötü yönetilen iş süreçleri, şirketlerin kayıplara uğramasına, müşteri ve çalışan kaybetmesine neden olmaktadır. Bu sebeple,...
SAP Clean Core Nedir? Neden Özelleştirmelerinizi Azaltmanız Gerekiyor?
SAP Clean Core nedir, neden önemlidir? Özelleştirmelerinizi azaltmanın ve S/4HANA'yı sürdürülebilir tutmanın yolları. MDP Group uzman...
SAP GTS İşletmelere Ne Sunuyor?
Küresel ticaret, oldukça karmaşık bir süreçtir. Bu yüzden düzenleyici, her sipariş için doğru olanı uygulanması ve sevkiyatı gibi tüm...
SAP Spartacus Nedir? Commerce Cloud Storefront Kapsamlı Rehber
SAP Spartacus nedir? SAP Spartacus, SAP Commerce Cloud (eski adıyla SAP Hybris) için geliştirilmiş, açık kaynaklı Angular tabanlı bir...
2026 Yılında E-Fatura Sisteminin En Önemli 10 Faydası
E-fatura kullanımı, hem yasal zorunlulukların genişlemesi hem de işletmelerin verimlilik ve doğruluk beklentileri nedeniyle her geçen yıl...
SAP S/4HANA Nedir? Yeni Nesil ERP Rehberi
SAP S/4HANA nedir? SAP S/4HANA, şirketlerin işlemleri gerçekleştirmesine ve iş verilerini gerçek zamanlı olarak analiz etmesine olanak...
SAP CO Nedir? Controlling Modülü Hakkında Detaylı Rehber
SAP CO nedir? SAP CO (Controlling), finans ve maliyet ekiplerinin iç muhasebe süreçlerini yönetmesini sağlayan bir SAP ERP modülüdür. Modül...
Mailiniz başarıyla gönderilmiştir en kısa sürede sizinle iletişime geçilecektir.
Mesajınız ulaştırılamadı! Lütfen daha sonra tekrar deneyin.