SlideShare a Scribd company logo
PostgreSQLPostgreSQL
Neler Yapar?Neler Yapar?
#pgdaytr
DBADBA
PGDay İstanbul 2015 @PGDayTR
Boğaziçi Üniversitesi
Gülçin Yıldırım
Select * from me ;Select * from me ;
'nde
okudu, algoritmalar ve veri tabanları ile
orada tanıştı.
ile karşılaşana dek birçok
veri tabanı ile çalıştı ama artık pek
tercih etmiyor.
Açık kaynak kod ve özgür yazılım seven
bir DBA. Çok az şey biliyor ve çok şey
öğrenmek istiyor, şu an 'de
çalışıyor.
Twitter :
Blog :
YTÜ Matematik Mühendisliği
PostgreSQL
Markafoni
@apatheticmagpie
kadinyazilimci.com
Neden PostgreSQL ÇokNeden PostgreSQL Çok
Güzel?Güzel?
(Atomicity, Consistency, Isolation, Durability)
Hot Standby
Streaming replication
/
ACID
MVCC Multi Version Concurrency Control
WAL Write-Ahead Logging
Point-in-Time Recovery
Standby server and high availability
Procedural languages
Partitioning Inheritance
Cost based optimiser
Multi platform support
Tablespaces
Neden PostgreSQL ÇokNeden PostgreSQL Çok
Güzel?Güzel?
( / )
: check constraints, unique
constraints, foreign keys, primary keys...
: , , ...
: MongoDB, Hadoop, Redis , MySQL
Triggers
Functions
Views Materialized Updatable
Constraint enforcement
Extension system hstore pg_stat_statements pg_trgm
Temporary tables
Unlogged tables
Foreign Data Wrappers
Postgres Yönetmek Çok Kolay!Postgres Yönetmek Çok Kolay!
pgAdminpgAdmin
Postgres'in grafik arayüzüdür. Sorgu analiz etme, çalışan sorguları
gözlemleme özellikleri mevcuttur. Kullandığınız özelliklerin kodlarını
görebilir, değiştirebilir ve düzenleyebilirsiniz.
pgAdminpgAdmin
Terminal ve psqlTerminal ve psql
psql Postgres'in etkileşimli (interaktif) terminalidir.
Komutlar size çok hız kazandıracaktır.
psql -h 127.0.0.1 -U gulcin -d pgday
l ve l+
c
dt ve dt+
di ve di+
d ve d+
du
dp
df
db
x
q
?
Rutin DBA görevleriRutin DBA görevleri
PostgreSQL'i KurmakPostgreSQL'i Kurmak
LinuxLinux
MacMac
Şu EDB versiyonunu indirebilirsiniz.
WindowsWindows
Kurulum için şu yararlanabilirsiniz.
apt-get install postgresql
yum install postgresql
linkten
linkten
PostgreSQL'i AyarlamakPostgreSQL'i Ayarlamak
postgresql.confpostgresql.conf
pg_hba.confpg_hba.conf
recovery.confrecovery.conf
OS ConfigurationOS Configuration
Backup Logical&PhysicalBackup Logical&Physical
HA SetupHA Setup
MonitoringMonitoring
Log AnalyzingLog Analyzing
Bloat ManagementBloat Management
Anahtar GörevlerAnahtar Görevler
Yedekleme PolitikasıYedekleme Politikası
Tavsiye:Tavsiye: Backup and Recovery ManagerBackup and Recovery Manager
for PostgreSQLfor PostgreSQL
BarmanBarman
“ A good backup tool is not for keeping
backups, it's for keeping your job.
Simon Riggs
Optimizasyon YapmaOptimizasyon Yapma
System TuningSystem Tuning
OS TuningOS Tuning
Hardware TuningHardware Tuning
Performance TuningPerformance Tuning
Query TuningQuery Tuning
Index ManagementIndex Management
Software ConfigurationSoftware Configuration
Optimizasyon YapmaOptimizasyon Yapma
Tavsiye:Tavsiye: PostgreSQL Workload AnalyzerPostgreSQL Workload AnalyzerPoWAPoWA
Upgrade PlanlamaUpgrade Planlama
Versiyonlar arasındaki farkları listelemeVersiyonlar arasındaki farkları listeleme
Mevcut yapıya nasıl etkisi olacaMevcut yapıya nasıl etkisi olacağğını araını araşştırmatırma
Neler kazandıracaNeler kazandıracağğını hesaplama / öngörmeını hesaplama / öngörme
GeçiGeçişşi planlamai planlama
Kaynakları doKaynakları doğğru kullanmaru kullanma
Yenilikleri incelemeYenilikleri inceleme
pg_upgradepg_upgrade
SistemiSistemi İİzlemezleme
, , , gibi yazılımlarla veri tabanı
sunucularımızı ve veri tabanlarımızı kontrol edebilirsiniz.
Tavsiye: bir projesidir.​
check_postgres veri tabanımızın çeşitli özelliklerini izleyip kontrol
edebilmemize yarayan bir betiktir. Nagios gibi yazılımlarla veya
bağımsız betiklerle çalışabilecek şekilde tasarlanmıştır.
Nagios PRTG New Relic Cacti
check_postgres bucardo
Sistemi Analiz EtmeSistemi Analiz Etme
Logları toplayıp analiz edersek çok daha iyi anlamış oluruz. Bunun
için aşağıdaki araçları kullanabilirsiniz.
Log analiz etmek üzere tasarlanmış bu araçlar log incelemenizi ve
bunlardan yola çıkarak kararlar almanızı sağlayacaktır.
pg_fouine
pgbadger
pgCluu
Sistemi Analiz EtmeSistemi Analiz Etme
Postgres ve DBA HayatıPostgres ve DBA Hayatı
İşleri olabildiğince otomatize edin.
Bir yedekleme politikanız olsun.
Yedekleriniz güvenli ve kullanılabilir olsun.
Tablo ve dizin (index) boyutlarının artışını kontrol edin.
Uzun süren sorguları loglayın ve bu sorguları düzenli aralıklarla
iyileştirin.
Loglara düşen hataları inceleyin ve nasıl bir soruna işaret
ettiklerini anlamaya çalışın, araştırın.
Vacuum analyze, autovacuum, full vacuum işlerini planlayın.
Veri tabanı kilitleri hakkında fikir edinin ve nasıl izleyip kontrol
edeceğinizi bilin.
Postgres ve DBA HayatıPostgres ve DBA Hayatı
İşleri otomatize etmek için 'crontab' komutu çok faydalı olacaktır.
Yedekleme, vacuum yapma gibi rutinler her DBA'in hayatını kurtaran
faydalı alışkanlıklardır.
gulcin# crontab -l
00 02 * * * sh /home/postgres/scripts/getbackup.sh
0 05 * * * sh /home/postgres/scripts/restore_test_db.sh
#WAL Archive CleanUp
0 02 * * * sh /var/lib/pgsql/removewal_archive.sh
crontab -e // crontab dosyasını düzenlemeye yarar.
# * * * * * çalıştırılacak komut
# ! ! ! ! !
# " " " " "
# " " " " "
# " " " " #$$$$$ haftanın günü (0 - 7) (0'dan 6'ya Pazar'dan Cumartesi'ye demektir; 7 Pazar, 0
da Pazar.)
# " " " #$$$$$$$$$$ ay (1 - 12)
# " " #$$$$$$$$$$$$$$$ ayın günü (1 - 31)
# " #$$$$$$$$$$$$$$$$$$$$ saat (0 - 23)
# #$$$$$$$$$$$$$$$$$$$$$$$$$ dakika (0 - 59)
Git kullanın!Git kullanın!
çok güzel. ile hemen öğren.
apt-get install git // Debian tabanlı dağıtım Ubuntu gibi.
yum install git // RHEL
yum install git-core // Fedora vs.
Gitlab Demo
ssh-keygen -t rsa -C "yildirim.gulcin88@gmail.com"
cat ~/.ssh/id_rsa.pub
git config --global user.name "Gulcin Yildirim"
git config --global user.email "yildirim.gulcin88@gmail.com"
mkdir pgday
cd pgday
git init
touch README
git add README
git commit -m 'Welcome to PGDay İstanbul 2015!'
git remote add origin git@demo.gitlab.com:gitlab/pgday.git
git push -u origin master
Nereden BaNereden Başşlayayım?layayım?
Postgres kaydolun.
Günde 1 mail ile ne kadar çok şey öğrenebileceğinize inanamazsınız.
: PostgreSQL yönetimi
: Kullanıcılar için genel bir tartışma alanı
: Postgres ve ona bağlı servis duyuruları
: Postgres performansına ilişkin konular
blogunu takip edin.
( , , , , ,
, , , , )
mail listelerine
pgsql-admin
pgsql-general
psql-announce
psql-performance
Planet PostgreSQL
2ndQuadrant pgExperts VMware OmniTI EnterpriseDB
EndPoint credativ Cybertec CommandPrompt OpenSCG
Postgres ÖPostgres Öğğrenmenin ilkrenmenin ilk
yolu: Oku!yolu: Oku!
Karşılaştığınız her konsept için yazılmış
bulup okuyun.
Postgres belgeleme konusunda en zengin açık kaynak
kodlu projelerden biridir.
Çok sık kullandığınız özellikleri bile okuyun çünkü ufak bir
detay hayat kurtarıcı olabilir.
"Why do I love Postgres?
- Because I'm not a DBA.
PostgreSQL
belgesini
KaynaklarKaynaklar
PostgreSQL database administration volume I
PostgreSQL Internals Through Pictures
Best Practices for Becoming an Exceptional Postgres DBA
TeTeşşekkürler!ekkürler!
Soru var mı?Soru var mı?

