Byla vydána nová verze 1.12.0 dynamického programovacího jazyka Julia (Wikipedie) určeného zejména pro vědecké výpočty. Přehled novinek v příspěvku na blogu a v poznámkách k vydání. Aktualizována byla také dokumentace.
V Redisu byla nalezena a v upstreamu již opravena kritická zranitelnost CVE-2025-49844 s CVSS 10.0 (RCE, vzdálené spouštění kódu).
Ministr a vicepremiér pro digitalizaci Marian Jurečka dnes oznámil, že přijme rezignaci ředitele Digitální a informační agentury Martina Mesršmída, a to k 23. říjnu 2025. Mesršmíd nabídl svou funkci během minulého víkendu, kdy se DIA potýkala s problémy eDokladů, které některým občanům znepříjemnily využití možnosti prokázat se digitální občankou u volebních komisí při volbách do Poslanecké sněmovny.
Společnost Meta představila OpenZL. Jedná se o open source framework pro kompresi dat s ohledem na jejich formát. Zdrojové kódy jsou k dispozici na GitHubu.
Google postupně zpřístupňuje českým uživatelům Režim AI (AI Mode), tj. nový režim vyhledávání založený na umělé inteligenci. Režim AI nabízí pokročilé uvažování, multimodalitu a možnost prozkoumat jakékoliv téma do hloubky pomocí dodatečných dotazů a užitečných odkazů na weby.
Programovací jazyk Python byl vydán v nové major verzi 3.14.0. Podrobný přehled novinek v aktualizované dokumentaci.
Bylo oznámeno, že Qualcomm kupuje Arduino. Současně byla představena nová deska Arduino UNO Q se dvěma čipy: MPU Qualcomm Dragonwing QRB2210, na kterém může běžet Linux, a MCU STM32U585 a vývojové prostředí Arduino App Lab.
Multiplatformní open source voxelový herní engine Luanti byl vydán ve verzi 5.14.0. Podrobný přehled novinek v changelogu. Původně se jedná o Minecraftem inspirovaný Minetest v říjnu loňského roku přejmenovaný na Luanti.
Byla vydána nová stabilní verze 6.10 (YouTube) multiplatformního frameworku a GUI toolkitu Qt. Podrobný přehled novinek v poznámkách k vydání.
Řešení dotazu:
find -newerBt '2016-06-01' ! -newerBt '2016-06-02'
find . -type f | while read -r file do stat "${file}" | grep ^Change:\ ....-..-0.\ > /dev/null && echo ${file} done
find . -type f | while read -r file do #stat "${file}" stat "${file}" | grep ^Modify:\ ....-..-01\ > /dev/null && echo ${file} doneTeď můžu pokračovat ...
Nejsem si jistý, co přesně myslíte formulací "rozhodit do Daily a Monthly", ale není to něco jako
for f in *.7z; do dir=$(date -d @$(stat -c %Y $f) +%Y/%m/%d) mkdir -p "$dir" mv -vi "$f" "${dir}/" done
Přesně mám na mysli toto:
Každý den se mi zálohují servery na své disky (je to rychlé) a následně se ty jejich zálohy kopírují na linuxový backup disk.
Skripty na těch serverech (Windows/Linux) neumí standardně dělat Monthly, jen Daily. A předělávat všechny skripty by byla otrava.
Proto na cílovém záložním serveru chci zálohy stěhovat do složky Monthly, abych si mohl udržovat 2 měsíce záloh ( zbytek se postupně odmazává), ale 6 měsíců záloh měsíčních, vždy první den v měsíci.
Je to i z kapacitních důvodů a takto je to po mě vyžadováno.
Vše mám pořešené, jen to kopírování 1.v měsíci jsem doposud neměl a nějak jsem se v tom zrácel.
Řešení výše je funkční, tvoje vyzkouším.
Moc děkuji za pomoc. Už jsem se s tím trápil celkem dlouho (po chvilkách cca měsíc).
Třeba to někomu dalšímu pomůže taky.
/srv/backup/$HOSTNAME/$YYYY-$MM-$DD/
, takže hned je vidět ze kdy a odkud záloha je.
Co se stane, když se prvního ta záloha nepovede a bude chybět? Budeš mít pak dvouměsíční díru v zálohách? Spíš než dle data bych to řešil pořadím. Prostě první záloha v měsíci se zachová, ostatní se smažou. Takže pokud prvního zálohování selže, tak se zachová záloha z druhého a zbytek jde pryč.
Další otázka je, co se má stát, pokud zálohování přestane fungovat (nebo se servr odstraní). Smažou se postupně všechny zálohy, nebo prostě zůstane posledních šest měsíčních záloh? Co se stane s nejaktuálnější zálohou? Pokud by poslední záloha byla z 31. dne v měsíci a zachovala by se jen měsíční záloha z 1. dne v měsíci, znamená to ztrátu dat za poslední měsíc.
IN=/home/user for f in $IN/*.7z; do dir=$(date -d @$(stat -c %Y $f) +%Y/%m/%d) echo $dir #mkdir -p "$dir" #mv -vi "$f" "${dir}/" done
Výsledkem je výpis datumů ze všech souborů, které se na uvedené cestě nacházejí. Takže teď už jen vybrat ten d=01 a je to.
for f in ${IN}/*.7z; do if [ "$(date -d @$(stat -c %Y $f) +%d" = 01 ]; then ... fi done
for f in ${IN}/*.7z; do if [ "$(date -d @$(stat -c %Y $f) +%d)" = 01 ]; then echo $f fi done
Píše Line 2: [01 Command not found Line 2: [02 Command not found Line 2: [03 Command not found Line 2: [04 Command not found Line 2: [05 Command not found Line 2: [06 Command not found
Ještě je tam nějaká chyba, ale tomu nerozumím. Jaký příkaz?
Pokud opravím hranaté závorky, pak je výstup takto:
for f in ${IN}/*.7z; do if [ "$(date -d @$(stat -c %Y $f) +%d)"] = 01 ; then echo $f fi done
Píše Line 2: [01] Command not found Line 2: [02] Command not found Line 2: [03] Command not found Line 2: [04] Command not found Line 2: [05] Command not found Line 2: [06] Command not found
Kde je tam chyba? Já jí nevidím...
test
a je potřeba ji chápat jako příkaz, od kterého je první argument oddělen mezerou.)
Tak toto jsem netušil, že to není jen ohraničení příkazu a mezera je nutná. Zase jsem chytřejší, moc díky.
Vyřešeno, teď to chodí skvěle
Akorát nesmíte mít mezery v názvech souborů
Může. Při návrhu takových skriptů je vhodné na tyhle věci myslet. Chyby ve zpracování mezer je lepší pohlídat a odstranit hned v úvodu, protože jinak člověka jednou spolehlivě střelí do nohy. (Otázka není zdali, ale kdy.)
Tak mi přijde, že většina navrhovaných řešení nesplňuje některé důležité předpoklady, jako například:
Tady je řešení, které bych použil já, kdybych potřeboval najít soubory změněné prvního.
find -type f -printf '%Td %p\n' \ | while read line; do ((10#"${line%% *}" == 1)) && echo "${line#* }" done
Tiskni
Sdílej: