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í
×
    včera 15:22 | IT novinky

    Eric Lengyel dobrovolně uvolnil jako volné dílo svůj patentovaný algoritmus Slug. Algoritmus vykresluje text a vektorovou grafiku na GPU přímo z dat Bézierových křivek, aniž by využíval texturové mapy obsahující jakékoli předem vypočítané nebo uložené obrázky a počítá přesné pokrytí pro ostré a škálovatelné zobrazení písma, referenční ukázka implementace v HLSL shaderech je na GitHubu. Slug je volným dílem od 17. března letošního

    … více »
    NUKE GAZA! 🎆 | Komentářů: 0
    včera 15:11 | Zajímavý projekt

    Sashiko (GitHub) je open source automatizovaný systém pro revizi kódu linuxového jádra. Monitoruje veřejné mailing listy a hodnotí navrhované změny pomocí umělé inteligence. Výpočetní zdroje a LLM tokeny poskytuje Google.

    Ladislav Hagara | Komentářů: 9
    včera 04:44 | Zajímavý software

    Cambalache, tj. RAD (rapid application development) nástroj pro GTK 4 a GTK 3, dospěl po pěti letech vývoje do verze 1.0. Instalovat jej lze i z Flathubu.

    Ladislav Hagara | Komentářů: 0
    20.3. 14:55 | Nová verze

    KiCad (Wikipedie), sada svobodných softwarových nástrojů pro počítačový návrh elektronických zařízení (EDA), byl vydán v nové major verzi 10.0.0 (𝕏). Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    20.3. 13:22 | IT novinky

    Letošní Turingovou cenu (2025 ACM A.M. Turing Award, Nobelova cena informatiky) získali Charles H. Bennett a Gilles Brassard za základní přínosy do oboru kvantové informatiky, které převrátily pojetí bezpečné neprolomitelné komunikace a výpočetní techniky. Jejich protokol BB84 z roku 1984 umožnil fyzikálně zaručený bezpečný přenos šifrovacích klíčů, zatímco jejich práce o kvantové teleportaci položila teoretické základy pro budoucí kvantový internet. Jejich práce spojila fyziku s informatikou a ovlivnila celou generaci vědců.

    Ladislav Hagara | Komentářů: 14
    20.3. 04:44 | Zajímavý článek

    Firefox 149 dostupný od 24. března přinese bezplatnou vestavěnou VPN s 50 GB přenesených dat měsíčně (s CZ a SK se zatím nepočítá) a zobrazení dvou webových stránek vedle sebe v jednom panelu (split view). Firefox Labs 149 umožní přidat poznámky k panelům (tab notes, videoukázka).

    Ladislav Hagara | Komentářů: 2
    20.3. 00:33 | Nová verze

    Byla vydána nová stabilní verze 7.9 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 146. Přehled novinek i s náhledy v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    20.3. 00:11 | Zajímavý software

    Dle plánu byla vydána Opera GX pro Linux. Ke stažení je .deb i .rpm. V plánu je flatpak. Opera GX je webový prohlížeč zaměřený na hráče počítačových her.

    Ladislav Hagara | Komentářů: 7
    19.3. 19:22 | Nová verze

    GNUnet (Wikipedie) byl vydán v nové major verzi 0.27.0. Jedná se o framework pro decentralizované peer-to-peer síťování, na kterém je postavena řada aplikací.

    Ladislav Hagara | Komentářů: 0
    19.3. 04:00 | Bezpečnostní upozornění

    Byly publikovány informace (technické detaily) o bezpečnostním problému Snapu. Jedná se o CVE-2026-3888. Neprivilegovaný lokální uživatel může s využitím snap-confine a systemd-tmpfiles získat práva roota.

    Ladislav Hagara | Komentářů: 4
    Které desktopové prostředí na Linuxu používáte?
     (15%)
     (7%)
     (1%)
     (12%)
     (29%)
     (2%)
     (5%)
     (1%)
     (13%)
     (24%)
    Celkem 1128 hlasů
     Komentářů: 27, poslední 17.3. 19:26
    Rozcestník

    Dotaz: Efektivní parsování logu

    13.9.2019 10:42 Jirka
    Efektivní parsování logu
    Přečteno: 652×
    Dobrý den.
    Hledám možnost, jakou bych efektivně mohl parsovat logy za nějaké konkrétní časové období.
    Existuje nějaký "jednoduchý" způsob, jak z logu vysypat všechno, např. ze dne 01.09.2019 v čase 09:00 - 10:15 ?

    Vzorový řádek z logu
    194.xxx.17x.yyy - - [13/Sep/2019:09:51:27 +0200] "GET /nejaky-obsah-bla-bla-bla/ HTTP/2.0" 301 275 "https://www.domena.cz/nejaky-obsah-bla-bla-bla" "Mozilla/5.0 (Linux; Android 6.0.1; Redmi 3S Build/MMB29M; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/76.0.3809.132 Mobile Safari/537.36 [FB_IAB/FB4A;FBAV/238.0.0.41.116;]"

    Děkuji.

    Odpovědi

    13.9.2019 11:17 Peter Golis | skóre: 65 | blog: Bežné záležitosti | Bratislava
    Rozbalit Rozbalit vše Re: Efektivní parsování logu
    Pre tento typ prípadu je ideál to mať v DB, a dáta vyťahovať selectom.
    13.9.2019 11:22 Jirka
    Rozbalit Rozbalit vše Re: Efektivní parsování logu
    Že bych jako syslog nebo nginx logy ukládal do DB ?
    ...to fakt ne ;-)


    Děkuji.
    13.9.2019 12:42 rich
    Rozbalit Rozbalit vše Re: Efektivní parsování logu
    Ale moznost to je...
    https://www.rsyslog.com/doc/v8-stable/tutorials/database.html
    Jinak opravdu "jednoduchy" zpusob je awk, grep atd.
    13.9.2019 13:24 Peter Golis | skóre: 65 | blog: Bežné záležitosti | Bratislava
    Rozbalit Rozbalit vše Re: Efektivní parsování logu
    Problém je ale ako potom zložiť dopyt typu SELECT blah FROM SystemEvents WHERE FromHost=:hostname AND DeviceReportedTime between "...:..." AND "...:..." .
    13.9.2019 23:41 Miloslav Ponkrác
    Rozbalit Rozbalit vše Re: Efektivní parsování logu
    Na některých pomalejších strojích, kde je málo požadavků mám log v databázi, a nemohu si to vynachválit.

    Je rozložen do několika tabulek, aby to bylo kratší.

    Například je tabulka hodnot UserStringů a v logu je jenom id. Po několika letech provozu mám asi 1000 různých UserStringů a už to nepřibývá. Log je díky tomu velice malý.

    Tam kde to lítá, je samozřejmě log v databázi skoro nesmysl.
    13.9.2019 11:31 Ivan
    Rozbalit Rozbalit vše Re: Efektivní parsování logu
    Tohle dela Splunk anebo ELK. Tezko rict jak "jednoduchy" je takovy tool zacit pouzivat.

    wamba avatar 13.9.2019 13:52 wamba | skóre: 38 | blog: wamba
    Rozbalit Rozbalit vše Re: Efektivní parsování logu

    Vždycky si můžeš napsat script v nějakým jazyce. Např. v Perlu 6

    use v6.c;
    constant %months = %(<Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec> Z=> 1..12);
    
    sub tag-by-DateTime ($log-line) {
        $log-line
        andthen .match: rx{
            '[' $<day>= \d **2
            '/' $<month-string>= \w **3
            '/' $<year>= \d **4
            ':' $<hour>= \d **2
            ':' $<minute>= \d **2
            ':' $<sec>= \d **2
            ' '<[+-]> \d ** 4
            ']'
        }
        andthen %(.hash, "month" => %months{$<month-string>})
        andthen DateTime.new: |$_
    }
    
    sub MAIN (
        :$file = '/var/log/httpd/access_log',
        :$from = DateTime.now.earlier(:1day).Str,
        :$to   = DateTime.now.Str,
    ) {
        my @log = lines $file.IO;
    
        @log
        andthen .map: {tag-by-DateTime($_) => $_}\
        andthen .grep: {.key ~~ DateTime.new($from) .. DateTime.new($to)}\
        andthen .map: *.value.put
    }
    
    a pak
    perl6 ./read-log-by-date-abc.p6 -file=/var/log/httpd/access_log  -from=2016-08-21T12:50:00 -to=2016-08-21T13:37:00
    

    Pár poznámek:

    • je to napsáno jen tak narychlo,
    • nejvíce kódu zabírá parsování data a času je lepší si najít knihovnu, která to udělá za tebe. (tz ignoruji)
    • nepředpokládá, že řádky jsou seřazeny podle data, tedy na velkých souborech to bude zbytečně pomalé.
    • například následující: :$to = DateTime.now.Str, je hodně neelegantní atp.
    This would have been so hard to fix when you don't know that there is in fact an easy fix.
    13.9.2019 14:48 OldFrog {Ondra Nemecek} | skóre: 36 | blog: Žabákův notes | Praha
    Rozbalit Rozbalit vše Re: Efektivní parsování logu
    Pokud používáte systemd, tak něco umí journalctl:
    journalctl --since= --until= ...
    
    To logování do databáze taky nemusí být špatný nápad, jsou i specializované řešení pro tento účel.
    -- OldFrog
    13.9.2019 23:37 Miloslav Ponkrác
    Rozbalit Rozbalit vše Re: Efektivní parsování logu
    Program nebo skript, který by provedl požadované bych napsal za pár minut. Rozhodně rychlejší než hledat nějaký nástroj.

    Možná bych si to během programování předvysypal grepem na řetězec [01/Jun/2019:
    14.9.2019 13:04 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: Efektivní parsování logu
    Pro tyto účely používám AWK. Umí filtrovat a parsovat vstup i formátovat výstup. Když je třeba, zvládne porovnat záznamy mezi sebou i agregovat data.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    14.9.2019 15:51 MP
    Rozbalit Rozbalit vše Re: Efektivní parsování logu
    Graylog + logy v jsonu a na nejaky awk apod si ani nevzpomenete pro bezne pouziti.

    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.