metaclass: (Default)
metaclass ([personal profile] metaclass) wrote2014-12-28 12:50 am

Везет на странности

В libuv (сишная либа для async io, используется в node.js, rust(вроде бы) и прочем таком) для реализации poll поверх IOCP используются недокументированные функции afd.sys - фактически, реверс-инжинеренный кусок кода из winsock.dll:

https://github.com/libuv/libuv/blob/v1.x/src/win/winsock.c#L477
https://github.com/piscisaureus/epoll_windows/blob/master/src/epoll.c#L721
http://x64blog.name/1306870455

Конечно же, тесты этого дела странным образом падают на 2003 винде.
Не то, чтобы мне сильно был нужен epoll на винде, да интегрированный в event loop этой либы, но безумные решения, попадающиеся под руки каждый день, задолбали уже.

[identity profile] berezovsky.livejournal.com 2014-12-28 12:56 am (UTC)(link)
Это, я так понимаю, всё идёт поиск адекватного аналога msmq. Придётся писать свой и оформлять коробочной либой!

[identity profile] vp.livejournal.com 2014-12-28 09:01 am (UTC)(link)
оно настолько хорошее?

[identity profile] dn2k.livejournal.com 2014-12-28 11:43 am (UTC)(link)
о, шизофреник березоффский снова посетил НАС!!!

[identity profile] falcrum.livejournal.com 2014-12-28 07:27 am (UTC)(link)
"C:\Program files" в коде не зашито?

[identity profile] anonim-legion.livejournal.com 2014-12-28 10:18 am (UTC)(link)
Я когда такое читаю

>для реализации poll поверх IOCP используются недокументированные функции afd.sys

Мне впоминаются строки известной песни:

Шанкр вместе с гонореей
Тоже выдумал еврей.
Только зачем? Вот не понятно!

[identity profile] metaclass.livejournal.com 2014-12-28 10:44 am (UTC)(link)
Зачем - примерно понятно, другой вопрос - как им совесть вообще разрешила это делать.
С учетом того, что информации про эти функции - ровно две страницы в гугле.

[identity profile] dn2k.livejournal.com 2014-12-28 12:08 pm (UTC)(link)
метакласс, почему тебя беспокоит чужая совесть? ты святой что ли?

[identity profile] dn2k.livejournal.com 2014-12-28 12:08 pm (UTC)(link)
а ну-ка пошел вон, умалищенный!!

[identity profile] slonopotamus.livejournal.com 2014-12-28 12:46 pm (UTC)(link)
Чем не устроила реализация poll(2) из gnulib?

[identity profile] metaclass.livejournal.com 2014-12-28 01:02 pm (UTC)(link)
Они пытаются select не использовать, т.к. он считается тормозным.

[identity profile] ng67.livejournal.com 2014-12-28 08:53 pm (UTC)(link)
Выучили бы уже 1С и успокоились...

[identity profile] ext_1684112 (from livejournal.com) 2014-12-29 04:25 am (UTC)(link)
Судя по аватарке, вы виндой не пользуетесь.

Аналогом poll в винде является именно IOCP. А эмуляция poll на select'е образца 1983 года будет весьма медленной, и по умолчанию не поддерживает больше 64 сокетов. После использования такого вот "кроссплатформенного" подхода господа линуксоиды начнут кричать про "тормозную винду".

[identity profile] slonopotamus.livejournal.com 2014-12-29 05:36 am (UTC)(link)
Винда сама по себе тормозная, куда не плюнь. Я тут жене ноутбук настраивал - 15 минут установка собственно винды (с флэшки на SSD), а потом ДЕВЯТЬ ЧАСОВ установки обновлений, в течение которых пользоваться девайсом было невозможно из-за выжранного проца и оперативки. Да я бы генту из исходников быстрее собрал.

[identity profile] octagram (from livejournal.com) 2015-01-02 07:35 pm (UTC)(link)
Зато в Линуксах, по крайней мере, в Debian, всё меняется, всё устаревает очень быстро. Не давно ставил Яндекс.Сервер, последний релиз которого был в 2010м году, и .deb есть для Линукса, но вот уже что–то не срастается, файлы, которые были установлены в rc.d что–то там ломают к чертям, пока их оттуда не удалишь. Так я и не понял, как по–нормальному Яндекс.Сервер в автозагрузку поставить, и что не так с теми rc скриптами, которые в комплекте с Яндекс.Сервером. А на Windows всё работает. А сколько лет DOS приложения работали на Windows, если учесть халявный Windows XP Mode в Windows 7? В Линуксе такой фанатичной преемственности нет.

Обратная сторона такой преемственности — это геморройность обновлений, да. Каждое обновление сопровождается хитрым логическим выражением, проверяющим версии DLL, записи в реестре, подключённое железо и ещё всякое такое.

Сделать так, как в Gentoo, не получится. Это, скорее, надо функционально–реактивное программирование применить, чтобы ускорить процесс. То есть, конфигурация компьютера — это поведение (то есть, функционально–реактивное значение). Конфигурация OS — это результат функции от конфигурации компьютера. И конфигурация компьютера, и функция от этой конфигурации могут инкрементально меняться со временем, вызывая реакции, по итогам которых результат перевычисляется с минимально требуемыми перевычислениями. Я пока не вижу, чтобы ФРП добралось до пакетных менеджеров, так что имеем то, что имеем.

[identity profile] lionet.livejournal.com 2014-12-29 10:21 am (UTC)(link)
Аналогом poll? Нет. poll и select — это одно и то же, в данном контексте. IOCP — аналог kqueue/epoll

[identity profile] ext_1684112 (from livejournal.com) 2014-12-29 10:26 am (UTC)(link)
Я в смысле аналога по предназначению. То есть, "если вам нужно очень быстрое и очень масштабируемое I/O, используйте %EntityName%".