User Tools

Site Tools


sysadmin:postgresql

This is an old revision of the document!


Basi di configurazione

  1. eseguire /usr/local/sbin/postgresql_shmall_shmmax.sh » /etc/sysctl.conf
  2. installare pgtune per un tuning grezzo di PostgreSQL sulla macchina
  3. eseguire pgtune -i /etc/postgresql/9.1/main/postgresql.conf | grep pgtune » /etc/postgresql/9.1/main/postgresql.conf
  4. abilitare i log su stderr seguendo la documentazione di pgbadger
  5. NOTA LOG: attualmente su befair2 i log sono in /var/lib/postgresql/9.1/main/pg_log/ vediamo come si comporta postgresql con rotazione e compressione

Performance

Query utili su indici e loro utilizzo

Ricerca indici doppi

Query “grezza” per noi

acs_service=# SELECT tablename,indexname,indexdef from pg_indexes WHERE schemaname='public';

Query appropriata da http://www.xzilla.net/blog/2008/Jul/Index-pruning-techniques.html

[1] select indrelid::regclass, array_accum(indexrelid::regclass) from pg_index group by indrelid, indkey having count(*) > 1; 

Nota: richiede di definire l'aggregato array_accum

Utilizzo degli indici

Utilizzo degli indici

  
  SELECT relid,schemaname,relname,idx_scan,idx_tup_read,idx_tup_fetch FROM pg_stat_all_indexes ORDER BY idx_scan desc;

Indici presenti

  SELECT * FROM pg_indexes;
  

Filtra solo quelli utilizzati almeno una volta

  
  SELECT * from pg_stat_all_indexes WHERE relname='table' AND idx_scan > 0 ;
  

Filtra solo quelli che sono stati efficaci almeno una volta

  SELECT * from pg_stat_all_indexes WHERE schemaname='public' AND (idx_tup_read > 0 OR idx_tup_fetch > 0);
  

Query più appropriata, eseguita su tutti gli schemi (da http://www.xzilla.net/blog/2008/Jul/Index-pruning-techniques.html)

  [2] select indexrelid::regclass as index, relid::regclass as table from pg_stat_user_indexes JOIN pg_index USING (indexrelid) where idx_scan = 0 and indisunique is false;

Ho modificato la query per trovare gli indici che sono stati efficaci almeno una volta:

  [3] select indexrelid::regclass as index, relid::regclass as table from pg_stat_user_indexes JOIN pg_index USING (indexrelid) where (idx_tup_read > 0 OR idx_tup_fetch > 0) and indisunique is false;

Invece questa la query per indici usati senza essere efficaci

  [4] select indexrelid::regclass as index, relid::regclass as table from pg_stat_user_indexes JOIN pg_index USING (indexrelid) where (idx_scan >0 and (idx_tup_read = 0 OR idx_tup_fetch = 0)) and indisunique is false;

Query per tabelle

Tabelle vuote (stima. Per una risposta esaustiva vedere http://stackoverflow.com/questions/2596670/how-do-you-find-the-row-count-for-all-your-tables-in-postgres)

  [5] SELECT schemaname,relname,n_live_tup FROM pg_stat_user_tables WHERE n_live_tup=0;

Esecuzione query al ...

  • [1] = … indici doppi
  • [2] = … indici non usati
  • [3] = … indici che sono stati efficaci
  • [4] = … indici usati ma non efficaci
  • [5] = … tabelle vuote

Query comode x debug

SELECT a.datname,
       c.relname,
       l.transactionid,
       l.mode,
       l.granted,
       a.usename,
       a.current_query, 
       a.query_start,
       age(now(), a.query_start) AS "age", 
       a.procpid 
  FROM  pg_stat_activity a
   JOIN pg_locks         l ON l.pid = a.procpid
   JOIN pg_class         c ON c.oid = l.relation
  WHERE mode='RowExclusiveLock' ORDER BY a.query_start;

Avvio manuale di postgres

se service postgresql start offre poca flessibilità usare

pg_ctlcluster 8.4 main start -- -w

o ancora più a basso livello, da utente postgres eseguire:

/usr/lib/postgresql/8.4/bin/pg_ctl start -D /var/lib/postgresql/8.4/main -w -o '-c config_file="/etc/postgresql/8.4/main/postgresql.conf"'
sysadmin/postgresql.1415180407.txt.gz · Last modified: 2014/11/05 09:40 by feroda