SlideShare une entreprise Scribd logo
1  sur  25
Télécharger pour lire hors ligne
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ı?

Contenu connexe

Tendances

왜 쿠버네티스는 systemd로 cgroup을 관리하려고 할까요
왜 쿠버네티스는 systemd로 cgroup을 관리하려고 할까요왜 쿠버네티스는 systemd로 cgroup을 관리하려고 할까요
왜 쿠버네티스는 systemd로 cgroup을 관리하려고 할까요Jo Hoon
 
Cache in API Gateway
Cache in API GatewayCache in API Gateway
Cache in API GatewayGilWon Oh
 
Json in Postgres - the Roadmap
 Json in Postgres - the Roadmap Json in Postgres - the Roadmap
Json in Postgres - the RoadmapEDB
 
Azure 仮想マシンにおける運用管理・高可用性設計のベストプラクティス
Azure 仮想マシンにおける運用管理・高可用性設計のベストプラクティスAzure 仮想マシンにおける運用管理・高可用性設計のベストプラクティス
Azure 仮想マシンにおける運用管理・高可用性設計のベストプラクティスYusuke Oi
 
Docker를 활용한 손쉬운 ECS 활용기 - 김민태 (AUSG) :: AWS Community Day Online 2021
Docker를 활용한 손쉬운 ECS 활용기 - 김민태 (AUSG) :: AWS Community Day Online 2021Docker를 활용한 손쉬운 ECS 활용기 - 김민태 (AUSG) :: AWS Community Day Online 2021
Docker를 활용한 손쉬운 ECS 활용기 - 김민태 (AUSG) :: AWS Community Day Online 2021AWSKRUG - AWS한국사용자모임
 
patroni-based citrus high availability environment deployment
patroni-based citrus high availability environment deploymentpatroni-based citrus high availability environment deployment
patroni-based citrus high availability environment deploymenthyeongchae lee
 
[오픈소스컨설팅] 프로메테우스 모니터링 살펴보고 구성하기
[오픈소스컨설팅] 프로메테우스 모니터링 살펴보고 구성하기[오픈소스컨설팅] 프로메테우스 모니터링 살펴보고 구성하기
[오픈소스컨설팅] 프로메테우스 모니터링 살펴보고 구성하기Ji-Woong Choi
 
(APP307) Leverage the Cloud with a Blue/Green Deployment Architecture | AWS r...
(APP307) Leverage the Cloud with a Blue/Green Deployment Architecture | AWS r...(APP307) Leverage the Cloud with a Blue/Green Deployment Architecture | AWS r...
(APP307) Leverage the Cloud with a Blue/Green Deployment Architecture | AWS r...Amazon Web Services
 
Event Streaming with Kafka Streams and Spring Cloud Stream | Soby Chacko, VMware
Event Streaming with Kafka Streams and Spring Cloud Stream | Soby Chacko, VMwareEvent Streaming with Kafka Streams and Spring Cloud Stream | Soby Chacko, VMware
Event Streaming with Kafka Streams and Spring Cloud Stream | Soby Chacko, VMwareHostedbyConfluent
 
MySQL 5.7が魅せる新しい運用の形
MySQL 5.7が魅せる新しい運用の形MySQL 5.7が魅せる新しい運用の形
MySQL 5.7が魅せる新しい運用の形yoku0825
 
ReadConcern and WriteConcern
ReadConcern and WriteConcernReadConcern and WriteConcern
ReadConcern and WriteConcernMongoDB
 
Building A CICD Pipeline for Deploying to Containers
Building A CICD Pipeline for Deploying to ContainersBuilding A CICD Pipeline for Deploying to Containers
Building A CICD Pipeline for Deploying to ContainersAmazon Web Services
 
[네이버오픈소스세미나] Maglev Hashing Scheduler in IPVS, Linux Kernel - 송인주
[네이버오픈소스세미나] Maglev Hashing Scheduler in IPVS, Linux Kernel - 송인주[네이버오픈소스세미나] Maglev Hashing Scheduler in IPVS, Linux Kernel - 송인주
[네이버오픈소스세미나] Maglev Hashing Scheduler in IPVS, Linux Kernel - 송인주NAVER Engineering
 
PostgreSQL and JDBC: striving for high performance
PostgreSQL and JDBC: striving for high performancePostgreSQL and JDBC: striving for high performance
PostgreSQL and JDBC: striving for high performanceVladimir Sitnikov
 
