<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="cs">
	<id>http://postgres.cz/index.php?action=history&amp;feed=atom&amp;title=Iterace_p%C5%99es_v%C5%A1echny_datab%C3%A1ze_na_v%C3%ADce_serverech</id>
	<title>Iterace přes všechny databáze na více serverech - Historie editací</title>
	<link rel="self" type="application/atom+xml" href="http://postgres.cz/index.php?action=history&amp;feed=atom&amp;title=Iterace_p%C5%99es_v%C5%A1echny_datab%C3%A1ze_na_v%C3%ADce_serverech"/>
	<link rel="alternate" type="text/html" href="http://postgres.cz/index.php?title=Iterace_p%C5%99es_v%C5%A1echny_datab%C3%A1ze_na_v%C3%ADce_serverech&amp;action=history"/>
	<updated>2026-05-12T22:45:40Z</updated>
	<subtitle>Historie editací této stránky</subtitle>
	<generator>MediaWiki 1.43.3</generator>
	<entry>
		<id>http://postgres.cz/index.php?title=Iterace_p%C5%99es_v%C5%A1echny_datab%C3%A1ze_na_v%C3%ADce_serverech&amp;diff=558&amp;oldid=prev</id>
		<title>imported&gt;Pavel: Založena nová stránka s textem „Cílem je identifikovat podezřelé databáze, která v určitém sloupečku učité tabulky obsahují pouze několik málo hodnot. Problémem je množstv…“</title>
		<link rel="alternate" type="text/html" href="http://postgres.cz/index.php?title=Iterace_p%C5%99es_v%C5%A1echny_datab%C3%A1ze_na_v%C3%ADce_serverech&amp;diff=558&amp;oldid=prev"/>
		<updated>2014-08-22T10:33:53Z</updated>

		<summary type="html">&lt;p&gt;Založena nová stránka s textem „Cílem je identifikovat podezřelé databáze, která v určitém sloupečku učité tabulky obsahují pouze několik málo hodnot. Problémem je množstv…“&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Nová stránka&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Cílem je identifikovat podezřelé databáze, která v určitém sloupečku učité tabulky obsahují pouze několik málo hodnot. Problémem je množství databází (s různými schématy) a množství databázových serverů.&lt;br /&gt;
&lt;br /&gt;
Kombinací bashe, ssh a psql lze poměrně jednoduše takovou úlohu provést.&lt;br /&gt;
&lt;br /&gt;
Nejdříve potřebujeme skript, který chceme spustit na každém serveru:&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
su - postgres -c &amp;#039;&lt;br /&gt;
for db in `psql -At -c &amp;quot;select datname from pg_database where not datistemplate and datallowconn limit 1000&amp;quot; postgres`;&lt;br /&gt;
do&lt;br /&gt;
  echo $db;&lt;br /&gt;
  psql -At -c  &amp;quot;select current_database(), \$_\$ALERT\$_\$ from pg_stats where attname = \$_\$foo_id\$_\$ and tablename like \$_\$bar%\$_\$ and n_distinct between 0 and 10&amp;quot; $db;&lt;br /&gt;
  psql -At -c  &amp;quot;select current_database(), \$_\$OK\$_\$ from pg_stats where attname = \$_\$foo_id\$_\$ and tablename like \$_\$bar%\$_\$ and NOT n_distinct between 0 and 10&amp;quot; $db;&lt;br /&gt;
done&amp;#039;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Dále potřebuje distribuční skript - skript se pustí na pozadí, vzdálená execuce se pustí paralelně:&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
for i in dbserver{21..26}; do echo $i; ( ssh -T -o StrictHostKeyChecking=no root@$i &amp;lt; check_pg_cluster.sh &amp;amp; )  ; done &amp;gt; log &amp;amp;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;/div&gt;</summary>
		<author><name>imported&gt;Pavel</name></author>
	</entry>
</feed>