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
AS2 ve AS4 EDI Protokolü Karşılaştırması
B2B entegrasyon dünyasında AS2 uzun yıllardır kullanılan standartlardan biri. Ancak özellikle e-fatura, e-irsaliye ve uluslararası B2B...
SAP e-Hesap Özeti Nedir? Banka Entegrasyonu Nasıl Çalışır?
SAP e-Hesap Özeti (EHO), şirketlerin tüm banka hesaplarına SAP üzerinden anlık erişim sağlamasına ve banka hareketlerinin otomatik olarak...
SAP Cloud Application Programming Model (SAP CAP) Nedir?
SAP Cloud Application Programming Model (CAP), SAP Business Technology'nin (SAP BTP) bulut ortamında modern iş uygulamaları geliştirmek için...
SAP FI Üzerinden e-Beyanname Süreçleri Nasıl Yönetilir?
GirişSAP FI üzerinden e-Beyanname yönetimi, Türkiye’de GİB uyumlu vergi beyannamelerinin otomatik hazırlanmasını, doğrulanmasını ve...
Integration Suite’de Cloud Connector ile SFTP Sunucusuna API Verisi Gönderme
Amaç: SAP Integration Suite’de, API verisini Cloud Connector aracılığı ile SFTP sunucusuna gönderen entegrasyonSFTP Sunucusu:Veriyi...
e-Fatura Birim Kodları Nelerdir?
e-Fatura birim kodları, e-fatura düzenleme sürecinde satılan mal veya hizmetin miktarını ve ölçü türünü standartlara uygun hale...
BRF+ Nedir ve Nasıl Kullanılır?
Günümüzün hızla değişien iş hayatında, şirketler için iş kurallarını esnek ve hızlı bir şekilde yönetmek büyük önem arz eder....
Fiori Geliştirme Seçenekleri: SAPUI5 vs Fiori Elements
Fiori uygulaması geliştirmek için doğru yöntemi seçmek, projenin maliyetini, süresini ve uzun vadeli bakım yükünü doğrudan etkiler....
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.