An Introduction To NoSQL & MongoDB
An Introduction To NoSQL & MongoDBAn Introduction To NoSQL & MongoDB
An Introduction To NoSQL & MongoDBLee Theobald
 
Learning how AWS implement AWS VPC CNI
Learning how AWS implement AWS VPC CNILearning how AWS implement AWS VPC CNI
Learning how AWS implement AWS VPC CNIHungWei Chiu
 
Visualize your data in Data Lake with AWS Athena and AWS Quicksight Hands-on ...
Visualize your data in Data Lake with AWS Athena and AWS Quicksight Hands-on ...Visualize your data in Data Lake with AWS Athena and AWS Quicksight Hands-on ...
Visualize your data in Data Lake with AWS Athena and AWS Quicksight Hands-on ...Amazon Web Services
 
Introduction to Docker
Introduction to DockerIntroduction to Docker
Introduction to DockerAditya Konarde
 
Concurrency Control in MongoDB 3.0
Concurrency Control in MongoDB 3.0Concurrency Control in MongoDB 3.0
Concurrency Control in MongoDB 3.0MongoDB
 

Tendances (20)

왜 쿠버네티스는 systemd로 cgroup을 관리하려고 할까요
왜 쿠버네티스는 systemd로 cgroup을 관리하려고 할까요왜 쿠버네티스는 systemd로 cgroup을 관리하려고 할까요
왜 쿠버네티스는 systemd로 cgroup을 관리하려고 할까요
 
Cache in API Gateway
Cache in API GatewayCache in API Gateway
Cache in API Gateway
 
Json in Postgres - the Roadmap
 Json in Postgres - the Roadmap Json in Postgres - the Roadmap
Json in Postgres - the Roadmap
 
Azure 仮想マシンにおける運用管理・高可用性設計のベストプラクティス
Azure 仮想マシンにおける運用管理・高可用性設計のベストプラクティスAzure 仮想マシンにおける運用管理・高可用性設計のベストプラクティス
Azure 仮想マシンにおける運用管理・高可用性設計のベストプラクティス
 
Docker를 활용한 손쉬운 ECS 활용기 - 김민태 (AUSG) :: AWS Community Day Online 2021
Docker를 활용한 손쉬운 ECS 활용기 - 김민태 (AUSG) :: AWS Community Day Online 2021Docker를 활용한 손쉬운 ECS 활용기 - 김민태 (AUSG) :: AWS Community Day Online 2021
Docker를 활용한 손쉬운 ECS 활용기 - 김민태 (AUSG) :: AWS Community Day Online 2021
 
patroni-based citrus high availability environment deployment
patroni-based citrus high availability environment deploymentpatroni-based citrus high availability environment deployment
patroni-based citrus high availability environment deployment
 
[오픈소스컨설팅] 프로메테우스 모니터링 살펴보고 구성하기
[오픈소스컨설팅] 프로메테우스 모니터링 살펴보고 구성하기[오픈소스컨설팅] 프로메테우스 모니터링 살펴보고 구성하기
[오픈소스컨설팅] 프로메테우스 모니터링 살펴보고 구성하기
 
(APP307) Leverage the Cloud with a Blue/Green Deployment Architecture | AWS r...
(APP307) Leverage the Cloud with a Blue/Green Deployment Architecture | AWS r...(APP307) Leverage the Cloud with a Blue/Green Deployment Architecture | AWS r...
(APP307) Leverage the Cloud with a Blue/Green Deployment Architecture | AWS r...
 
Event Streaming with Kafka Streams and Spring Cloud Stream | Soby Chacko, VMware
Event Streaming with Kafka Streams and Spring Cloud Stream | Soby Chacko, VMwareEvent Streaming with Kafka Streams and Spring Cloud Stream | Soby Chacko, VMware
Event Streaming with Kafka Streams and Spring Cloud Stream | Soby Chacko, VMware
 
MySQL 5.7が魅せる新しい運用の形
MySQL 5.7が魅せる新しい運用の形MySQL 5.7が魅せる新しい運用の形
MySQL 5.7が魅せる新しい運用の形
 
ReadConcern and WriteConcern
ReadConcern and WriteConcernReadConcern and WriteConcern
ReadConcern and WriteConcern
 
Building A CICD Pipeline for Deploying to Containers
Building A CICD Pipeline for Deploying to ContainersBuilding A CICD Pipeline for Deploying to Containers
Building A CICD Pipeline for Deploying to Containers
 