More Related Content

What's hot

PostgreSQLのリカバリ超入門(もしくはWAL、CHECKPOINT、オンラインバックアップの仕組み)
PostgreSQLのリカバリ超入門(もしくはWAL、CHECKPOINT、オンラインバックアップの仕組み)PostgreSQLのリカバリ超入門(もしくはWAL、CHECKPOINT、オンラインバックアップの仕組み)
PostgreSQLのリカバリ超入門(もしくはWAL、CHECKPOINT、オンラインバックアップの仕組み)
Hironobu Suzuki
 
Log analytics with ELK stack
Log analytics with ELK stackLog analytics with ELK stack
Log analytics with ELK stack
AWS User Group Bengaluru
 
Introduction to PostgreSQL
Introduction to PostgreSQLIntroduction to PostgreSQL
Introduction to PostgreSQL
Joel Brewer
 
Postgresql
PostgresqlPostgresql
RDS Postgres and Aurora Postgres | AWS Public Sector Summit 2017
RDS Postgres and Aurora Postgres | AWS Public Sector Summit 2017RDS Postgres and Aurora Postgres | AWS Public Sector Summit 2017
RDS Postgres and Aurora Postgres | AWS Public Sector Summit 2017
Amazon Web Services
 
Inside vacuum - 第一回PostgreSQLプレ勉強会
Inside vacuum - 第一回PostgreSQLプレ勉強会Inside vacuum - 第一回PostgreSQLプレ勉強会
Inside vacuum - 第一回PostgreSQLプレ勉強会Masahiko Sawada
 
Migrating Apache Spark ML Jobs to Spark + Tensorflow on Kubeflow
Migrating Apache Spark ML Jobs to Spark + Tensorflow on KubeflowMigrating Apache Spark ML Jobs to Spark + Tensorflow on Kubeflow
Migrating Apache Spark ML Jobs to Spark + Tensorflow on Kubeflow
Databricks
 
