abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
dnes 21:32 | Nasazení Linuxu

Canonical představuje nejnovější verzi chytré helmy DAQRI s Ubuntu pro rozšířenou realitu. K vidění bude příští týden v Barceloně na veletrhu Mobile World Congress 2017.

Ladislav Hagara | Komentářů: 0
dnes 21:31 | Pozvánky

Pro zájemce o hlubší znalosti fungování operačních systémů připravila MFF UK nový předmět Pokročilé operační systémy, v rámci něhož se vystřídají přednášející nejen z řad pracovníků fakulty, ale dorazí také odborníci ze společností AVAST, Oracle, Red Hat a SUSE. Tento předmět volně navazuje na kurz Operační systémy ze zimního semestru, ale pokud máte praktické zkušenosti odjinud (například z přispívání do jádra Linuxu) a chcete si

… více »
Martin Děcký | Komentářů: 0
dnes 21:30 | Pozvánky

Czech JBoss User Group Vás srdečně zve na setkání JBUG v Brně, které se koná ve středu 1. března 2017 v prostorách Fakulty Informatiky Masarykovy Univerzity v místnosti A318 od 18:00. Přednáší Tomáš Remeš a Matěj Novotný na téma CDI 2.0 - New and Noteworthy. Více informací na Facebooku a na Twitteru #jbugcz.

mjedlick | Komentářů: 0
včera 23:45 | Zajímavý software

Na blogu Qt bylo představeno Qt 3D Studio. Jedná se o produkt dosud známý pod názvem NVIDIA DRIVE™ Design Studio. NVIDIA jej věnovala Qt. Jedná se o několik set tisíc řádků zdrojového kódu. Qt 3D Studio bude stejně jako Qt k dispozici jak pod open source, tak pod komerční licencí. Ukázka práce s Qt 3D Studiem na YouTube.

Ladislav Hagara | Komentářů: 8
včera 17:50 | Komunita

Nadace The Document Foundation (TDF) zastřešující vývoj svobodného kancelářského balíku LibreOffice slaví 5 let od svého oficiálního vzniku. Nadace byla představena 28. září 2010. Formálně byla založena ale až 17. února 2012.

Ladislav Hagara | Komentářů: 0
včera 12:50 | Komunita

Mozilla.cz informuje, že dosud experimentální funkce Page Shot z programu Firefox Test Pilot (zprávička) se stane součástí Firefoxu. Page Shot je nástroj pro vytváření snímků webových stránek. Umí výběr oblasti, prvku stránky (např. odstavce), nebo uložení snímku celé stránky. Snímky lze ukládat na disk nebo nahrávat na server Mozilly. Nedávno bylo oznámeno, že se součástí Firefoxu stane Activity Stream.

Ladislav Hagara | Komentářů: 29
včera 04:10 | Nová verze

Po 10 týdnech vývoje od vydání Linuxu 4.9 (zprávička) oznámil Linus Torvalds, mj. již 20 let žijící v USA, vydání Linuxu 4.10 (LKML). Přehled nových vlastností a vylepšení například na Kernel Newbies a v Jaderných novinách (1, 2 a 3). Kódové jméno Linuxu 4.10 je Fearless Coyote.

Ladislav Hagara | Komentářů: 19
19.2. 15:55 | Zajímavý projekt

Vyzkoušet si příkazy a vyřešit několik úkolů lze na stránkách Commandline Challenge (CMD Challenge). Úkoly lze řešit různými způsoby, důležitý je výsledek. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT.

Ladislav Hagara | Komentářů: 18
18.2. 17:35 | Bezpečnostní upozornění

Německá Bundesnetzagentur (obdoba českého ČTU) zakázala na německém území prodej panenky Cayla kvůli „špionáži“ dětí. Tato elektronická hračka obsahuje mikrofon, reproduktor a kameru a bezdrátové komunikační rozhraní, pomocí kterého se hračka připojuje na servery výrobce. Takovýmto způsobem může hračka pomocí umělé inteligence „odpovídat“ na dotazy dítěte. Hlavní problém bude ale asi někde jinde, podle prvotních zpráv může

… více »
Petr Tomášek | Komentářů: 34
17.2. 15:30 | Bezpečnostní upozornění

CSIRT.CZ upozorňuje, že bezpečnostní experti objevili nový typ malwaru, jenž cílí na open source e-commerce platformu Magento. Malware je zajímavý tím, že se jedná o první svého druhu, jehož kód zůstává skrytý v SQL databázi zasaženého e-shopu. Škodlivý kód je volán pomocí tzv. SQL trigerru, který je spouštěn při každém vytvoření objednávky v systému.