[네이버오픈소스세미나] Maglev Hashing Scheduler in IPVS, Linux Kernel - 송인주
[네이버오픈소스세미나] Maglev Hashing Scheduler in IPVS, Linux Kernel - 송인주[네이버오픈소스세미나] Maglev Hashing Scheduler in IPVS, Linux Kernel - 송인주
[네이버오픈소스세미나] Maglev Hashing Scheduler in IPVS, Linux Kernel - 송인주
 
PostgreSQL and JDBC: striving for high performance
PostgreSQL and JDBC: striving for high performancePostgreSQL and JDBC: striving for high performance
PostgreSQL and JDBC: striving for high performance
 
(ARC307) Infrastructure as Code
(ARC307) Infrastructure as Code(ARC307) Infrastructure as Code
(ARC307) Infrastructure as Code
 
An Introduction To NoSQL & MongoDB
An Introduction To NoSQL & MongoDBAn Introduction To NoSQL & MongoDB
An Introduction To NoSQL & MongoDB
 
Learning how AWS implement AWS VPC CNI
Learning how AWS implement AWS VPC CNILearning how AWS implement AWS VPC CNI
Learning how AWS implement AWS VPC CNI
 
Visualize your data in Data Lake with AWS Athena and AWS Quicksight Hands-on ...
Visualize your data in Data Lake with AWS Athena and AWS Quicksight Hands-on ...Visualize your data in Data Lake with AWS Athena and AWS Quicksight Hands-on ...
Visualize your data in Data Lake with AWS Athena and AWS Quicksight Hands-on ...
 
Introduction to Docker
Introduction to DockerIntroduction to Docker
Introduction to Docker
 
Concurrency Control in MongoDB 3.0
Concurrency Control in MongoDB 3.0Concurrency Control in MongoDB 3.0
Concurrency Control in MongoDB 3.0
 

En vedette

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 ActionBarry Greene
 
OpenDNS Enterprise Web Content Filtering
OpenDNS Enterprise Web Content FilteringOpenDNS Enterprise Web Content Filtering
OpenDNS Enterprise Web Content FilteringOpenDNS
 
DNS for Developers - NDC Oslo 2016
DNS for Developers - NDC Oslo 2016DNS for Developers - NDC Oslo 2016
DNS for Developers - NDC Oslo 2016Maarten Balliauw
 
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 BehaviorShumon Huque
 
Remediating Violated Customers
Remediating Violated CustomersRemediating Violated Customers
Remediating Violated CustomersBarry Greene
 
I Have the Power(View)
I Have the Power(View)I Have the Power(View)
I Have the Power(View)Will Schroeder
 
Creating Domain Specific Languages in Python
Creating Domain Specific Languages in PythonCreating Domain Specific Languages in Python
Creating Domain Specific Languages in PythonSiddhi
 
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 LinuxKonkona Basu
 
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 2015Eurotech
 
Hands-on getdns Tutorial
Hands-on getdns TutorialHands-on getdns Tutorial
Hands-on getdns TutorialShumon 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 Architectureenumplatform
 
Approaches to application request throttling
Approaches to application request throttlingApproaches to application request throttling
Approaches to application request throttlingMaarten Balliauw
 
150928 - Verisign Public DNS
150928 - Verisign Public DNS150928 - Verisign Public DNS
150928 - Verisign Public DNSMichael Kaczmarek
 

En vedette (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
 

Similaire à PostgreSQL DBA Neler Yapar?

Javascript Performance Optimisation
Javascript Performance OptimisationJavascript Performance Optimisation
Javascript Performance Optimisationirfandurmus
 
Gradle ile Proje Insası
Gradle ile Proje InsasıGradle ile Proje Insası
Gradle ile Proje InsasıÖmer ÖZKAN
 
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 Sunumuatifceylan
 
Sunucularımızı Gözleyelim
Sunucularımızı GözleyelimSunucularımızı Gözleyelim
Sunucularımızı GözleyelimOguz Yarimtepe
 
Weblogic performance tips&tricks
Weblogic performance tips&tricksWeblogic performance tips&tricks
Weblogic performance tips&tricksZekeriya 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 AnaliziHakan Ilter
 
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
 
Abapgit kurulum kullanım
Abapgit kurulum kullanımAbapgit kurulum kullanım
Abapgit kurulum kullanımEliflknurNACAR
 
İ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 09Cihan Özhan
 
Test Driven Development
Test Driven Development Test Driven Development
Test Driven Development Nezir Yürekli
 

Similaire à 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
 
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
 
Test Driven Development
Test Driven Development Test Driven Development
Test Driven Development
 

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