Spark (Structured) Streaming vs. Kafka Streams
Spark (Structured) Streaming vs. Kafka StreamsSpark (Structured) Streaming vs. Kafka Streams
Spark (Structured) Streaming vs. Kafka Streams
Guido Schmutz
 
PostgreSQL Database Slides
PostgreSQL Database SlidesPostgreSQL Database Slides
PostgreSQL Database Slides
metsarin
 
統計情報のリセットによるautovacuumへの影響について(第39回PostgreSQLアンカンファレンス@オンライン 発表資料)
統計情報のリセットによるautovacuumへの影響について(第39回PostgreSQLアンカンファレンス@オンライン 発表資料)統計情報のリセットによるautovacuumへの影響について(第39回PostgreSQLアンカンファレンス@オンライン 発表資料)
統計情報のリセットによるautovacuumへの影響について(第39回PostgreSQLアンカンファレンス@オンライン 発表資料)
NTT DATA Technology & Innovation
 
分散DB Apache Kuduのアーキテクチャ DBの性能と一貫性を両立させる仕組み 「HybridTime」とは
分散DB Apache KuduのアーキテクチャDBの性能と一貫性を両立させる仕組み「HybridTime」とは分散DB Apache KuduのアーキテクチャDBの性能と一貫性を両立させる仕組み「HybridTime」とは
分散DB Apache Kuduのアーキテクチャ DBの性能と一貫性を両立させる仕組み 「HybridTime」とは
Cloudera Japan
 
