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
SAP Fiori Konseptler, Launchpad ve En İyi Uygulamalar
SAP Fiori, SAP sistemlerini kullanan şirketlerin çalışanlarına modern, sezgisel ve cihazdan bağımsız bir kullanıcı deneyimi sunmayı...
Express.js ve MongoDB ile Connection Pooling Nasıl Yapılır?
Express.js ve MongoDB ile connection pooling, birden fazla veri tabanına tek bir Node.js uygulaması üzerinden dinamik bağlantı sağlamayı...
SAP GTS ile Gümrük ve İhracat Süreçlerine Tam Uyum Nasıl Sağlanır?
Dünya ticareti artık sadece ürünleri bir ülkeden diğerine göndermekten ibaret değil. Gümrük mevzuatları, ticaret kısıtlamaları, serbest...
Sequelize ile Tablo İlişkileri Nasıl Yapılır?
Sequelize Nedir?Sequelize, NodeJs tabanlı bir ORM (Object-Relational Mapping) yazılımıdır. Veritabanı yapılarını Obje ve onun...
İlaç Takip Sistemi Nedir?
İlaç takip sistemi (İTS), bir ilacın üretim bandından hastaya ulaşıncaya kadar geçtiği tüm süreçleri takip ederek ilaç...
e-Ödeme Nedir? SAP e-Ödeme Çözümü Hakkında Bilmeniz Gerekenler
e-Ödeme, kurumsal ödeme süreçlerinin onay hiyerarşisi, banka transferi ve belge kaydı dahil tüm adımlarıyla elektronik ortamda...
Finans Departmanında Dijital Dönüşüm: SAP Çözümleri Rehberi
Finans departmanında dijital dönüşüm, muhasebe ve finans süreçlerinde insan kaynaklı hata riskini minimize ederken operasyonel hızı ve...
E-Müstahsil Makbuzu Nedir?
Teknoloji artık hayatımızın her alanında sık sık karşımıza çıkıyor. Her gün yaşanan teknolojik gelişmeler sonucunda eski usul...
SAP Business Technology Platform (SAP BTP) Özellikleri
SAP Business Technology Platformu, SAP bulut iş uygulamalarını geliştirmenize, özelleştirmenize olanak tanıyan açık bir platformdur.SAP BTP,...
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.