vak: (Default)
Serge Vakulenko ([personal profile] vak) wrote2025-02-18 06:23 pm

Асинхронный линукс

Народ, кто-нибудь уже поимел опыт с <linux/io_uring.h>? Как оно по жизни?

Неожиданно для себя обнаружил, что в Линуксе пять лет назад появилась крутая фича. А именно три системных вызова, реализующих эффективный асинхронный интерфейс ко всем сервисам ядра.
  • int io_uring_setup(unsigned entries, struct io_uring_params *p);
  • int io_uring_enter(unsigned fd, unsigned to_submit, unsigned min_complete, unsigned flags, sigset_t *sig);
  • int io_uring_register(unsigned fd, unsigned opcode, void *arg, unsigned nr_args);
Революционная штука, как я погляжу. Может коренным образом изменить подход к разработке приложений. Только сложновато для программиста выходит. Есть статьи про это дело.
lev: (Default)

[personal profile] lev 2025-02-19 08:05 pm (UTC)(link)
джизус крайст. а async io без поллинга никак? не признают богомерзких threads?
lev: (Default)

[personal profile] lev 2025-02-19 08:30 pm (UTC)(link)
пардон, опять туплю. контекст переключается медленне, чем приходят байты с конечного устройства?
Edited 2025-02-19 20:30 (UTC)
lev: (Default)

[personal profile] lev 2025-02-19 08:50 pm (UTC)(link)
интересно, i286 успевал обрабатывать внешний модем на com порту с 56к/сек (там же вроде бы прерывание на байт).
lev: (Default)

[personal profile] lev 2025-02-19 09:07 pm (UTC)(link)
ok, даже с фифо, если прерывание на половине буфера, это 7к/сек
lev: (Default)

[personal profile] lev 2025-02-19 09:27 pm (UTC)(link)
все таки, меня удивляет такое медленное переключение контекста.

[personal profile] sassa_nf 2025-02-20 08:27 pm (UTC)(link)
It's not just speed of context switch. If you have 10M connections, you just can't have thread-per-connection. So you need ways of processing orders of magnitude more connections than you have threads.