Skip to main content

PostgreSQL Veritabanı Üzerinden Mail Atılması (SQL İle)

Merhaba,

PostgreSQL'de veritabanı üzerinden mail atmak için bir kaç yol bulunuyor. Bu yollar açık kaynak kodlu araçları kullanmaktan geçiyor örneğin pgMail ya da bir fonksiyon içindeki bir python koduyla da yapabilirsiniz. Bunlar, kullanabileceğiniz yöntemlerden sadece ikisi.

Veritabanı üzerinden sadece SQL scripti kullanarak mail atılması için bir script hazırladım. Bu yazıda farklı bir araç tanıtmayacağım. Postgres'in kendi özelliğini kullanarak bu işlemi gerçekleştirmek için aşağıdaki adımları kullanmanız yeterli olacaktır. (Linux tarafında mail atılması için gereken kurulumlarınız hazırsa tabi)

Maili Postgres'in in-core özelliği olan COPY ifadesini kullanarak atacağız. COPY ifadesini kullanarak farklı kaynaklardaki verileri Postgres veritanabındaki tablolara yazabileceğimiz gibi, Postgres veritabanındaki bir tabloyu da sunucu üzerinde, postgres kullanıcısnın yetkisi dahilindeki dizinlere aktarmamız mümkün. COPY ile ilgili daha fazla bilgiye bu linkten ulaşabilirsiniz. 

Yazdığım scriptteki gibi COPY FROM PROGRAM komutu ile sunucu üzerindeki bir komutu çalıştırmamız mümkün. Burada yer alan PROGRAM komutunun peşine yazacağınız linux komutlarının sonucunu bir tabloya aktarır. Bu komutun sonucu ile tablonuzun yapısının uyması yeterli olacaktır.

Burada önemli nokta, sunucunuz üzerinde mail atılması için uygun kurulumları yapmanız gerekecek(mail, mutt .. gibi). Bu düzenlemelerin yapıldığını düşünerek ilerleyelim.

Öncelikle sunucu üzerinde mail komutunu kullanarak mail atma işlemini test ediyorum. Test sonrası bu komutu yukarıda bahsettiğim COPY komutuyla birlikte kullanacağım.

echo "Mailinizin body içeriğini buraya ekleyin...." | mail -s "Test Başlık" test@test.com

Sonraki adım, COPY FROM PROGRAM komutunun sonucunun files_log adındaki bir tabloya yazılacağını düşünerek tabloyu oluşturuyorum çünkü COPY FROM PROGRAM komutunu kullanırken tablo kullanmak zorundayız fakat tablonun yer kaplamasını da istemiyorsanız ya da herhangi bir tabloya ihtiyacım yok diyorsanız böyle bir durum için, permanent(kalıcı) tablo oluşturmak yerine temporary(geçici) tablo oluşturma yöntemini seçebilirsiniz. Aşağıdaki örnekte TEMPORARY tablo oluşturdum.

NOT: Temporary tabloların sadece o session için oluşturulduğunu, backend session'u bittiğinde o tablonun da silindiğini unutmayın!

CREATE TEMPORARY TABLE IF NOT EXISTS files_log(result_ text);

COPY komutunun kullanımı aşağıdaki gibi olmalı. 

COPY <table_name>(<column1>) FROM PROGRAM 'linux commands..';

Yukarıdaki yapıya uygun, mail atmak için linux üzerinde çalıştırdığım komutumu PROGRAM komutu sonrası tek tırnak içinde yazıyorum.

COPY files_log (result_) FROM PROGRAM 'echo "Mailinizin body içeriğini buraya ekleyin...." | mail -s "Test Başlık" test@test.com';

Yukarıdaki komutu çalıştırmanız sonrası mail kutunuzu kontrol etmeyi unutmayın.

Eğer bu komutları bir fonksiyon içinde birleştirmek istersek aşağıdaki gibi ilerleyebiliriz. Şimdi fonksiyonu oluşturalım. 

CREATE OR REPLACE FUNCTION public.send_mail_func()
 RETURNS text
 LANGUAGE plpgsql
AS $function$

BEGIN
  CREATE TEMP TABLE IF NOT EXISTS files_log(result_ text);

  COPY files_log (result_) FROM PROGRAM 'echo "Mailinizin body içeriğini buraya ekleyin...." | mail -s "Mailinizin Başlığını buraya ekleyin..." test@test.com';

  RETURN 'Açıklama... ';
