И либо я что-то делаю не так, либо функция не асинхронна.
В частности, если вызвать fiber.sleep(10) то все работает как и запланированно (как понимаю: файбер приостанавливает свою работу и управление передается планировщику).
Если же, в том же куске кода, воспользоваться конструкцией os.execute('sleep 10') то в логе появляются сообщения:
main txn.c:586 W> too long WAL write: 1 rows at LSN 33785885: 10.004 sec
Параллельно у меня работают другие файберы, которые периодически пишут в vinyl.
В документации к tarantool ничего нет об асинхронности функции os.execute, но такое поведение выглядит странным.
Подскажите, может кто сталкивался с проблемой? Или это плановая работу функции?
PS: пример искусственный, вызываю я конечно не системный sleep, но длительно выполняющийся скрипт.
Да, os.execute синхронный, потому что это функция стандартной библиотеки Lua (его runtime ничего не знает про многозадачность в Tarantool). Попробуйте модуль popen.
Обсуждают сегодня