![[personal profile]](https://www.dreamwidth.org/img/silk/identity/user.png)
к вопросу о власти крипто-линуксоидов.
Я так понимаю, что у тех, у кого реально есть возможность чего-нибудь накрутить в софте для госструктур, достаточно хорошая зарплата и вообще положение в обществе, чтобы их весь этот мрак, который мы тут массово обсуждаем, никак не интересовал.
Если есть ресурсы делать всякую опердень на обычных языках силами 100 человек, то нахер не нужно никакое ФП. Если есть возможность купить, впарить винды, заплатить откаты и еще при наваре остаться - нахер не нужен никакой линукс, вообще. И если есть зарплата, позволяющая все нужное покупать и еще и откладывать - нахер не нужны никакие революции, смены власти и прочее, на что дрочат все радикалы, от либералов до левых.
Я так понимаю, что у тех, у кого реально есть возможность чего-нибудь накрутить в софте для госструктур, достаточно хорошая зарплата и вообще положение в обществе, чтобы их весь этот мрак, который мы тут массово обсуждаем, никак не интересовал.
Если есть ресурсы делать всякую опердень на обычных языках силами 100 человек, то нахер не нужно никакое ФП. Если есть возможность купить, впарить винды, заплатить откаты и еще при наваре остаться - нахер не нужен никакой линукс, вообще. И если есть зарплата, позволяющая все нужное покупать и еще и откладывать - нахер не нужны никакие революции, смены власти и прочее, на что дрочат все радикалы, от либералов до левых.
no subject
Date: 2009-10-10 12:17 am (UTC)no subject
Date: 2009-10-10 12:21 am (UTC)мне пришлось как то глубоко вляпаться в вынь скрип хост. ничего позитивного не получил. возможно специфика.
зы. с тех пор и поселил у себя набор unixtools(tail, cat, grep, find, awk и прочее) и на работе.
no subject
Date: 2009-10-10 12:28 am (UTC)А теперь, внимание, элегантное решение в Windows! :)
forfiles /p c:\superpapka /s /c "cmd /c if not @fname==dontdelete.me del /q @file"
Вот и все А в Linux (да и вообще в никсах) без медленных комманд find, sed и ужасного синтаксиса не обойтись.
no subject
Date: 2009-10-10 12:53 am (UTC)получил мгновенный ответ вида "man find" :)
если подробнее:
max_posedon> кстати, forfiles в 100 раз медленнее find
max_posedon> а задача решается тупо
max_posedon> find + regexp -exec rm
max_posedon> без sed-а и без синтаксиса
насчет скорости конечно надо тестить... а в остальном... имхо не такое уж "элегантное" в Windows решение :)
no subject
Date: 2009-10-10 12:59 am (UTC)max_posedon> find + regexp -exec rm
Где тут тупо решение задачи? :))) Мне, пожалуйста, конкретную строку, да еще такую, чтобы на UNIX тоже работала :)))
На счет скорости forfiles - он в разы быстрее, чем известные мне 2 решения. В частности, я сравнивал с RHEL и HP-UX на очень быстрых машинках :)
no subject
Date: 2009-10-10 01:06 am (UTC)что то типа такого.
по скорости на "миллион в миллионе" очень не уверен что forfiles будет быстрее. но без теста утверждать не возьмусь. тут много чего влияет. и файловая система не в последнюю очередь (ну тем более что на отдельно взятых "миллион в миллионе" просто не реально создать).
no subject
Date: 2009-10-10 01:21 am (UTC)find: missing argument to `-exec'
Разбираться нет времени и желания :) Синтаксис уже ужасен - в Windows он предельно понятен - один параметр для определенного, конкретного действия. И ничего лишнего.
no subject
Date: 2009-10-10 08:41 am (UTC)на hp-ux проверить не могу - нету
no subject
Date: 2009-10-10 09:17 am (UTC)no subject
Date: 2009-10-10 09:32 am (UTC)no subject
Date: 2009-10-10 08:49 am (UTC)по крайней мере для меня, слабо разбирающегося в виндовых скриптах, интуитивно непонятны все эти /p /s и т.д.
и, кстати, ваше решение работает на всех версиях Windows ? хотя бы 32-хбитных ?
если нет, то в условии задачи вы не имеете морального права требовать работы скрипта-аналога даже на всех версиях линукса, не говоря уж о других разных *nix-системах.
PS моя позиция к фанатизму различных адептов очень близка к позиции ребе wildwildman.
no subject
Date: 2009-10-10 09:20 am (UTC)no subject
Date: 2009-10-10 09:47 am (UTC)битность я ввел для того, чтобы не тянуть некогда популярную Win 3.x, но если вы настаиваете... ;-)
т.е. получается, что для Win вы выбрали какое-то конкретное семейство, а для *nix требуете работы везде. неувязочка.
я вот сейчас тест буду проводить - очень уж ваша задачка занятной оказалась ;-)
если есть время - давайте проведем нормальные тесты, а не будем меряться пиписьками ;-)
У меня Win систем нет - поэтому на них проверить не смогу.
Предпосылки:
1. ФС - в RAM (чтобы не сказывалось влияние веников)
2. количество директорий - 1000
3. количество файлов - 1000 + dontdelete.me
количество уменьшено, т.к. лично у меня терпения не хватит, чтобы дождаться создания всего этого барахла. + не всякая ФС потянет.
и памяти не хватит - только что 2G на tmpfs было съедено только половиной ;-)
PS лучше поделитесь красивым скриптом для генерации такого чудовищного количества директорий/файлов - у меня пока что вот: http://pastebin.ca/1609460
no subject
Date: 2009-10-10 09:51 am (UTC)no subject
Date: 2009-10-10 05:12 pm (UTC)forfiles - не является частью шелла - это внешняя отдельная команда, исходя из описания, я не понимаю зачем они переименовали find и переделали опции?
find - зависит от производителя конкретного *nix и, опять-таки, не является частью шелла.
я использую gnu/find - как наиболее распространенного.
(no subject)
From:no subject
Date: 2009-10-10 01:07 am (UTC)раздел "Execute!"
no subject
Date: 2009-10-10 01:14 am (UTC)И потом, find - это известный тормоз, да еще и с rm!!! На миллионе файлов в HP-UX на машине с 64 гигабайтами памяти на HP9000-ке по дереву из миллиона файлов и каталогов find "гулял" почти 20 минут. Ну не пиздец, а? :)
В то же время, на вполне тривиальном ноуте с C2D процом и всего лишь 4 гигами памяти с Windows 7 x64, приведенное мною решение с forfiles отработало менее чем за 10 минут.
no subject
Date: 2009-10-10 01:19 am (UTC)no subject
Date: 2009-10-10 01:21 am (UTC)no subject
Date: 2009-10-10 01:20 am (UTC)А теперь, внимание, элегантное решение в Windows! :)
> Вот и все А в Linux (да и вообще в никсах) без медленных комманд find, sed и ужасного синтаксиса не обойтись.
Я готов решить вашу задачу в Linux быстрее чем на Windows, если мы поспорим скажем на ящик пива.
Но решить я готов её именно в Linux, а не во всех POSIX ОС или каких то ебанутых окружениях, не потому что не могу, а потому что вы заявили что именно в Linux оно не красиво и медленно.
Впрочем, вы тоже можете очень сильно улучшить своё решение прочитав man по find, в частности про -delete про -false и прочие -name* параметры.
P.S. На выходные уезжаю отдыхать, если не струсите продолжим общение в воскресенье вечером.
no subject
Date: 2009-10-10 01:23 am (UTC)no subject
Date: 2009-10-10 01:27 am (UTC)А ящик пива жаль, я надеялся, что вы всё таки уверены в своём утверждении и хотите себе ящик пива. :)
no subject
Date: 2009-10-10 01:33 am (UTC)А на счет тестирования - все основательно. На двух машинах были созданы структуры папок произвольной вложенности (но одинаковые), общее количество папок - 500 тыс., а файлов в них 1 млн. Причем 100 тыс. из этих файлов были с вышеуказанным именем и их нужно было удалить. Эксперимент прошел на ура - быстрее всех оказались forfiles, потом RHEL 5.1 бокс и в заключение HP-UX бокс. Я уже не говорю о том, что железяка с RHEL и HP-UX по сути намного производительнее, чем простой ноут с семеркой.
А на счет пива - не заморачивайтесь - я его не пью :) И потом, мы слишком далеко находимся, чтобы обмениваться ящиками пива :) Ну и в конце концов, вы пиво сами себе можете позволить :)
(no subject)
From:(no subject)
From:no subject
Date: 2009-10-11 01:04 pm (UTC)find /superpapaka -type f \! -name dontdelete.me -delete
find /superpapaka -type f \! -name dontdelete.me -exec rm -rf {} \+
Обратить внимание на плюс вместо точки с запятой - он форкнет rm минимальное количество раз, что существенно влияет на производительность.
Ну а требование, чтобы все юниксы работали одинаково, если одинаковый интерпретатор shell - звучит
бредовопо меньше мере странно. Ибо кроме шелла есть еще куча утилит, не встроенных в него. И find в их числе, это "внешняя команда" в терминах DOS/Windows. И в той же Windows набор этих внешних команд и их синтаксис тоже вполне отличается от версии к версии.no subject
Date: 2009-10-10 06:40 am (UTC)