Představena byla služba Raspberry Pi Connect usnadňující vzdálený grafický přístup k vašim Raspberry Pi z webového prohlížeče. Odkudkoli. Zdarma. Zatím v beta verzi. Detaily v dokumentaci.
Byla vydána verze R14.1.2 desktopového prostředí Trinity Desktop Environment (TDE, fork KDE 3.5). Přehled novinek v poznámkách k vydání, podrobnosti v seznamu změn.
Dnešním dnem lze již také v Česku nakupovat na Google Store (telefony a sluchátka Google Pixel).
Apple představil (keynote) iPad Pro s čipem Apple M4, předělaný iPad Air ve dvou velikostech a nový Apple Pencil Pro.
Richard Biener oznámil vydání verze 14.1 (14.1.0) kolekce kompilátorů pro různé programovací jazyky GCC (GNU Compiler Collection). Jedná se o první stabilní verzi řady 14. Přehled změn, nových vlastností a oprav a aktualizovaná dokumentace na stránkách projektu. Některé zdrojové kódy, které bylo možné přeložit s předchozími verzemi GCC, bude nutné upravit.
Free Software Foundation zveřejnila ocenění Free Software Awards za rok 2023. Vybráni byli Bruno Haible za dlouhodobé příspěvky a správu knihovny Gnulib, nováček Nick Logozzo za front-end Parabolic pro yt-dlp a tým Mission logiciels libres francouzského státu za nasazování svobodného softwaru do praxe.
Před 10 lety Microsoft dokončil akvizici divize mobilních telefonů společnosti Nokia a pod značkou Microsoft Mobile ji zanedlouho pohřbil.
Fedora 40 release party v Praze proběhne v pátek 17. května od 18:30 v prostorách společnosti Etnetera Core na adrese Jankovcova 1037/49, Praha 7. Součástí bude program kratších přednášek o novinkách ve Fedoře.
Stack Overflow se dohodl s OpenAI o zpřístupnění obsahu Stack Overflow pro vylepšení OpenAI AI modelů.
AlmaLinux byl vydán v nové stabilní verzi 9.4 (Mastodon, 𝕏). S kódovým názvem Seafoam Ocelot. Přehled novinek v příspěvku na blogu a v poznámkách k vydání.
Řešení dotazu:
find složka -iname *.pdf -exec evince {} +pokud používáš evince
find . -iname '*.pdf' -print0 | xargs -0 okular(případně můžeš okular nahradit za jiný prohlížeč)
xargs nohup okular &
.
Problém je v tom, že ampersand interpretuje shell, ze kterého se spouští find
. Zrovna před pár dny se tu přesně tento problém řešil.
Co se týká významu, co se zkusit podívat do manuálových stránek příslušných příkazů (find
, xargs
, nohup
)?
&
není v příkazu pro find
, ale za pajpou u příkazu xargs
.
find
(a xargs
) a vztahuje se k příkazu xargs
, ne k jednotlivým okularům.
find . -iname '*.pdf' -exec bash -c "okular3000 {} &" \;což spustí na pozadí tři okular3000 (ovšem v novém shellu - nikoliv jako jobs v tom aktuálním), ale nevidím způsob, jak stejným způsobem spustit okular s více argumenty, krom spuštění "find na pozadí" nebo "xargs na pozadí" což dělá skoro totéž:
find . -iname '*.pdf' -exec okular {} \+ & find . -iname '*.pdf' -print0 | xargs -O okular &má to vedlejší efekt že na pozadí jako job běží xargs (okular běží na pozadí jako potomek xargs), ale nepovažuji to za problém, spíš kvituji že mi neběží tři okulary. Find má ještě vedlejší efekt že když se vyčerpá počet argumentů tak čeká až okular zavřete a otevře zbytek, xargs defaultně také, ale lze mu vnutit třeba -N 1000, což by na otevření pár milionů pdf mohlo stačit :) Nebo máte nějaké lepší řešení jak spustit na pozadí okular s více argumenty, aniž by jako rodič běžel find či xargs?
Tento stav nastal, ale nenapadá mne proč by to měl být problém, pokud se použije okular, který umí otevřít víc pdf najednou.
V tom problém není. Problém je v tom, že některé příspěvky v diskusi vyznívaly tak, jako by to automaticky fungovalo s jakýmkoli prohlížečem a ampersand zajišťoval paralelní spouštění jednotlivých příkazů. Některé pak dokonce tvrdily zcela nepravdivé věci (jako např. ty nesmysly o fungování nohup
). Proto jsem se to pokusil uvést na pravou míru.
find . -iname '*.pdf' -print0 | xargs -0 nohup okular &-iname vyhledává podle jména a nerozlišuje velká-malá písmena -print0 vypíše výsledky, mezi ně dá znak null xargs a nohup jsou jiné programy, xargs vytváří příkazy ze stdin a nohup spouští program na pozadí tak aby ho nešlo ukončit ctrl-c
man find
man xargs
man nohup
nohup
nespouští program na pozadí (jak si lze snadno ověřit), ale funguje jako wrapper, díky kterému je ignorován signál HUP
(odtud jeho název), zatímco kombinace kláves Ctrl-C způsobí poslání signálu INT
, takže tou program bez problémů ukončíte (pokud ji neignoruje on sám, ale pak ho zase neukončí ani bez nohup
).
xargs: POZOR: Nezamýšleli jste, čistě náhodou, že se tak ptám, použít přepínač --null?
Neignorujte xargs
, chce si s vámi povídat, je to taky jen program a má své potřeby a city :D
Aneb jak občas říkám na školeních účastníkům: chce-li člověk spravovat Linux, měl by se naučit dvě věci, které ho praxe s Windows odnaučí:
nohup
je zbytečné, protože nezavřené IO také většině aplikací nevadí. Akorát se pak zbytečně zapisuje na disku a všude se válí nohup.out
.
Jsem z té otázky poněkud zmatený. Jako shell používám bash, stejně jako autor otázky.
SIGHUP nerozesílá bash, ale emulátor terminálu. Bash jej pouze rozešle dále pokud jej dostane (je to napsáno i v manu). Jako emulátor terminálu používám konsoli z KDE. Zkoušel jsem teď i xterm a ten SIGHUP zasílá taky. Projel jsem to i stracem a SIGHUP tam byl.
SIGTERM
či SIGKILL
a neklikám na křížky apod.), ukončuji v něm běžící shell (slovy exit
či spíš CTRL+D
, asi zvyk z ssh sessions). S ohledem na shopt huponexit = off
(to je to co jsem říkal že je u shellů obvyklé) bash SIGHUP
sám nepošle, a konsole pak také ne, a procesy na pozadí nic nedostanou a běží dál, zdědí je init. Pokud terminál ukončíte SIGTERM
či SIGKILL
pak ano, bash přepošle signály co dostane dál a nohup má smysl.
Tiskni Sdílej: