Policisté zadrželi odsouzeného drogového dealera Tomáše Jiřikovského, který daroval ministerstvu spravedlnosti za tehdejšího ministra Pavla Blažka (ODS) bitcoiny v miliardové hodnotě, a zajistili i darovanou kryproměnu. Zadržení Jiřikovského může být podle ministerstva důležité k rozuzlení kauzy, která vypukla koncem května a vedla ke konci Blažka. Zajištění daru podle úřadu potvrzuje závěry dříve publikovaných právních
… více »Administrativa amerického prezidenta Donalda Trumpa jedná o možném převzetí podílu ve výrobci čipů Intel. Agentuře Bloomberg to řekly zdroje obeznámené se situací. Akcie Intelu v reakci na tuto zprávu výrazně posílily. Trump minulý týden označil Tana za konfliktní osobu, a to kvůli jeho vazbám na čínské společnosti, čímž vyvolal nejistotu ohledně dlouholetého úsilí Intelu o obrat v hospodaření. Po pondělní schůzce však prezident o šéfovi Intelu hovořil příznivě.
Společnost Purism stojící za linuxovými telefony a počítači Librem má nově v nabídce postkvantový šifrátor Librem PQC Encryptor.
VirtualBox, tj. multiplatformní virtualizační software, byl vydán v nové verzi 7.2. Přehled novinek v Changelogu. Vypíchnou lze vylepšené GUI.
Eric Migicovsky, zakladatel společnosti Pebble, v lednu oznámil, že má v plánu spustit výrobu nových hodinek Pebble s již open source PebbleOS. V březnu spustil předprodej hodinek Pebble Time 2 (tenkrát ještě pod názvem Core Time 2) za 225 dolarů s dodáním v prosinci. Včera představil jejich konečný vzhled (YouTube).
Byla oznámena nativní podpora protokolu ACME (Automated Certificate Management Environment) ve webovém serveru a reverzní proxy NGINX. Modul nginx-acme je zatím v preview verzi.
Vývojáři KDE oznámili vydání balíku aplikací KDE Gear 25.08. Přehled novinek i s náhledy a videi v oficiálním oznámení.
Společnost Perplexity AI působící v oblasti umělé inteligence (AI) podala nevyžádanou nabídku na převzetí webového prohlížeče Chrome internetové firmy Google za 34,5 miliardy dolarů (zhruba 723 miliard Kč). Informovala o tom včera agentura Reuters. Upozornila, že výše nabídky výrazně převyšuje hodnotu firmy Perplexity. Společnost Google se podle ní k nabídce zatím nevyjádřila.
Intel vydal 34 upozornění na bezpečnostní chyby ve svých produktech. Současně vydal verzi 20250812 mikrokódů pro své procesory řešící 6 bezpečnostních chyb.
Byla vydána nová verze 1.25 programovacího jazyka Go (Wikipedie). Přehled novinek v poznámkách k vydání.
getopts
, dále jak zjistit, kolik procesorového času spotřebovává daný program pomocí time
, a také jak spustit program tak, aby jej nepřerušilo ukončení řídícího terminálu pomocí nohup
.Nástroj getopts
slouží ke zpracování přepínačů a jejich argumentů, které jsou předány shellovému skriptu. Název je zkratkou get options, česky „získej přepínače/nastavení“.
Obvykle se volá v cyklu while
, dokud vrací návratovou hodnotu 0 (tzn. dokud neprojde všechny zadané přepínače). Použití vypadá takto:
aopt=false bopt=false barg="" while getopts 'ab:' opt; do case "$opt" in a) aopt=true ;; b) bopt=true barg=$OPTARG ;; esac done if $aopt; then echo "Zadali jste přepínač -a" fi if $bopt; then echo "Zadali jste přepínač -b s argumentem $barg" fi
Funguje to potom takto:
$ ./skript -a Zadali jste přepínač -a $ ./skript -b ./skript: přepínač vyžaduje argument – b $ ./skript -b xy Zadali jste přepínač -b s argumentem xy $ ./skript -c ./skript: chybný přepínač – c
Jako argument se předává nejdříve řetězec s přepínači, přičemž má-li určitý přepínač vyžadovat argument, přidá se za něj dvojtečka. Takže pokud chcete, aby váš program podporoval přepínače -a s argumentem -h a -v, řetězec bude vypadat takto: ,a:hv‘. Další argument je proměnná, kam se ukládá právě zpracovávaný přepínač anebo ,?‘, pokud jde o přepínač neznámý (tj. neuvedený v prvním argumentu getopts
).
getopts
automaticky vypisuje chybové hlášení, pokud přepínač vyžaduje argument a vy jej nezadáte nebo pokud zadáte neznámý přepínač. V případě, že si chcete chybějící argument ošetřit sami, můžete do řetězce s argumenty přidat na začátek (před všechny přepínače) dvojtečku, což změní chování programu. Pokud nyní vynecháte argument, tak se do zadané proměnné (v ukázce výše je to $opt) uloží dvojtečka a znak přepínače vyvolávající tuto chybu se uloží do proměnné OPTARG. Je to možná trochu matoucí, proto přikládám jednoduchou ukázku:
while getopts ':a:b:' opt; do case "$opt" in 'a') aopt=true; aarg=$OPTARG ;; ':') echo "Přepínač -$OPTARG vyžaduje argument." exit 1 ;; esac done
time
je nástroj sloužící ke zjištění skutečné doby běhu daného příkazu a spotřebovaného procesorového času v uživatelském a jaderném prostoru. Název vychází z anglického slova, které v tomto kontextu znamená odměřit (čas).
Použití je velmi jednoduché, zkrátka před samotný příkaz přidáte time
, takže například příkaz
time tar -jcf etc.tar.bz2 /etc
zabalí a zkomprimuje adresář /etc do souboru etc.tar.bz2 a nakonec vypíše tři zmiňované časy:
real 0m1.900s user 0m0.560s sys 0m0.067s
Z tohoto vyplývá, že příkaz běžel 1,9 sekund (real) a využil 0.627 sekund procesorového času (user+sys), z čehož 0.560 sekund bylo v uživatelském prostoru (user) a zbylých 0.067 sekund v jaderném (sys).
Chcete-li spustit time
na složitý příkaz obsahující např. roury, máte několik možností. Pokud na to půjdete stejně jako u jednoduchého příkazu, tak je na implementaci, který čas se bude měřit (pouze jeden program, nebo i ty ostatní za rourami). Chcete-li mít jistotu, tak si buď příkaz uložte do skriptu a volejte time
na skript, anebo použijte následující způsob:
time sh -c "find ~ -iname thumbs.db -type f -print0 | xargs -0 rm"
Výstup příkazu time
bez argumentů se v různých implementacích může lišit (a skutečně liší). Chcete-li jednotný formát, který by měl být ve všech standardních implementacích stejný, použijte přepínač -p. Výstup bude vypadat takto:
# time -p ls -R / > /dev/null real 1.85 user 0.53 sys 1.30
Počet desetinných míst se může lišit dle potřeby (až šest), ovšem vždy musí být vypsáno alespoň jedno.
Příkaz nohup
slouží ke spuštění daného programu tak, aby ignoroval signál SIGHUP, který systém posílá, když je ukončen řídící terminál daného procesu.
Například následující příkaz spustí fatrat
tak, aby běžel i po uzavření konzole:
nohup fatrat
Výstup programu je ukládán do souboru nohup.out
v aktuálním pracovním adresáři a pokud tento soubor nelze otevřít pro zápis, tak se použije soubor ~/nohup.out
, přičemž pokud ani do něj nelze zapisovat, nohup
skončí s chybou a daný program nespustí.
Často je žádoucí spustit program rovnou na pozadí a ignorovat jeho výpisy, čehož lze dosáhnout takto:
# std. výstup a std. chybový výstup je přesměrován do /dev/null nohup fatrat &> /dev/null &
Pokud takto spouštíte něco na vzdáleném počítači přes SSH, tak se vám může stát, že se nebudete moci odpojit. To řešíme tak, že přesměrujeme i standardní vstup. Nakonec by tedy příkaz vypadal takto:
nohup fatrat &> /dev/null < /dev/null &
Ještě dodám jeden malý související tip, který patrně není unixový (a přenositelný), nicméně na GNU/Linuxu funguje. Spustíte-li z konzole příkaz, který běží dlouho, a vy se rozhodnete v polovině jeho průběhu, že jste ho vlastně chtěli spustit přes nohup
, lze to vyřešit. Když zmáčknete Ctrl+Z, proces se zastaví (dostane signál SIGSTOP). Když poté spustíte bg
, proces pokračuje v běhu na pozadí. Nakonec když spustíte disown
, tak docílíte podobného efektu, jako kdybyste program spustili přes nohup
. Nyní můžete klidně daný shell ukončit a příkaz poběží dál.
Nástroje: Tisk bez diskuse
Tiskni
Sdílej:
Neodpovidajici SSH session (prave treba kvuli background procesu) je take mozne ukoncit pomoci nasledujiciho navodu:
http://www.onlinehowto.net/Tutorials/SSH/SSH-tips-and-tricks-Dead-or-unresponsive-ssh-session/1271
Klicova je posledni veta:
"So to kill the dead ssh session you do Enter then Shift + ` and then . (dot)."
disown [ options ] [job ...]
If job is omitted, the most recently started or stopped background job is used. Takze proces nemusite stopovat, ale staci dodat hodnotu job daneho procesu.