abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 23:33 | Nová verze

    Google Chrome 126 byl prohlášen za stabilní. Nejnovější stabilní verze 126.0.6478.55 přináší řadu oprav a vylepšení (YouTube). Podrobný přehled v poznámkách k vydání. Opraveno bylo 21 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře.

    Ladislav Hagara | Komentářů: 0
    včera 16:44 | Nová verze

    Byl vydán Mozilla Firefox 127.0. Přehled novinek v poznámkách k vydání, poznámkách k vydání pro firmy a na stránce věnované vývojářům. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 127 je již k dispozici také na Flathubu a Snapcraftu.

    Ladislav Hagara | Komentářů: 0
    včera 15:11 | Nová verze

    Byla vydána (𝕏) nová verze 9.5 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    včera 11:44 | IT novinky

    Společnost Raspberry Pi dnes vstoupila na Londýnskou burzu jako Raspberry Pi Holdings plc (investor).

    Ladislav Hagara | Komentářů: 0
    včera 01:22 | IT novinky

    Do 17. června do 19:00 běží na Steamu přehlídka nadcházejících her Festival Steam Next | červen 2024 doplněná demoverzemi, přenosy a dalšími aktivitami. Demoverze lze hrát zdarma.

    Ladislav Hagara | Komentářů: 0
    10.6. 22:33 | IT novinky

    Apple na své vývojářské konferenci WWDC24 (Worldwide Developers Conference, keynote) představil řadu novinek: svou umělou inteligenci pojmenovanou jednoduše Apple Intelligence, iOS 18, visionOS 2, macOS Sequoia, iPadOS 18, watchOS 11, …

    Ladislav Hagara | Komentářů: 9
    10.6. 21:44 | Nová verze

    Vyšla nová verze XMPP (Jabber) klienta Gajim, která přidává podporu reakcí pomocí emoji (XEP-0444: Message Reactions) a citace zpráv (XEP-0461: Message Replies). Přehled dalších vylepšení je k dispozici na oficiálních stránkách.

    sonicpp | Komentářů: 1
    10.6. 15:00 | Nová verze

    Po po téměř roce vývoje od vydání verze 5.38 byla vydána nová stabilní verze 5.40 programovacího jazyka Perl (Wikipedie). Do vývoje se zapojilo 75 vývojářů. Změněno bylo přibližně 160 tisíc řádků v 1 500 souborech. Přehled novinek a změn v podrobném seznamu.

    Ladislav Hagara | Komentářů: 7
    10.6. 12:00 | Zajímavý článek

    Uroš Popović popisuje, jak si nastavit Linux na desce jako Raspberry Pi Zero, aby je šlo používat jako USB „flešku“.

    Fluttershy, yay! | Komentářů: 1
    10.6. 08:44 | Zajímavý software

    Andreas Kling oznámil, že jelikož už se nevěnuje nezávislému operačnímu systému SerenityOS, ale výhradně jeho webovému prohlížeči Ladybird, přičemž vyvíjí primárně na Linuxu, SerenityOS opustí a Ladybird bude nově samostatný projekt (nový web, repozitář na GitHubu).

    Fluttershy, yay! | Komentářů: 2
    Rozcestník

    Dotaz: Presmerovanie stdout len do suboru a stderr do suboru aj konzoly

    7.8.2020 17:18 GeorgeWH | skóre: 42
    Presmerovanie stdout len do suboru a stderr do suboru aj konzoly
    Přečteno: 391×
    Zdravim.

    Uz sa s tym piplam dve hodiny a nic. Mam sh (nie bash) skript, ktoreho standardny a error vystup chcem ulozit do suboru a zaroven na konzolu vypisat len error hlasky. Skusal som kadejake variacie s exec, ale stale som mal bud vsetko v konzole a prazdny subor alebo naopak alebo nikde nic...

    Najlepsie by bolo, keby bolo vsetko vyriesene v skripte, ale uspokojil by som sa aj s variantou, ked by napr. ./moj-skript.sh >/dev/null do konzoly vypisal len chybu a do suboru vsetko a ./moj-skript.sh by vypisal vsetko do konzoly aj suboru.

    Skript moj-skript.sh:
    #!/bin/sh
    #
    
    # nejako nastavene presmerovanie stdout a stderr do suboru moj-skript.log
    # a zaroven presmerovanie stderr na konzolu
    ???
    
    /bin/ls /etc/fstab
    /bin/ls /nonexists
    
    Vystup skriptu
    $ ./moj-skript.sh
    ls: /nonexists: No such file or directory
    
    Obsah log suboru moj-skript.log
    /etc/fstab
    ls: /nonexists: No such file or directory
    
    Vdaka.

    Řešení dotazu:


    Odpovědi

    xkucf03 avatar 7.8.2020 17:48 xkucf03 | skóre: 49 | blog: xkucf03
    Rozbalit Rozbalit vše Re: Presmerovanie stdout len do suboru a stderr do suboru aj konzoly

    Tohle dělá, co chceš:

    #!/bin/sh
    
    funkce() {
    	/bin/ls /etc/fstab
    	/bin/ls /nonexists
    }
    
    
    mkfifo out.fifo
    mkfifo err.fifo
    mkfifo xxx.fifo
    
    cat out.fifo > xxx.fifo &
    cat err.fifo | tee xxx.fifo &
    cat xxx.fifo > xxx.log &
    
    funkce 1> out.fifo 2> err.fifo
    
    wait
    wait
    wait
    
    rm -f out.fifo err.fifo xxx.fifo
    

    Ale nelíbí se mi to, říkám si, že by to mělo jít jednodušeji…

    Navíc je tam problém s úklidem při nějaké chybě a s tím, že se ti můžou zprávy zapsané do STDOUT a STDERR prolnout.

    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
    7.8.2020 19:32 GeorgeWH
    Rozbalit Rozbalit vše Re: Presmerovanie stdout len do suboru a stderr do suboru aj konzoly
    Ten ls bol len na demonstraciu pozadovaneho vysledku. Robit taketo upravy je dost nerealne.
    xkucf03 avatar 7.8.2020 20:58 xkucf03 | skóre: 49 | blog: xkucf03
    Rozbalit Rozbalit vše Re: Presmerovanie stdout len do suboru a stderr do suboru aj konzoly

    Pak asi tohle: #4, případně tam ještě přidat ten sed z #7.

    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
    7.8.2020 17:49 pavele
    Rozbalit Rozbalit vše Re: Presmerovanie stdout len do suboru a stderr do suboru aj konzoly
    tee
    xkucf03 avatar 7.8.2020 17:58 xkucf03 | skóre: 49 | blog: xkucf03
    Rozbalit Rozbalit vše Re: Presmerovanie stdout len do suboru a stderr do suboru aj konzoly

    Můžeš to rozvést?

    V Bashi jde dosadit proces místo cesty k souboru, otázka je, jak ty výstupy pak zase spojit do jednoho… Možná nějak adaptovat tenhle příklad… ale tohle jsou docela zběsilosti – do toho článku jsem to dával spíš jako odstrašující příklad :-)

    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
    xkucf03 avatar 7.8.2020 18:12 xkucf03 | skóre: 49 | blog: xkucf03
    Rozbalit Rozbalit vše Re: Presmerovanie stdout len do suboru a stderr do suboru aj konzoly

    P.S. Tak trochu funguje tohle:

    funkce 2> >(tee -a xxx.log) >> xxx.log

    ale nelíbí se mi ten zápis do jednoho souboru ze dvou procesů bez jakékoli synchronizace…

    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
    7.8.2020 19:17 jejda | skóre: 24 | blog: jejda
    Rozbalit Rozbalit vše Re: Presmerovanie stdout len do suboru a stderr do suboru aj konzoly
    Taky si můžeš ten error z logu jednoduše grepnout.
    #!/bin/sh
    log=moj-skript.log
    for file in /etc/fstab /nonexists; do
      /bin/ls $file >> $log 2>&1
      tail -1 $log | grep "^/bin/ls: "
    done
    7.8.2020 19:54 jiwopene | skóre: 31 | blog: Od každého trochu…
    Rozbalit Rozbalit vše Re: Presmerovanie stdout len do suboru a stderr do suboru aj konzoly
    ( ./moj-skript.sh 2> >( tee /dev/stderr ) | sed '' ) > moj-skript.log
    Ten sed zajišťuje bufferování řádku podobné tomu, které se používá u výstupu na terminál. stderr zůstává stderr.
    .sig virus 3.2_cz: Prosím, okopírujte tento text do vaší patičky.
    7.8.2020 21:45 GeorgeWH | skóre: 42
    Rozbalit Rozbalit vše Re: Presmerovanie stdout len do suboru a stderr do suboru aj konzoly
    Vysledok je ok, ale potreboval by som to dostat priamo do toho skriptu, aby ho jednoducho stacilo spustit a aby to bolo hlavne blbovzdorne.
    Jendа avatar 7.8.2020 22:07 Jendа | skóre: 78 | blog: Jenda | JO70FB
    Rozbalit Rozbalit vše Re: Presmerovanie stdout len do suboru a stderr do suboru aj konzoly
    Jsem zagůglil bash replace stdout of current script a první odkaz říká že by na začátku mělo jít udělat exec a>b a to efektivně změní všechen výstup skriptu.

    A před tím první, co mě napadlo bez googlení, bylo napsat si modul do bashe, který nahradí file deskriptory 1 a 2, a zavést ho pomocí enable -f :-D
    xkucf03 avatar 7.8.2020 22:16 xkucf03 | skóre: 49 | blog: xkucf03
    Rozbalit Rozbalit vše Re: Presmerovanie stdout len do suboru a stderr do suboru aj konzoly

    Ten exec se normálně používá, ale problém je, že on tady chce STDERR rozdvojit, jednou ho poslat na terminál a jednou ho spojit s STDOUT a společně poslat do souboru.

    V tom modulu bys musel řešit to samé – číst současně ze dvou FD a data z jednoho posílat na terminál a data z obou posílat do souboru.

    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
    Řešení 1× (GeorgeWH (tazatel))
    7.8.2020 22:09 GeorgeWH | skóre: 42
    Rozbalit Rozbalit vše Re: Presmerovanie stdout len do suboru a stderr do suboru aj konzoly
    Tak uz to mam, stacilo to supnut do skriptu a nie je to az take zle. Akurat to funguje len v bash-i, ale tak co uz (vsetky skripty sa snazim pisat v shell-i):
    #!/bin/bash
    #
    
    (
    
    echo "INFO: log iba do suboru"
    ls /etc/fstab
    
    echo "ERROR: log do suboru aj na konzolu" >&2
    ls /nonexists
    
    echo "INFO: log iba do suboru"
    
    echo "ERROR: log do suboru aj na konzolu" >&2
    
    ) 2> >( tee /dev/stderr ) | sed '' > moj-skript.log
    
    Vdaka.
    xkucf03 avatar 7.8.2020 22:26 xkucf03 | skóre: 49 | blog: xkucf03
    Rozbalit Rozbalit vše Re: Presmerovanie stdout len do suboru a stderr do suboru aj konzoly

    Případně se to ještě řeší tak, že na začátek skriptu dáš IF, ve kterém zkontroluješ nějakou proměnnou, pokud není nastavená, tak ji nastavíš a spustíš sám sebe s tím přesměrováním:

    #!/bin/bash
    
    if [ -z "$XXX" ]; then
    	export XXX=x;
    	echo "spouštím s přesměrováním";
    	"$0" "$@" &>1;
    fi
    
    echo "původní skript";
    echo "parametry: " "$@";

    Tohle se hodí i v případě, že potřebuješ potřebuješ třeba přepsat nebo doplnit nějaké CLI parametry.

    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

    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.