PostgreSQL on Kubernetes: Realizing High Availability with PGO (Postgres Ibiz...
PostgreSQL on Kubernetes: Realizing High Availability with PGO (Postgres Ibiz...PostgreSQL on Kubernetes: Realizing High Availability with PGO (Postgres Ibiz...
PostgreSQL on Kubernetes: Realizing High Availability with PGO (Postgres Ibiz...
NTT DATA Technology & Innovation
 
XIDを周回させてみよう
XIDを周回させてみようXIDを周回させてみよう
XIDを周回させてみようAkio Ishida
 
Ilya Kosmodemiansky - An ultimate guide to upgrading your PostgreSQL installa...
Ilya Kosmodemiansky - An ultimate guide to upgrading your PostgreSQL installa...Ilya Kosmodemiansky - An ultimate guide to upgrading your PostgreSQL installa...
Ilya Kosmodemiansky - An ultimate guide to upgrading your PostgreSQL installa...
PostgreSQL-Consulting
 
PostgreSQL開発コミュニティに参加しよう!(PostgreSQL Conference Japan 2021 発表資料)
PostgreSQL開発コミュニティに参加しよう!(PostgreSQL Conference Japan 2021 発表資料)PostgreSQL開発コミュニティに参加しよう!(PostgreSQL Conference Japan 2021 発表資料)
PostgreSQL開発コミュニティに参加しよう!(PostgreSQL Conference Japan 2021 発表資料)
NTT DATA Technology & Innovation
 
Custom DevOps Monitoring System in MelOn (with InfluxDB + Telegraf + Grafana)
Custom DevOps Monitoring System in MelOn (with InfluxDB + Telegraf + Grafana)Custom DevOps Monitoring System in MelOn (with InfluxDB + Telegraf + Grafana)
Custom DevOps Monitoring System in MelOn (with InfluxDB + Telegraf + Grafana)
Seungmin Yu
 
PostgreSQL10徹底解説
PostgreSQL10徹底解説PostgreSQL10徹底解説
PostgreSQL10徹底解説
Masahiko Sawada
 
Amazon Aurora Deep Dive (db tech showcase 2016)
Amazon Aurora Deep Dive (db tech showcase 2016)Amazon Aurora Deep Dive (db tech showcase 2016)
Amazon Aurora Deep Dive (db tech showcase 2016)
Amazon Web Services Japan
 
MySQLとPostgreSQLと日本語全文検索 - Azure DatabaseでMroonga・PGroongaを使いたいですよね!?
MySQLとPostgreSQLと日本語全文検索 - Azure DatabaseでMroonga・PGroongaを使いたいですよね!?MySQLとPostgreSQLと日本語全文検索 - Azure DatabaseでMroonga・PGroongaを使いたいですよね!?
MySQLとPostgreSQLと日本語全文検索 - Azure DatabaseでMroonga・PGroongaを使いたいですよね!?
Kouhei Sutou
 
Distributed Databases Deconstructed: CockroachDB, TiDB and YugaByte DB
Distributed Databases Deconstructed: CockroachDB, TiDB and YugaByte DBDistributed Databases Deconstructed: CockroachDB, TiDB and YugaByte DB
Distributed Databases Deconstructed: CockroachDB, TiDB and YugaByte DB
YugabyteDB
 

What's hot (20)

PostgreSQLのリカバリ超入門(もしくはWAL、CHECKPOINT、オンラインバックアップの仕組み)
PostgreSQLのリカバリ超入門(もしくはWAL、CHECKPOINT、オンラインバックアップの仕組み)PostgreSQLのリカバリ超入門(もしくはWAL、CHECKPOINT、オンラインバックアップの仕組み)
PostgreSQLのリカバリ超入門(もしくはWAL、CHECKPOINT、オンラインバックアップの仕組み)
 
Log analytics with ELK stack
Log analytics with ELK stackLog analytics with ELK stack
Log analytics with ELK stack
 
Introduction to PostgreSQL
Introduction to PostgreSQLIntroduction to PostgreSQL
Introduction to PostgreSQL
 
Postgresql
PostgresqlPostgresql
Postgresql
 
RDS Postgres and Aurora Postgres | AWS Public Sector Summit 2017
RDS Postgres and Aurora Postgres | AWS Public Sector Summit 2017RDS Postgres and Aurora Postgres | AWS Public Sector Summit 2017
RDS Postgres and Aurora Postgres | AWS Public Sector Summit 2017
 
Inside vacuum - 第一回PostgreSQLプレ勉強会
Inside vacuum - 第一回PostgreSQLプレ勉強会Inside vacuum - 第一回PostgreSQLプレ勉強会
Inside vacuum - 第一回PostgreSQLプレ勉強会
 
Migrating Apache Spark ML Jobs to Spark + Tensorflow on Kubeflow
Migrating Apache Spark ML Jobs to Spark + Tensorflow on KubeflowMigrating Apache Spark ML Jobs to Spark + Tensorflow on Kubeflow
Migrating Apache Spark ML Jobs to Spark + Tensorflow on Kubeflow
 
Spark (Structured) Streaming vs. Kafka Streams
Spark (Structured) Streaming vs. Kafka StreamsSpark (Structured) Streaming vs. Kafka Streams
Spark (Structured) Streaming vs. Kafka Streams
 
PostgreSQL Database Slides
PostgreSQL Database SlidesPostgreSQL Database Slides
PostgreSQL Database Slides
 
統計情報のリセットによるautovacuumへの影響について(第39回PostgreSQLアンカンファレンス@オンライン 発表資料)
統計情報のリセットによるautovacuumへの影響について(第39回PostgreSQLアンカンファレンス@オンライン 発表資料)統計情報のリセットによるautovacuumへの影響について(第39回PostgreSQLアンカンファレンス@オンライン 発表資料)
統計情報のリセットによるautovacuumへの影響について(第39回PostgreSQLアンカンファレンス@オンライン 発表資料)
 
分散DB Apache Kuduのアーキテクチャ DBの性能と一貫性を両立させる仕組み 「HybridTime」とは
分散DB Apache KuduのアーキテクチャDBの性能と一貫性を両立させる仕組み「HybridTime」とは分散DB Apache KuduのアーキテクチャDBの性能と一貫性を両立させる仕組み「HybridTime」とは
分散DB Apache Kuduのアーキテクチャ DBの性能と一貫性を両立させる仕組み 「HybridTime」とは
 
PostgreSQL on Kubernetes: Realizing High Availability with PGO (Postgres Ibiz...
PostgreSQL on Kubernetes: Realizing High Availability with PGO (Postgres Ibiz...PostgreSQL on Kubernetes: Realizing High Availability with PGO (Postgres Ibiz...
PostgreSQL on Kubernetes: Realizing High Availability with PGO (Postgres Ibiz...
 
XIDを周回させてみよう
XIDを周回させてみようXIDを周回させてみよう
XIDを周回させてみよう
 
Ilya Kosmodemiansky - An ultimate guide to upgrading your PostgreSQL installa...
Ilya Kosmodemiansky - An ultimate guide to upgrading your PostgreSQL installa...Ilya Kosmodemiansky - An ultimate guide to upgrading your PostgreSQL installa...
Ilya Kosmodemiansky - An ultimate guide to upgrading your PostgreSQL installa...
 
PostgreSQL開発コミュニティに参加しよう!(PostgreSQL Conference Japan 2021 発表資料)
PostgreSQL開発コミュニティに参加しよう!(PostgreSQL Conference Japan 2021 発表資料)PostgreSQL開発コミュニティに参加しよう!(PostgreSQL Conference Japan 2021 発表資料)
PostgreSQL開発コミュニティに参加しよう!(PostgreSQL Conference Japan 2021 発表資料)
 
Custom DevOps Monitoring System in MelOn (with InfluxDB + Telegraf + Grafana)
Custom DevOps Monitoring System in MelOn (with InfluxDB + Telegraf + Grafana)Custom DevOps Monitoring System in MelOn (with InfluxDB + Telegraf + Grafana)
Custom DevOps Monitoring System in MelOn (with InfluxDB + Telegraf + Grafana)
 
PostgreSQL10徹底解説
PostgreSQL10徹底解説PostgreSQL10徹底解説
PostgreSQL10徹底解説
 
Amazon Aurora Deep Dive (db tech showcase 2016)
Amazon Aurora Deep Dive (db tech showcase 2016)Amazon Aurora Deep Dive (db tech showcase 2016)
Amazon Aurora Deep Dive (db tech showcase 2016)
 
MySQLとPostgreSQLと日本語全文検索 - Azure DatabaseでMroonga・PGroongaを使いたいですよね!?
MySQLとPostgreSQLと日本語全文検索 - Azure DatabaseでMroonga・PGroongaを使いたいですよね!?MySQLとPostgreSQLと日本語全文検索 - Azure DatabaseでMroonga・PGroongaを使いたいですよね!?
MySQLとPostgreSQLと日本語全文検索 - Azure DatabaseでMroonga・PGroongaを使いたいですよね!?
 
Distributed Databases Deconstructed: CockroachDB, TiDB and YugaByte DB
Distributed Databases Deconstructed: CockroachDB, TiDB and YugaByte DBDistributed Databases Deconstructed: CockroachDB, TiDB and YugaByte DB
Distributed Databases Deconstructed: CockroachDB, TiDB and YugaByte DB
 

Viewers also liked

Are you ready for the next attack? reviewing the sp security checklist (apnic...
Are you ready for the next attack? reviewing the sp security checklist (apnic...Are you ready for the next attack? reviewing the sp security checklist (apnic...
Are you ready for the next attack? reviewing the sp security checklist (apnic...
Barry Greene
 
Indusrty Strategy For Action
Indusrty Strategy For ActionIndusrty Strategy For Action
Indusrty Strategy For Action
Barry Greene
 
OpenDNS Enterprise Web Content Filtering
OpenDNS Enterprise Web Content FilteringOpenDNS Enterprise Web Content Filtering
OpenDNS Enterprise Web Content Filtering
OpenDNS
 
DNS for Developers - NDC Oslo 2016
DNS for Developers - NDC Oslo 2016DNS for Developers - NDC Oslo 2016
DNS for Developers - NDC Oslo 2016
Maarten Balliauw
 
Managing Postgres with Ansible
Managing Postgres with AnsibleManaging Postgres with Ansible
Managing Postgres with Ansible
Gulcin Yildirim Jelinek
 
Query-name Minimization and Authoritative Server Behavior
Query-name Minimization and Authoritative Server BehaviorQuery-name Minimization and Authoritative Server Behavior
Query-name Minimization and Authoritative Server Behavior
Shumon Huque
 
Remediating Violated Customers
Remediating Violated CustomersRemediating Violated Customers
Remediating Violated Customers
Barry Greene
 
I Have the Power(View)
I Have the Power(View)I Have the Power(View)
I Have the Power(View)
Will Schroeder
 
PostgreSQL Hem Güçlü Hem Güzel!
PostgreSQL Hem Güçlü Hem Güzel!PostgreSQL Hem Güçlü Hem Güzel!
PostgreSQL Hem Güçlü Hem Güzel!
Gulcin Yildirim Jelinek
 
Creating Domain Specific Languages in Python
Creating Domain Specific Languages in PythonCreating Domain Specific Languages in Python
Creating Domain Specific Languages in Python
Siddhi
 
DNS and Troubleshooting DNS issues in Linux
DNS and Troubleshooting DNS issues in LinuxDNS and Troubleshooting DNS issues in Linux
DNS and Troubleshooting DNS issues in Linux
Konkona Basu
 
TTÜ Geeky Weekly
TTÜ Geeky WeeklyTTÜ Geeky Weekly
TTÜ Geeky Weekly
Gulcin Yildirim Jelinek
 
IoT Security in Action - Boston Sept 2015
IoT Security in Action - Boston Sept 2015IoT Security in Action - Boston Sept 2015
IoT Security in Action - Boston Sept 2015
Eurotech
 
Hands-on getdns Tutorial
Hands-on getdns TutorialHands-on getdns Tutorial
Hands-on getdns Tutorial
Shumon Huque
 
BIND’s New Security Feature: DNSRPZ - the "DNS Firewall"
BIND’s New Security Feature: DNSRPZ - the "DNS Firewall"BIND’s New Security Feature: DNSRPZ - the "DNS Firewall"
BIND’s New Security Feature: DNSRPZ - the "DNS Firewall"
Barry Greene
 
A Designated ENUM DNS Zone Provisioning Architecture
A Designated ENUM DNS Zone Provisioning ArchitectureA Designated ENUM DNS Zone Provisioning Architecture
A Designated ENUM DNS Zone Provisioning Architecture
enumplatform
 
Approaches to application request throttling
Approaches to application request throttlingApproaches to application request throttling
Approaches to application request throttling
Maarten Balliauw
 
150928 - Verisign Public DNS
150928 - Verisign Public DNS150928 - Verisign Public DNS
150928 - Verisign Public DNSMichael Kaczmarek
 

Viewers also liked (20)

Network security
Network securityNetwork security
Network security
 
Are you ready for the next attack? reviewing the sp security checklist (apnic...
Are you ready for the next attack? reviewing the sp security checklist (apnic...Are you ready for the next attack? reviewing the sp security checklist (apnic...
Are you ready for the next attack? reviewing the sp security checklist (apnic...
 
Indusrty Strategy For Action
Indusrty Strategy For ActionIndusrty Strategy For Action
Indusrty Strategy For Action
 
OpenDNS Enterprise Web Content Filtering
OpenDNS Enterprise Web Content FilteringOpenDNS Enterprise Web Content Filtering
OpenDNS Enterprise Web Content Filtering
 
DNS for Developers - NDC Oslo 2016
DNS for Developers - NDC Oslo 2016DNS for Developers - NDC Oslo 2016
DNS for Developers - NDC Oslo 2016
 
Managing Postgres with Ansible
Managing Postgres with AnsibleManaging Postgres with Ansible
Managing Postgres with Ansible
 
Query-name Minimization and Authoritative Server Behavior
Query-name Minimization and Authoritative Server BehaviorQuery-name Minimization and Authoritative Server Behavior
Query-name Minimization and Authoritative Server Behavior
 
Remediating Violated Customers
Remediating Violated CustomersRemediating Violated Customers
Remediating Violated Customers
 
I Have the Power(View)
I Have the Power(View)I Have the Power(View)
I Have the Power(View)
 
PostgreSQL Hem Güçlü Hem Güzel!
PostgreSQL Hem Güçlü Hem Güzel!PostgreSQL Hem Güçlü Hem Güzel!
PostgreSQL Hem Güçlü Hem Güzel!
 
Creating Domain Specific Languages in Python
Creating Domain Specific Languages in PythonCreating Domain Specific Languages in Python
Creating Domain Specific Languages in Python
 
DNS and Troubleshooting DNS issues in Linux
DNS and Troubleshooting DNS issues in LinuxDNS and Troubleshooting DNS issues in Linux
DNS and Troubleshooting DNS issues in Linux
 
TTÜ Geeky Weekly
TTÜ Geeky WeeklyTTÜ Geeky Weekly
TTÜ Geeky Weekly
 
IoT Security in Action - Boston Sept 2015
IoT Security in Action - Boston Sept 2015IoT Security in Action - Boston Sept 2015
IoT Security in Action - Boston Sept 2015
 
Hands-on getdns Tutorial
Hands-on getdns TutorialHands-on getdns Tutorial
Hands-on getdns Tutorial
 
BIND’s New Security Feature: DNSRPZ - the "DNS Firewall"
BIND’s New Security Feature: DNSRPZ - the "DNS Firewall"BIND’s New Security Feature: DNSRPZ - the "DNS Firewall"
BIND’s New Security Feature: DNSRPZ - the "DNS Firewall"
 
A Designated ENUM DNS Zone Provisioning Architecture
A Designated ENUM DNS Zone Provisioning ArchitectureA Designated ENUM DNS Zone Provisioning Architecture
A Designated ENUM DNS Zone Provisioning Architecture
 
Approaches to application request throttling
Approaches to application request throttlingApproaches to application request throttling
Approaches to application request throttling
 
150928 - Verisign Public DNS
150928 - Verisign Public DNS150928 - Verisign Public DNS
150928 - Verisign Public DNS
 
IDNOG - 2014
IDNOG - 2014IDNOG - 2014
IDNOG - 2014
 

Similar to PostgreSQL DBA Neler Yapar?

VERİTABANI SIZMA TESTLERİ
VERİTABANI SIZMA TESTLERİVERİTABANI SIZMA TESTLERİ
VERİTABANI SIZMA TESTLERİ
BGA Cyber Security
 
Javascript Performance Optimisation
Javascript Performance OptimisationJavascript Performance Optimisation
Javascript Performance Optimisation
irfandurmus
 
Gradle ile Proje Insası
Gradle ile Proje InsasıGradle ile Proje Insası
Gradle ile Proje Insası
Ömer ÖZKAN
 
MongoDB ve C# Driver'ı
MongoDB ve C# Driver'ıMongoDB ve C# Driver'ı
MongoDB ve C# Driver'ı
Serdar Buyuktemiz
 
Karabük Üniversitesi Programlama Günleri - PostgreSQL Sunumu
Karabük Üniversitesi Programlama Günleri - PostgreSQL SunumuKarabük Üniversitesi Programlama Günleri - PostgreSQL Sunumu
Karabük Üniversitesi Programlama Günleri - PostgreSQL Sunumu
atifceylan
 
PostgreSQL'i öğrenmek ve yönetmek
PostgreSQL'i öğrenmek ve yönetmekPostgreSQL'i öğrenmek ve yönetmek
PostgreSQL'i öğrenmek ve yönetmek
Gulcin Yildirim Jelinek
 
Sunucularımızı Gözleyelim
Sunucularımızı GözleyelimSunucularımızı Gözleyelim
Sunucularımızı Gözleyelim
Oguz Yarimtepe
 
Weblogic performance tips&tricks
Weblogic performance tips&tricksWeblogic performance tips&tricks
Weblogic performance tips&tricks
Zekeriya Besiroglu
 
DBA ve Geliştiriciler İçin Başarımı Artırıcı Öneriler - PostgreSQL Konferansı...
DBA ve Geliştiriciler İçin Başarımı Artırıcı Öneriler - PostgreSQL Konferansı...DBA ve Geliştiriciler İçin Başarımı Artırıcı Öneriler - PostgreSQL Konferansı...
DBA ve Geliştiriciler İçin Başarımı Artırıcı Öneriler - PostgreSQL Konferansı...
atifceylan
 
Pig ve Hive ile Hadoop üzerinde Veri Analizi
Pig ve Hive ile Hadoop üzerinde Veri AnaliziPig ve Hive ile Hadoop üzerinde Veri Analizi
Pig ve Hive ile Hadoop üzerinde Veri Analizi
Hakan Ilter
 
Selenium
SeleniumSelenium
Selenium
Osman Yuksel
 
Jenkins
JenkinsJenkins
Jenkins
Osman Yuksel
 
Web Uygulamalarında Kaynak Kod Analizi - 1
Web Uygulamalarında Kaynak Kod Analizi - 1Web Uygulamalarında Kaynak Kod Analizi - 1
Web Uygulamalarında Kaynak Kod Analizi - 1Mehmet Ince
 
PAROLA KIRMA SALDIRILARI
PAROLA KIRMA SALDIRILARIPAROLA KIRMA SALDIRILARI
PAROLA KIRMA SALDIRILARI
BGA Cyber Security
 
Abapgit kurulum kullanım
Abapgit kurulum kullanımAbapgit kurulum kullanım
Abapgit kurulum kullanım
EliflknurNACAR
 
İleri Seviye T-SQL Programlama - Chapter 09
İleri Seviye T-SQL Programlama - Chapter 09İleri Seviye T-SQL Programlama - Chapter 09
İleri Seviye T-SQL Programlama - Chapter 09
Cihan Özhan
 
Visual Studio Developer Tools
Visual Studio Developer ToolsVisual Studio Developer Tools
Visual Studio Developer Tools
Uğur Tılıkoğlu
 

Similar to PostgreSQL DBA Neler Yapar? (20)

VERİTABANI SIZMA TESTLERİ
VERİTABANI SIZMA TESTLERİVERİTABANI SIZMA TESTLERİ
VERİTABANI SIZMA TESTLERİ
 
Javascript Performance Optimisation
Javascript Performance OptimisationJavascript Performance Optimisation
Javascript Performance Optimisation
 
Gradle ile Proje Insası
Gradle ile Proje InsasıGradle ile Proje Insası
Gradle ile Proje Insası
 
MongoDB ve C# Driver'ı
MongoDB ve C# Driver'ıMongoDB ve C# Driver'ı
MongoDB ve C# Driver'ı
 
Karabük Üniversitesi Programlama Günleri - PostgreSQL Sunumu
Karabük Üniversitesi Programlama Günleri - PostgreSQL SunumuKarabük Üniversitesi Programlama Günleri - PostgreSQL Sunumu
Karabük Üniversitesi Programlama Günleri - PostgreSQL Sunumu
 
Php refactoring
Php refactoringPhp refactoring
Php refactoring
 
PostgreSQL'i öğrenmek ve yönetmek
PostgreSQL'i öğrenmek ve yönetmekPostgreSQL'i öğrenmek ve yönetmek
PostgreSQL'i öğrenmek ve yönetmek
 
Sunucularımızı Gözleyelim
Sunucularımızı GözleyelimSunucularımızı Gözleyelim
Sunucularımızı Gözleyelim
 
Weblogic performance tips&tricks
Weblogic performance tips&tricksWeblogic performance tips&tricks
Weblogic performance tips&tricks
 
DBA ve Geliştiriciler İçin Başarımı Artırıcı Öneriler - PostgreSQL Konferansı...
DBA ve Geliştiriciler İçin Başarımı Artırıcı Öneriler - PostgreSQL Konferansı...DBA ve Geliştiriciler İçin Başarımı Artırıcı Öneriler - PostgreSQL Konferansı...
DBA ve Geliştiriciler İçin Başarımı Artırıcı Öneriler - PostgreSQL Konferansı...
 
Test Driven Development
Test Driven DevelopmentTest Driven Development
Test Driven Development
 
Pig ve Hive ile Hadoop üzerinde Veri Analizi
Pig ve Hive ile Hadoop üzerinde Veri AnaliziPig ve Hive ile Hadoop üzerinde Veri Analizi
Pig ve Hive ile Hadoop üzerinde Veri Analizi
 
Selenium
SeleniumSelenium
Selenium
 
Jenkins
JenkinsJenkins
Jenkins
 
Web Uygulamalarında Kaynak Kod Analizi - 1
Web Uygulamalarında Kaynak Kod Analizi - 1Web Uygulamalarında Kaynak Kod Analizi - 1
Web Uygulamalarında Kaynak Kod Analizi - 1
 
PAROLA KIRMA SALDIRILARI
PAROLA KIRMA SALDIRILARIPAROLA KIRMA SALDIRILARI
PAROLA KIRMA SALDIRILARI
 
Abapgit kurulum kullanım
Abapgit kurulum kullanımAbapgit kurulum kullanım
Abapgit kurulum kullanım
 
İleri Seviye T-SQL Programlama - Chapter 09
İleri Seviye T-SQL Programlama - Chapter 09İleri Seviye T-SQL Programlama - Chapter 09
İleri Seviye T-SQL Programlama - Chapter 09
 
Java 1
Java 1Java 1
Java 1
 
Visual Studio Developer Tools
Visual Studio Developer ToolsVisual Studio Developer Tools
Visual Studio Developer Tools
 

PostgreSQL DBA Neler Yapar?

  • 1. PostgreSQLPostgreSQL Neler Yapar?Neler Yapar? #pgdaytr DBADBA PGDay İstanbul 2015 @PGDayTR Boğaziçi Üniversitesi Gülçin Yıldırım
  • 2. Select * from me ;Select * from me ; 'nde okudu, algoritmalar ve veri tabanları ile orada tanıştı. ile karşılaşana dek birçok veri tabanı ile çalıştı ama artık pek tercih etmiyor. Açık kaynak kod ve özgür yazılım seven bir DBA. Çok az şey biliyor ve çok şey öğrenmek istiyor, şu an 'de çalışıyor. Twitter : Blog : YTÜ Matematik Mühendisliği PostgreSQL Markafoni @apatheticmagpie kadinyazilimci.com
  • 3. Neden PostgreSQL ÇokNeden PostgreSQL Çok Güzel?Güzel? (Atomicity, Consistency, Isolation, Durability) Hot Standby Streaming replication / ACID MVCC Multi Version Concurrency Control WAL Write-Ahead Logging Point-in-Time Recovery Standby server and high availability Procedural languages Partitioning Inheritance Cost based optimiser Multi platform support Tablespaces
  • 4. Neden PostgreSQL ÇokNeden PostgreSQL Çok Güzel?Güzel? ( / ) : check constraints, unique constraints, foreign keys, primary keys... : , , ... : MongoDB, Hadoop, Redis , MySQL Triggers Functions Views Materialized Updatable Constraint enforcement Extension system hstore pg_stat_statements pg_trgm Temporary tables Unlogged tables Foreign Data Wrappers
  • 5. Postgres Yönetmek Çok Kolay!Postgres Yönetmek Çok Kolay! pgAdminpgAdmin Postgres'in grafik arayüzüdür. Sorgu analiz etme, çalışan sorguları gözlemleme özellikleri mevcuttur. Kullandığınız özelliklerin kodlarını görebilir, değiştirebilir ve düzenleyebilirsiniz.
  • 7. Terminal ve psqlTerminal ve psql psql Postgres'in etkileşimli (interaktif) terminalidir. Komutlar size çok hız kazandıracaktır. psql -h 127.0.0.1 -U gulcin -d pgday l ve l+ c dt ve dt+ di ve di+ d ve d+ du dp df db x q ?
  • 8. Rutin DBA görevleriRutin DBA görevleri
  • 9. PostgreSQL'i KurmakPostgreSQL'i Kurmak LinuxLinux MacMac Şu EDB versiyonunu indirebilirsiniz. WindowsWindows Kurulum için şu yararlanabilirsiniz. apt-get install postgresql yum install postgresql linkten linkten
  • 11. OS ConfigurationOS Configuration Backup Logical&PhysicalBackup Logical&Physical HA SetupHA Setup MonitoringMonitoring Log AnalyzingLog Analyzing Bloat ManagementBloat Management Anahtar GörevlerAnahtar Görevler
  • 12. Yedekleme PolitikasıYedekleme Politikası Tavsiye:Tavsiye: Backup and Recovery ManagerBackup and Recovery Manager for PostgreSQLfor PostgreSQL BarmanBarman “ A good backup tool is not for keeping backups, it's for keeping your job. Simon Riggs
  • 13. Optimizasyon YapmaOptimizasyon Yapma System TuningSystem Tuning OS TuningOS Tuning Hardware TuningHardware Tuning Performance TuningPerformance Tuning Query TuningQuery Tuning Index ManagementIndex Management Software ConfigurationSoftware Configuration
  • 14. Optimizasyon YapmaOptimizasyon Yapma Tavsiye:Tavsiye: PostgreSQL Workload AnalyzerPostgreSQL Workload AnalyzerPoWAPoWA
  • 15. Upgrade PlanlamaUpgrade Planlama Versiyonlar arasındaki farkları listelemeVersiyonlar arasındaki farkları listeleme Mevcut yapıya nasıl etkisi olacaMevcut yapıya nasıl etkisi olacağğını araını araşştırmatırma Neler kazandıracaNeler kazandıracağğını hesaplama / öngörmeını hesaplama / öngörme GeçiGeçişşi planlamai planlama Kaynakları doKaynakları doğğru kullanmaru kullanma Yenilikleri incelemeYenilikleri inceleme pg_upgradepg_upgrade
  • 16. SistemiSistemi İİzlemezleme , , , gibi yazılımlarla veri tabanı sunucularımızı ve veri tabanlarımızı kontrol edebilirsiniz. Tavsiye: bir projesidir.​ check_postgres veri tabanımızın çeşitli özelliklerini izleyip kontrol edebilmemize yarayan bir betiktir. Nagios gibi yazılımlarla veya bağımsız betiklerle çalışabilecek şekilde tasarlanmıştır. Nagios PRTG New Relic Cacti check_postgres bucardo
  • 17. Sistemi Analiz EtmeSistemi Analiz Etme Logları toplayıp analiz edersek çok daha iyi anlamış oluruz. Bunun için aşağıdaki araçları kullanabilirsiniz. Log analiz etmek üzere tasarlanmış bu araçlar log incelemenizi ve bunlardan yola çıkarak kararlar almanızı sağlayacaktır. pg_fouine pgbadger pgCluu
  • 19. Postgres ve DBA HayatıPostgres ve DBA Hayatı İşleri olabildiğince otomatize edin. Bir yedekleme politikanız olsun. Yedekleriniz güvenli ve kullanılabilir olsun. Tablo ve dizin (index) boyutlarının artışını kontrol edin. Uzun süren sorguları loglayın ve bu sorguları düzenli aralıklarla iyileştirin. Loglara düşen hataları inceleyin ve nasıl bir soruna işaret ettiklerini anlamaya çalışın, araştırın. Vacuum analyze, autovacuum, full vacuum işlerini planlayın. Veri tabanı kilitleri hakkında fikir edinin ve nasıl izleyip kontrol edeceğinizi bilin.
  • 20. Postgres ve DBA HayatıPostgres ve DBA Hayatı İşleri otomatize etmek için 'crontab' komutu çok faydalı olacaktır. Yedekleme, vacuum yapma gibi rutinler her DBA'in hayatını kurtaran faydalı alışkanlıklardır. gulcin# crontab -l 00 02 * * * sh /home/postgres/scripts/getbackup.sh 0 05 * * * sh /home/postgres/scripts/restore_test_db.sh #WAL Archive CleanUp 0 02 * * * sh /var/lib/pgsql/removewal_archive.sh crontab -e // crontab dosyasını düzenlemeye yarar. # * * * * * çalıştırılacak komut # ! ! ! ! ! # " " " " " # " " " " " # " " " " #$$$$$ haftanın günü (0 - 7) (0'dan 6'ya Pazar'dan Cumartesi'ye demektir; 7 Pazar, 0 da Pazar.) # " " " #$$$$$$$$$$ ay (1 - 12) # " " #$$$$$$$$$$$$$$$ ayın günü (1 - 31) # " #$$$$$$$$$$$$$$$$$$$$ saat (0 - 23) # #$$$$$$$$$$$$$$$$$$$$$$$$$ dakika (0 - 59)
  • 21. Git kullanın!Git kullanın! çok güzel. ile hemen öğren. apt-get install git // Debian tabanlı dağıtım Ubuntu gibi. yum install git // RHEL yum install git-core // Fedora vs. Gitlab Demo ssh-keygen -t rsa -C "yildirim.gulcin88@gmail.com" cat ~/.ssh/id_rsa.pub git config --global user.name "Gulcin Yildirim" git config --global user.email "yildirim.gulcin88@gmail.com" mkdir pgday cd pgday git init touch README git add README git commit -m 'Welcome to PGDay İstanbul 2015!' git remote add origin git@demo.gitlab.com:gitlab/pgday.git git push -u origin master
  • 22. Nereden BaNereden Başşlayayım?layayım? Postgres kaydolun. Günde 1 mail ile ne kadar çok şey öğrenebileceğinize inanamazsınız. : PostgreSQL yönetimi : Kullanıcılar için genel bir tartışma alanı : Postgres ve ona bağlı servis duyuruları : Postgres performansına ilişkin konular blogunu takip edin. ( , , , , , , , , , ) mail listelerine pgsql-admin pgsql-general psql-announce psql-performance Planet PostgreSQL 2ndQuadrant pgExperts VMware OmniTI EnterpriseDB EndPoint credativ Cybertec CommandPrompt OpenSCG
  • 23. Postgres ÖPostgres Öğğrenmenin ilkrenmenin ilk yolu: Oku!yolu: Oku! Karşılaştığınız her konsept için yazılmış bulup okuyun. Postgres belgeleme konusunda en zengin açık kaynak kodlu projelerden biridir. Çok sık kullandığınız özellikleri bile okuyun çünkü ufak bir detay hayat kurtarıcı olabilir. "Why do I love Postgres? - Because I'm not a DBA. PostgreSQL belgesini
  • 24. KaynaklarKaynaklar PostgreSQL database administration volume I PostgreSQL Internals Through Pictures Best Practices for Becoming an Exceptional Postgres DBA