END;
$function$;

Son olarak oluşturduğunuz fonksiyonu çalıştırın ve yeniden mail kutunuzu kontrol etmeyi unutmayın. 

SELECT send_mail_func();

Sevgiler,

Comments

Popular posts from this blog

PGConf Europe 2018 Güncesi 1

Merhaba, Diğer tüm veritabanları arasında en popüler açık kaynak kodlu veritabanı olan PostgreSQL, tüm yıl boyunca farklı ülkelerde bir çok konferansa sahiplik yapmaktadır. En bilinenleri PGDay ve PGConf'dur. Ayrıca her yıl 2 Şubatta Brüksel’de yapılan FOSDEM etkinliğinde de PostgreSQL konuşmalarının yapıldığı bir oturum mutlaka olmaktadır. PostgreSQL etkinlik detaylarına bu linkten ulaşabilirsiniz. Bu yıl ki PGConf Europe konferansı Lizbon'da yapıldı. Konferansla ilgili izlenimlerimi, yaptığım neredeyse 6 günlük yolculuğun en başından tüm detaylarıyla birlikte paylaşmak istiyorum. Yolculuğumuz sevgili Seda ile birlikte Atatürk Havalimanı’ndan sabah 07:30’da Lizbon’a direk uçuşla başladı.  Hava şahaneydi ve uçuşumuz konforlu geçti. Koltuğumuz cam kenarı ve uçağın kanadının hemen yanındaydı (benim favori koltuklarım 24, 25, 26, 27 ve 28. sıradakiler) ve biz 27. sıradaydık. Bol bol resim çektik bulutların üstündeyken ve uçak kanatlı olanlardan.  Lizbon’a vardığımı...

PostgreSQL High Availability - Patroni 2

Patroni kurulumuyla ilgili oldukça fazla kaynak bulunmakta fakat kurulum ve yönetimini beraber barındıran kaynağa denk gelmedim. Bu yazıda hem Patroni kurulumu hem de kurulum sonrası yönetimiyle alakalı detaylara ulaşabilirsiniz. PostgreSQL cluster'larının yönetimi için kullanılan Patroni ile ilgili temel bilgilerin yer aldığı Autofailover üzerine hazırladığım yazı serisine aşağıdaki linklerden erişebilirsiniz. PostgreSQL ve Autofailover PostgreSQL'de Autofailover ve Patroni 1 (Giriş) PostgreSQL'de Autofailover ve Patroni 2 (Kurulum, Konfigürasyon ve Yönetim) PostgreSQL'de Autofailover ve Patroni 3 (Mevcut PostgreSQL Cluster'inin Patroni'ye Geçirilmesi) Patroni, PostgreSQL veritabanlarının kurulumundan ve konfigürasyonundan sorumludur. Yani Patroni'yi kurduğumuz sunucular aynı zamanda Patroni ile kurulmuş PostgreSQL'leri barındıracak. Üç node'lu PostgreSQL ve üç node'lu ETCD cluster'larını oluşturacağım. Kuruluma önce üç no...

PostgreSQL High Availability - Patroni 1

Patroni, PostgreSQL HA (High Availability) Cluster yapısının kurulması ve yönetimi için kullanılan open source bir araçtır. Patroni, PostgreSQL Cluster’inin kurulumu (bootstrap), replikasyonunun kurulumu, PostgreSQL otomatik failover yapılması amacıyla kullanılır. Python ile yazılmıştır. Bir önceki yazıda PostgreSQL'de Autofailover araçlarının ne olduğu ve neden Autofailover'a gereksinim duyulduğu konusunda yazı paylaşmıştım. Yazıya buradan ulaşabilirsiniz. Patroni Kurulumu İçin Gereksinimler nedir? Patroni’nin tek başına kurulumu autofailover yapısını yapılandırmak için yeterli değildir. Patroni ile Autofailover yapısının kurulması için DCS (Distributed Configuration Store) araçlarından birine ihtiyaç vardır. Bunlardan bazıları; ETCD, Consul, ZooKeeper, Kubernetes. PostgreSQL üzerinde Autofailover araçlarından Patroni entegre edecekseniz DCS araçlarından birini kullanmanız gerekecek. DCS dediğimiz şey aslında Service Discovery araçlarından biri olduğundan bu iki tan...