Portál AbcLinuxu, 12. května 2025 15:44

Dotaz: Přesměrování chyb do souboru v shell

12.9.2013 14:45 Antonín
Přesměrování chyb do souboru v shell
Přečteno: 421×
Odpovědět | Admin
Ahoj, mám nějaký script v shellu a nevím, jak přesměrovat chyby z toho scriptu do souboru. Jedná se o to, že script není ve funkci. Jinak by to nebyl problém. Děkuji za pomoc.

Řešení dotazu:


Nástroje: Začni sledovat (0) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

Řešení 1× (mikky)
12.9.2013 14:48 Kit
Rozbalit Rozbalit vše Re: Přesměrování chyb do souboru v shell
Odpovědět | | Sbalit | Link | Blokovat | Admin
script 2>>error.log
12.9.2013 15:07 Antonín
Rozbalit Rozbalit vše Re: Přesměrování chyb do souboru v shell
Jak jsem psal, nemám to ve funkci :-( čili tohle "script 2>>error.log" použít nemůžu. Díky
12.9.2013 15:20 gsnak | skóre: 22 | blog: gsnak
Rozbalit Rozbalit vše Re: Přesměrování chyb do souboru v shell
Co znamena "nemam to ve funkci"?
Čo Rys, to vrah!
12.9.2013 15:42 Antonín
Rozbalit Rozbalit vše Re: Přesměrování chyb do souboru v shell
Ok, příklad, zle se vyjadřuji ;)

mám soubor /root/myscript
#!/bin/bash
ls /roooooooooooooooo/
ls /roooooooooo/
ls /rooooooooooooooxxxxxxxoo/
ls /rxxoxxxxxxxxxx/
ls /rccccccccccccccoooo/
spustím /root/mysqcript
ls: nelze přistoupit k /roooooooooooooooo/: Adresář nebo soubor neexistuje
ls: nelze přistoupit k /roooooooooo/: Adresář nebo soubor neexistuje
ls: nelze přistoupit k /rooooooooooooooxxxxxxxoo/: Adresář nebo soubor neexistuje
ls: nelze přistoupit k /rxxoxxxxxxxxxx/: Adresář nebo soubor neexistuje
ls: nelze přistoupit k /rccccccccccccccoooo/: Adresář nebo soubor neexistuje
ale jak to udělat aby se chyby zobrazily v souboru a nemusel to psát takto..

#!/bin/bash
ls /roooooooooooooooo/ 2>>/root/error.log
ls /roooooooooo/ 2>>/root/error.log
ls /rooooooooooooooxxxxxxxoo/ 2>>/root/error.log
ls /rxxoxxxxxxxxxx/ 2>>/root/error.log
ls /rccccccccccccccoooo/ 2>>/root/error.log

můžu to udělat takto?
#!/bin/bash
error()
{
  echo $1 >> /root/error.log
}

ls /roooooooooooooooo/ || error "nějaká zpráva"
ls /roooooooooo/  || error "nějaká zpráva"
ls /rooooooooooooooxxxxxxxoo/  || error "nějaká zpráva"
ls /rxxoxxxxxxxxxx/  || error "nějaká zpráva"
ls /rccccccccccccccoooo/  || error "nějaká zpráva"
nevím jestli se používá | nebo || :-(
12.9.2013 15:47 Vojtěch Horký | skóre: 39 | blog: Vojtův zápisník | Praha
Rozbalit Rozbalit vše Re: Přesměrování chyb do souboru v shell
#!/bin/sh

(
    ls /roooooooooooooooo/
    ls /roooooooooo/
    ls /rooooooooooooooxxxxxxxoo/
    ls /rxxoxxxxxxxxxx/
    ls /rccccccccccccccoooo/
) 2 >>/root/error.log
I am always ready to learn although I do not always like to be taught. (W. Churchill)
12.9.2013 16:12 Kit
Rozbalit Rozbalit vše Re: Přesměrování chyb do souboru v shell
Pokud mám soubor /root/myscript
#!/bin/bash
ls /roooooooooooooooo/
ls /roooooooooo/
ls /rooooooooooooooxxxxxxxoo/
ls /rxxoxxxxxxxxxx/
ls /rccccccccccccccoooo/
tak
/root/myscript 2>>/root/error.log
mi normálně funguje jak má.
12.9.2013 21:05 Patrik Uhrak | skóre: 31 | blog: pato
Rozbalit Rozbalit vše Re: Přesměrování chyb do souboru v shell
... ale jak to udělat aby se chyby zobrazily v souboru a nemusel to psát takto..
#!/bin/bash
ls /roooooooooooooooo/ 2>>/root/error.log
ls /roooooooooo/ 2>>/root/error.log
ls /rooooooooooooooxxxxxxxoo/ 2>>/root/error.log
ls /rxxoxxxxxxxxxx/ 2>>/root/error.log
ls /rccccccccccccccoooo/ 2>>/root/error.log
#! /bin/bash

log="/cesta/k/error.log"
exec 2>"$log"

tvoj_kod
12.9.2013 15:47 Antonín
Rozbalit Rozbalit vše Re: Přesměrování chyb do souboru v shell
Edit konce..

můžu to udělat takto?

#!/bin/bash
error()
{
  echo $1 >> /root/error.log
}

ls /roooooooooooooooo/ 2>/dev/null || error "nějaká zpráva"
ls /roooooooooo/ 2>/dev/null || error "nějaká zpráva"
ls /rooooooooooooooxxxxxxxoo/ 2>/dev/null || error "nějaká zpráva"
ls /rxxoxxxxxxxxxx/ 2>/dev/null || error "nějaká zpráva"
ls /rccccccccccccccoooo/ 2>/dev/null || error "nějaká zpráva"
nevím jestli se používá | nebo || :-(
12.9.2013 16:06 Patrik Uhrak | skóre: 31 | blog: pato
Rozbalit Rozbalit vše Re: Přesměrování chyb do souboru v shell

Tak pokial nevies, tak citaj:

http://www.tldp.org/LDP/abs/html/index.html

A pokial sa ti nechce, tak to asi nepojde.

12.9.2013 16:18 Antonín
Rozbalit Rozbalit vše Re: Přesměrování chyb do souboru v shell
To je tedy rada.. ptám se na konkrétní věc jelikož "||" se pouřívá jen v if.
12.9.2013 19:16 Patrik Uhrak | skóre: 31 | blog: pato
Rozbalit Rozbalit vše Re: Přesměrování chyb do souboru v shell

V akom if, ved sam to pouzivas i bez. Rada je to na nezaplatenie, bo je tam vsetko krasne vysvetlene, kopec ukazok a taktiez myslim testy su tam, alebo testy som mal dakde inde. Jedno alebo druhe.

12.9.2013 16:44 mikky | skóre: 25 | blog: Ghlog | M. L. - Praha
Rozbalit Rozbalit vše Re: Přesměrování chyb do souboru v shell
co vlastně chceš?

./script 2>error.log

funguje dle očekávání, tedy chybové hlášky skončí v souboru error.log
Je vám méně než 30 ? (jsme vrstevnící => budeme si tykat) : (jsem pro vás bažant => můžete mi tykat);
12.9.2013 18:27 Antonín
Rozbalit Rozbalit vše Re: Přesměrování chyb do souboru v shell
Chci mít běh scriptu pod svou kontrolou... co se týká chyb! mám soubor a.sh, soubor b.sh v souboru a.sh budu mít
#!/bin/bash
start()
{
. /root/b.sh
}

start 2>>/root/error.log || {
echo "Akci se nepodařilo dokončit! Chyba: $ERR"
exit 0
}
v souboru b.sh budu mít
aaa || ERR="zprava1"; exit 1
bbb || ERR="zprava2";exit 1
ccc || ERR="zprava3";exit 1
Pokud vše spustím a nastane chyba, zprávu : Akci se nepodařilo dokončit! neuvidím, navíc se provedou všechny neplatné příkazy v souboru b.sh. Očekával bych při tomto zadání po spuštění výsledek.

Na obrazovce: Akci se nepodařilo dokončit! Chyba: zprava1"

v souboru error.log: /root/b.sh: řádek 1: aaa: příkaz nenalezen

Děkuji
12.9.2013 19:11 Patrik Uhrak | skóre: 31 | blog: pato
Rozbalit Rozbalit vše Re: Přesměrování chyb do souboru v shell

1. Spustas aaa  a taky prikaz neexistuje. K bbb a ccc sa nedostane, bo je tam exit 1

2. Nikdy nedostanes hlasku "Akci se nepodarilo dokoncit" , ak to ponechas takto.

12.9.2013 19:36 Antonín
Rozbalit Rozbalit vše Re: Přesměrování chyb do souboru v shell

1. Spustas aaa  a taky prikaz neexistuje. K bbb a ccc sa nedostane, bo je tam exit 1

2. Nikdy nedostanes hlasku "Akci se nepodarilo dokoncit" , ak to ponechas takto.

Ano aaa neexistuje, proto jsem to tam dal aby vyskočila chyba ;) Jinak když dám místo exit 1 return 1 tak je vysledek stejný :( tak nevm jak to udelat..
12.9.2013 19:29 NN
Rozbalit Rozbalit vše Re: Přesměrování chyb do souboru v shell
Neni to vynalezani kola? Nestacilo by poslat chybovy vystup zaroven do souboru a zaroven do vystupu, napriklad takto:
ls foo 2>&1 | tee err.log
12.9.2013 19:38 Antonín
Rozbalit Rozbalit vše Re: Přesměrování chyb do souboru v shell
Neni to vynalezani kola? Nestacilo by poslat chybovy vystup zaroven do souboru a zaroven do vystupu, napriklad takto:
ls foo 2>&1 | tee err.log
No stačilo ale jak to napsat na funkci nebo na if?
12.9.2013 22:04 NN
Rozbalit Rozbalit vše Re: Přesměrování chyb do souboru v shell
'if' je podmineny prikaz.. vystup funkce naprikad takto:
foo() {
ls foo;
}

foo 2>&1 | tee bar.log
Mam pocit, ze nikdo tady jeste neprisel na to o co se pokousite, ale toto je poradna pane, ne kurz skriptovani v shellu..
12.9.2013 15:21 Kit
Rozbalit Rozbalit vše Re: Přesměrování chyb do souboru v shell
Pokud potřebuješ chybový výstup, který není chybový, přesměrovat ze skriptu, který není skriptem z funkce, která není funkcí, do souboru, který není souborem, tak na to jsem opravdu krátký. Zkus se zeptat nějaké chytré horákyně.
13.9.2013 20:19 potato
Rozbalit Rozbalit vše Re: Přesměrování chyb do souboru v shell
+1
12.9.2013 14:51 Petr Šobáň | skóre: 80 | blog: soban | Olomouc
Rozbalit Rozbalit vše Re: Přesměrování chyb do souboru v shell
Odpovědět | | Sbalit | Link | Blokovat | Admin
Ono hledání nefunguje?

Standardní vstup a výstup

Znak 2> přesměruje standardní chybový výstup do souboru

Pokud je někde problém s přesměrováním chce to uvést konkrétní ukázku a popsat co nefunguje.....
12.9.2013 20:25 Antonín
Rozbalit Rozbalit vše Re: Přesměrování chyb do souboru v shell
Odpovědět | | Sbalit | Link | Blokovat | Admin
Ty jo, tolik odborníků a neporadí ani jeden :(
12.9.2013 20:29 Kit
Rozbalit Rozbalit vše Re: Přesměrování chyb do souboru v shell
To si děláš srandu? Máš tady hned několik správných rad. Nemůžeme za to, že je neumíš použít - nebo že neumíš popsat, co vlastně chceš.
12.9.2013 20:45 Antonín
Rozbalit Rozbalit vše Re: Přesměrování chyb do souboru v shell
Nedělám si srandu, jsem tady, jelikož to fakt nevím.. Skončil jsem na tom příkladu zde a radu jsem nedostal
13.9.2013 20:24 potato
Rozbalit Rozbalit vše Re: Přesměrování chyb do souboru v shell
Potíž je, že si ostatní mají dojem, že ti radí, akorát se vždy ukáže, že chceš vždy něco jiného. Přinejmenším ale dostáváš informace.

Takže další výstřel od boku:
set -e
Nic to nikam nepřesměrovává. Řeší to, že chceš skript ukončit při chybě (tedy možná, kdoví, těžko říci).
12.9.2013 20:45 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
Rozbalit Rozbalit vše Re: Přesměrování chyb do souboru v shell

Tý jo, vždyť nemluvíš řečí mého kmene - já jsem to do teď nepobral, ostatní hádají a střílí ti od pasu rady, a vždy jen svou poznámkou zamlžíš .

Prostě klasika, …odpověď je 42… a zcela určitě je to správná odpověď. Ale abych byl upřímný, myslím si, že problém spočívá v tom, že jste nikdy pořádně nevěděli, jak zní otázka.

To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
rADOn avatar 13.9.2013 16:24 rADOn | skóre: 44 | blog: bloK | Praha
Rozbalit Rozbalit vše Re: Přesměrování chyb do souboru v shell
Tak já nevím, buď nám tady hned několik zkušených harcovníků přes noc zblbnulo… nebo je chyba někde jinde. Já z toho taky nejsem dvakrát moudrej, tady odtud to vypadá že úplně první chyba bude v tom že vymýšlíš nějakou hroznou elektrárnu do initskriptu která by neměla valnýho smyslu i kdyby ti to fungovalo. stderr má svůj smysl aby člověk věděl kam sáhnout když se něco podělá, a když nevíš co dělás tak uděláš líp když se do toho nebudeš vrtat.

Někteří neschopní hlupáci co ti tu nedokážou poradit napsali víc shellskriptů než kolik má bill gates doma oken, možná že když popíšeš o co se to vlastně snažíš, tak ti poradí něco lepšího.
"2^24 comments ought to be enough for anyone" -- CmdrTaco

Založit nové vláknoNahoru

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

ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.