Přímý přenos (YouTube) z konference LinuxDays 2025, jež probíhá tento víkend v Praze v prostorách FIT ČVUT. Na programu je spousta zajímavých přednášek.
V únoru loňského roku Úřad pro ochranu osobních údajů pravomocně uložil společnosti Avast Software pokutu 351 mil. Kč za porušení GDPR. Městský soud v Praze tuto pokutu na úterním jednání zrušil. Potvrdil ale, že společnost Avast porušila zákon, když skrze svůj zdarma dostupný antivirový program sledovala, které weby jeho uživatelé navštěvují, a tyto informace předávala dceřiné společnosti Jumpshot. Úřad pro ochranu osobních údajů
… více »Google Chrome 141 byl prohlášen za stabilní. Nejnovější stabilní verze 141.0.7390.54 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 21 bezpečnostních chyb. Za nejvážnější z nich (Heap buffer overflow in WebGPU) bylo vyplaceno 25 000 dolarů. Vylepšeny byly také nástroje pro vývojáře.
eDoklady mají kvůli vysoké zátěži technické potíže. Ministerstvo vnitra doporučuje vzít si sebou klasický občanský průkaz nebo pas.
Novým prezidentem Free Software Foundation (FSF) se stal Ian Kelling.
Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za září (YouTube).
Vyšla kniha Počítačové programy a autorské právo. Podle internetových stránek nakladatelství je v knize "Významný prostor věnován otevřenému a svobodnému softwaru, jeho licencím, důsledkům jejich porušení a rizikům „nakažení“ proprietárního kódu režimem open source."
Red Hat řeší bezpečnostní incident, při kterém došlo k neoprávněnému přístupu do GitLab instance používané svým konzultačním týmem.
Immich byl vydán v první stabilní verzi 2.0.0 (YouTube). Jedná se o alternativu k výchozím aplikacím od Googlu a Applu pro správu fotografií a videí umožňující vlastní hosting serveru Immich. K vyzkoušení je demo. Immich je součástí balíčků open source aplikací FUTO. Zdrojové kódy jsou k dispozici na GitHubu pod licencí AGPL-3.0.
Český telekomunikační úřad vydal zprávy o vývoji cen a trhu elektronických komunikací se zaměřením na rok 2024. Jaká jsou hlavní zjištění? V roce 2024 bylo v ČR v rámci služeb přístupu k internetu v pevném místě přeneseno v průměru téměř 366 GB dat na jednu aktivní přípojku měsíčně – celkově jich tak uživateli bylo přeneseno přes 18 EB (Exabyte). Nejvyužívanějším způsobem přístupu k internetu v pevném místě zůstal v roce 2024 bezdrátový
… více »exit
je normalni prikaz, neodchytava se. Jestli je ve skriptu, tak napis potrebne veci pred nej. Jestli tam neni, pripis svoje prikazy na konec skriptu.
Pokud mas na mysli signal SIGTERM, kterym se obvykle ukoncuji procesy (napriklad prikazem kill
), tak k tomu se pouziva prikaz trap
. Zde je priklad:
#!/bin/bash trap terminator TERM terminator() { echo -e "\nSkript byl zabit." exit 1 } while true; do echo -n "." sleep 1 doneKdyz ten skript spustis v jednom terminalu, tak se bude vykonavat nekonecna smycka. Kdyz vyvolas jeho ukonceni (treba prikazem
killall skript
z jineho terminalu), provedou se prikazy popsane ve funkci "terminator" (lze zvolit libovolny jiny nazev). Kdybys chtel odchytit jiny signal, treba SIGINT, ktery se posila pri stisknuti kombinace ctrl-c, nahrad slovo TERM slovem INT. Vice o signalech najdes v man 7 signal
nebo v manualu ke kill, killall apod.
exit
ve skriptu), trap
lze pověsit i na exit
přes "sigspec" 0 (resp. EXIT). Tedy v příklady výše: trap terminator 0
Druhá poznámka: napřed bych funkci definoval, potom teprve přiřadil k trap
. Takhle v jednu chvíli máme trap
odkazující na neexistující volání.
Třetí poznámka je od věci: killall
je strašně škaredý zlozvyk, na což člověk při troše smůlu přijde ve chvíli, kdy si sedne před něco, co vypadá jako Linux (něco System V kompatibilního), ale není to Linux. Raději pkill
. ;)
Nicméně pokud chcete (třeba centrálně ošetřený úklid, bez nutnosti volat příslušnou funkci před každýmNo tohle bych přesně potřeboval ale nějak jsem vás nepochopil jak to přesně myslíte. Můžete to ještě trochu rozvést případně nějakou ukázku? Díkyexit
ve skriptu),trap
lze pověsit i naexit
přes "sigspec" 0 (resp. EXIT). Tedy v příklady výše:trap terminator 0
#!/bin/bash
# Funkce, ktera se ma vykonat pred ukoncenim behu
ukoncovaciFunkce() {
# Treba mazani docasnych adresaru, zde nic
:
# Explicitni ukonceni behu je nutne pouze v pripade, ze zachytavete i
# jine udalosti nez EXIT, zde priklad vzdy vraci 0
exit 0
}
# Nastavi trap pri ukonceni se napred zavola ukoncovaciFunkce
trap ukoncovaciFunkce EXIT
# Vlastni skript, kdekoliv se zaloval exit (nebo beh dojde na konec skriptu),
# vykona se ukoncovaciFunkce
exit 0
Platí i ten zbytek, tj. odkaz na man -s7 signal
. Stejnou funkci můžete přiřadit vícero událostem (nejen signály, více je popsáno v manuálu bash
), příp. můžete na různé pověsit různá volání. Např. zmiňovanému signálu SIGTERM
(15, výchozí kill
) nebo typicky chcete zachytávat SIGINT
(2, přerušení z klávesnice, onbykle ^C
).
Ještě poznámka k EXIT
. Nastane při ukončení shellu, takže kdybyste chytal jiné události a také EXIT
a prováděl tutéž akci, vykoná se dvakrát (např. jednou při zachycení SIGINT
a podruhé při ukončení samotného procesu shellu).
V takom prípade stačí spustiť to spracovávanie hneď za tým spúšťaným skriptom.Tomu moc nerozumím...
echo "test 1" ./skript.sh echo "test 2"tak sa ten druhý príkaz echo spustí po tom, ako sa ukončí skript.sh (či už kvôli chybe, alebo preto, lebo je v ňom exit). Takže ak treba po vykonaní toho skriptu niečo urobiť, netreba používať trap.
v souboru start.sh mám #!/bin/bash ukoncovaciFunkce() { echo "Konec!" exit 0 } trap ukoncovaciFunkce EXIT while [[ 1 ]] do ./skript1.sh ./skript2.sh done exit 0a v souboru skript1.sh a skript2.sh budu mít třeba jen exit 1 or exit 0 tak se nevypíše "Konec" a hlavní script se stejně neukončí. Ten Trap funguje jenom v tom souboru start.sh, jinak už ne a to nevím jak ošetřit, proto jsem se ptal, jestli to musí být v každém souboru...
trap
se nedědí z rodičovského shellu. Ty další skripty jsou samostatně spuštěné procesy bash, viz:
$ trap -p
trap -- '' SIGTSTP
trap -- '' SIGTTIN
trap -- '' SIGTTOU
$ trap /bin/true EXIT
$ trap -p
trap -- '/bin/true' EXIT
trap -- '' SIGTSTP
trap -- '' SIGTTIN
trap -- '' SIGTTOU
$ bash
$ trap -p
trap -- '' SIGTSTP
trap -- '' SIGTTIN
trap -- '' SIGTTOU
Takže si buď v jednotlivých procesech shellu nastavíte vlastní zachytávání, nebo v uvedením případě můžete alternativně ty skripty místo spouštění vkládat a zachytávat pro ně událost RETURN
. Pak ale naopak nesmíte ty další skripty ukončovat s exitem, neb jste stále ve stejné procesu a ukončíte si tento:
skript1.sh:
echo "ve skript1.sh"hlavni.sh:
#!/bin/bash navratovaAkce() { echo "a jsme zpet" } trap navratovaAkce RETURN echo "vlozime skript1.sh" source skript1.sh exit 0Technicky to možné je, nicméně bych se klonil k první variantě ošetřit si to místně.
Třetí poznámka je od věci:Tesat do kamene! :Dkillall
je strašně škaredý zlozvyk, na což člověk při troše smůlu přijde ve chvíli, kdy si sedne před něco, co vypadá jako Linux (něco System V kompatibilního), ale není to Linux. Radějipkill
. ;)
Tiskni
Sdílej: