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 05:11 | Komunita

    Dan Blanchard vydal knihovnu pro Python chardet v nové verzi 7.0.0. S novou verzí byla knihovna přelicencována z LGPL na MIT. Souhlasili s tím všichni přispěvatelé? Dan Blanchard souhlasy vůbec neřešil. Zaúkoloval umělou inteligenci (Claude), aby knihovnu zcela přepsala a výslovně jí nařídil, aby nepoužila žádný LGPL kód. Dan Blanchard tvrdí, že se jedná o clean room design. Protistrana argumentuje, že umělá inteligence byla trénována

    … více »
    Ladislav Hagara | Komentářů: 1
    včera 18:44 | Komunita

    Andy Nguyen si na svou herní konzoli PlayStation 5 (PS5) pomocí exploitu Byepervisor nainstaloval Linux (Ubuntu). V Linuxu si spustil Steam a PS5 tak proměnil v Steam Machine. Na PS5 může hrát hry, které jsou vydané pouze pro PC a jsou na Steamu [Tom's Hardware].

    Ladislav Hagara | Komentářů: 6
    včera 12:22 | Nová verze

    Správce sbírky fotografií digiKam byl vydán ve verzi 9.0.0. Jedná se o větší vydání provázené aktualizacemi knihoven. Mnoho dílčích změn se vedle oprav chyb týká uživatelského rozhraní, mj. editace metadat.

    |🇵🇸 | Komentářů: 1
    7.3. 13:55 | Nová verze

    Byla vydána verze 2026 distribuce programu pro počítačovou sazbu TeX s názvem TeX Live (Wikipedie). Přehled novinek v oficiální dokumentaci.

    Ladislav Hagara | Komentářů: 12
    6.3. 23:22 | Humor

    Jihokorejská Národní daňová služba (NTS) zabavila kryptoměnu Pre-retogeum (PRTG) v hodnotě 5,6 milionu dolarů. Pochlubila se v tiskové zprávě, do které vložila fotografii zabavených USB flash disků s kryptoměnovými peněženkami spolu se souvisejícími ručně napsanými mnemotechnickými obnovovacími frázemi. Krátce na to byla kryptoměna v hodnotě 4,8 milionu dolarů odcizena. O několik hodin ale vrácena, jelikož PRTG je extrémně nelikvidní, s denním objemem obchodování kolem 332 dolarů a zalistováním na jediné burze, MEXC [Bitcoin.com].

    Ladislav Hagara | Komentářů: 9
    6.3. 16:33 | Nová verze

    Komunita kolem Linuxu From Scratch (LFS) vydala nové verze knih s návody na instalaci vlastního linuxového systému ze zdrojových kódů Linux From Scratch 13.0 a Beyond Linux From Scratch 13.0. Pouze se systemd.

    Ladislav Hagara | Komentářů: 0
    6.3. 16:00 | Nová verze

    Byla vydána nová stabilní major verze 25.12 linuxové distribuce primárně určené pro routery a vestavěné systémy OpenWrt (Wikipedie). Jedná se o nástupce předchozí major verze 24.10. Přehled novinek v poznámkách k vydání. Podporováno je více než 2200 zařízení.

    Ladislav Hagara | Komentářů: 0
    6.3. 04:44 | Komunita

    Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za únor (YouTube). Odstraněn byl veškerý kód napsaný ve Swiftu. JavaScriptový engine LibJS byl reimplementován v Rustu.

    Ladislav Hagara | Komentářů: 4
    5.3. 21:11 | Nová verze

    Byla vydána verze 1.94.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example. Zveřejněny byly výsledky průzkumu mezi vývojáři v programovacím jazyce Rust: 2025 State of Rust Survey Results.

    Ladislav Hagara | Komentářů: 8
    5.3. 17:33 | Komunita

    Google zveřejnil seznam 185 organizací přijatých do letošního Google Summer of Code (GSoC). Dle plánu se zájemci přihlašují od 16. do 31. března. Vydělat si mohou od 750 do 6600 dolarů. V Česku a na Slovensku je to 900 dolarů za malý, 1800 dolarů za střední a 3600 dolarů za velký projekt. Další informace v často kladených otázkách (FAQ). K dispozici jsou také statistiky z minulých let.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (17%)
     (7%)
     (0%)
     (11%)
     (28%)
     (2%)
     (5%)
     (2%)
     (12%)
     (25%)
    Celkem 1033 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    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: 1652×
    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: 53 | 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: 53 | 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.

    24.6.2016 08:05 Filip Jirsák | skóre: 67 | 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: 50 | 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-DK, Relational pipes
    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.