Wymyśliłem że chcę znaleźć w pewnym katalogu (i podkatalogach) największe pliki na serwerze NAS Austor (potem je będę kasował). Takie polecenie działa:
find . -type f -print0 | xargs -0 du -m "{}" | sort -n -r -k 1 | head -n 20
Chcę to wpisać do skryptu. Jednak w wyniku tego polecenia dostaję przed listą plików jak niżej:
du: {}: No such file or directory
(...)
du: {}: No such file or directory
56320 ./Msi-Ge75-NVME-1/C-root/!!!!!!Main-Storage/!!!!!WAŻNE-SCH/wazneschn.tc
30437 ./Evo-2T/D-root/!Malinowo/max2play/210115 Obraz m2p PI4-8GB, pilot ok, Kodi mrozi, przed update-upgrade/kingston-64G.img
(...)
Pytanie: jak elegancko zmodyfikować ww. polecenie abym nie dostawał w jego wyniku na początku: "du: {}: No such file or directory" powtórzonego ileś razy? Ja prawdę mówiąc nie wiem jak to zrobić ani elegancko ani nieelegancko. Przez nielegancko rozumiem: przekierowując błędy do /dev/null itp. Prośba o pomoc.
Inne podejście:
find . -type f -size +100M -exec du -m {} ';' | sort -n -r -k 1 | head -n 20
Powyższe nie wypluwa błędów, ale muszę się ograniczać do plików powyżej 100MB, bo ta metoda jest z 200 razy wolniejsza niż ta z pierwszego postu - jeśli zapuszcza się ją dla wszystkich plików czyli:
find . -type f -exec du -m {} ';' | sort -n -r -k 1 | head -n 20
Jeśli ktoś ma pomysł jak naprawić polecenie z pierwszego postu to prośba o odpowiedź
find . -type f -exec du -ah {} + | sort -hr | head -n 20
Może być 0,1 sekundy szybsze.