Ladislav Hagara | Komentářů: 5
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (13%)
 (2%)
 (72%)
 (3%)
 (10%)
Celkem 677 hlasů
 Komentářů: 61, poslední dnes 13:06
Rozcestník

Dotaz: mazani starych db v postgresql

23.6.2016 13:14 masi | skóre: 4
mazani starych db v postgresql
Přečteno: 1327×
Zdravim,

mam runner testu z gitlabu, kde se hromadi POSTGRE databaze a hledam jak to promazavat pravidelne. S mysql je to snadne, ale u postgre me napada jedine prez find prohledat adresar, kde jsou data a vse starsi treba tyden hledat prez jmena adresaru v indexu v postgre, abych to sparoval a mohl pak korektne prez pgdrop zahazovat.

Napada nekoho spravnejsi zpusob?

Jsou to jen testovaci data a v zasade db vytvorena vic nez 3d zpet nemaji smysl, ale zas bych nerad smazal treba systemove databaze a delat find na fs, pak se dotazovat v db na jmeno db podle indexu a nasledne to mazal mi prijde zbytecne slozite a vypocetne neefektivni, zvlast kdyz je tam ted par stovek db

Predem diky za tipy.

Řešení dotazu:


Odpovědi

Heron avatar 23.6.2016 16:39 Heron | skóre: 50 | blog: root_at_heron | Olomouc
Rozbalit Rozbalit vše Re: mazani starych db v postgresql
Seznam db získáte přímo klientem psql -l, případně (a to pro vás bude asi vhodnější), přímo SQL dotazem: SELECT datname FROM pg_database;

Heron avatar 23.6.2016 16:42 Heron | skóre: 50 | blog: root_at_heron | Olomouc
Rozbalit Rozbalit vše Re: mazani starych db v postgresql
Pokud máte ty testovací DB vhodně pojmenované, tak si pomocí SQL dotazu můžete vylistovat přesně ty, které chcete smazat:
SELECT datname FROM pg_database WHERE datistemplate = false AND datname LIKE 'test%';
23.6.2016 19:55 masi | skóre: 4
Rozbalit Rozbalit vše Re: mazani starych db v postgresql
diky. Nicmene tohle neni zdaleka ono. Obe varianty znam a neresi muj problem... Poskladal jsem neco jako:

SELECT (pg_stat_file('base/'||oid ||'/PG_VERSION')).modification as modify, datname FROM pg_database WHERE datname LIKE '%_%' AND modify < NOW() - INTERVAL '7 days';

ale nefunguje to. A navic nevim jak to pak poskladat do "drop database $ten_vysledek". Ten dotaz vyse funguje jen do doby nez tam dam tu pasaz 'AND modify < NOW() - INTERVAL '7 days''. Nejde to zrejme proto, ze ve chvili kdy se dela where se nejmenuje ten sloupec modify, ale je to jen tip, protoze mi to rika, ze ten sloupec neexistuje. Cili by to mozna slo prez nejaky select into tmptable a pak nad tim select s where jako mam vyse a nakonec to dat drop database, ale porad to zkousim nalamat do jednoho dotazu ale me znalosti nestaci a nemuzu najit nic co bych pochopil a fungovalo by. Nepochybuji o tom, ze to poskladat jde, ale po hodine googleni a zkouseni, zacinam pochybovat, ze to poskladam ja :-) Uz zvazuju varianty jako select, grep, nebo nejaky pekny python a pak pgdrop $dbname :-)

Prosim nejakeho guru o pomoc, casto tu byval Pavel Stehule a psal neuveritelna zaklinadla.

Řešení 1× (Filip Jirsák)
24.6.2016 08:05 Filip Jirsák | skóre: 66 | blog: Fa & Bi
Rozbalit Rozbalit vše Re: mazani starych db v postgresql
Nejde to zrejme proto, ze ve chvili kdy se dela where se nejmenuje ten sloupec modify, ale je to jen tip, protoze mi to rika, ze ten sloupec neexistuje. Cili by to mozna slo prez nejaky select into tmptable
Úplně stačí ten výraz, který máte v SELECT, zkopírovat do WHERE místo modify. Je to duplicitní kód, ale to je holt SQL… (Navíc v té části SELECT to pak asi nebudete potřebovat.)
zkousim nalamat do jednoho dotazu
V PostgreSQL máte uložené procedury, je zbytečné to cpát do jednoho dotazu, když to nepotřebujete optimalizovat.
Řešení 1× (masi (tazatel))
24.6.2016 10:07 masi | skóre: 4
Rozbalit Rozbalit vše Re: mazani starych db v postgresql
Genialni!!!

moc diky za pomoc. Nize je finalni verze

SELECT datname FROM pg_database WHERE datname LIKE '%_%' AND (pg_stat_file('base/'||oid ||'/PG_VERSION')).modification < NOW() - INTERVAL '7 days';

Zkusim z toho udelat proceduru
xkucf03 avatar 18.8.2016 21:09 xkucf03 | skóre: 45 | blog: xkucf03
Rozbalit Rozbalit vše Re: mazani starych db v postgresql
Je to duplicitní kód, ale to je holt SQL…
Ani v SQL není potřeba duplikovat kód – stačí použít vnořený dotaz nebo CTE (WITH).
Mám rád, když se lidé přou, znamená to, že vědí, co dělají, a že mají směr. Frantovo.cz, SQL-Výuka.cz, Nekuřák.net
Řešení 1× (Filip Jirsák)
25.6.2016 06:50 Pavel Stěhule
Rozbalit Rozbalit vše Re: mazani starych db v postgresql
V Postgresu není alias na stejné úrovni viditelný. Tj.
SELECT vyraz AS y FROM foo WHERE y = 10; -- nelze
Lze duplikovat výraz (nicméně spočítá se pouze jednou):
SELECT vyraz AS y FROM foo WHERE vyraz = 10; -- vyraz se pocita pouze jednou
nebo použít derivovanou tabulku a přesunout predikát tam, vně už je alias viditelný:
SELECT * FROM (SELECT vyraz AS y) s WHERE y = 10;
4.7.2016 14:10 masi
Rozbalit Rozbalit vše Re: mazani starych db v postgresql
Ahoj,

jen abych to nejak zakoncil.

Nakonec jsem vyplodil toto:
CREATE OR REPLACE FUNCTION clean_all_dbs(IN _days_ago INT)
  RETURNS void
  LANGUAGE plpgsql
AS
$$
DECLARE
  db RECORD;
BEGIN
  FOR db IN 
    SELECT 
      datname,
      (pg_stat_file('base/'||oid ||'/PG_VERSION')).modification AS modify
    FROM 
      pg_database
    WHERE
      (pg_stat_file('base/'||oid ||'/PG_VERSION')).modification < NOW() - INTERVAL '14 days'
      AND datname LIKE '%\_%'
  LOOP
    EXECUTE 'DROP DATABASE IF EXISTS ' || quote_ident(db.datname);
    RAISE INFO 'Dropped database: %', quote_ident(db.datname);
  END LOOP;
END;
$$;
Neni tam doreseno jen predani kolik dni zpetne se ma mazat, ale jinak to "skoro" funguje. Jediny problem je "ERROR: DROP DATABASE cannot be executed from a function or multi-command string."

Po chvili googleni jsem se docetl, ze neni podporovano dropovani databazi ve funkcich a tak jsem to nakonec udelal shell scriptem na par radcich.

Ne ze bych workaround nenasel, ale byl to rakovy hnus, ze mi prislo lepsi to udelat scriptem nize
#!/bin/bash
#
# Simple postgre cleaning script
#
 
days_ago=${1?"First arg define how old databases may be deleted"}
DELDB="/tmp/pg_deleted_db-$(date +%F)"


# Generate databases list
psql -c "SELECT \
  datname, \
  (pg_stat_file('base/'||oid ||'/PG_VERSION')).modification AS modify \
FROM \
  pg_database \
WHERE \
  (pg_stat_file('base/'||oid ||'/PG_VERSION')).modification < NOW() - INTERVAL '"${days_ago}" days\' \
  AND datname LIKE '%\_%';" | grep '_' > ${DELDB}


# Main
echo "Deleting databases more than $days_ago old..."

while read -r dbname modify; do
  dropdb ${dbname} && echo "Database ${dbname} has been dropped because is last modified on ${modify}!"
done < ${DELDB}

Zrejme to neni usecase co by resilo mnoho lidi, ale mozna to nekomu usetri par hodin casu :-)

Založit nové vláknoNahoru

Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

ISSN 1214-1267   www.czech-server.cz
© 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.