Внутренние узлы node.js. Как это на самом деле работает

Возможно, кто-то, кто реализовал модуль node.js, может объяснить протокол между очередью node.js, обрабатываемой в одном потоке, и блокирующими операциями ввода-вывода, которые будут выполняться модулем.

Я подозреваю, что это происходит примерно так:

  1. Поток node.js регистрирует обратный вызов в форме замыкания и сохраняет его с некоторым идентификатором корреляции.
  2. node.js вызывает метод (который должен выполнять блокировку ввода-вывода) для модуля и передает ему параметры метода и идентификатор корреляции.
  3. Метод модуля раскручивает поток и блокирует операцию ввода-вывода.
  4. когда операция ввода-вывода завершается, поток модулей перезванивает потоку node.js и передает ему результаты и идентификатор корреляции.
  5. Поток node.js находит хранимое закрытие обратного вызова по идентификатору корреляции и вызывает его, возвращая результат из модуля.

Вопрос 1: корректна ли приведенная выше последовательность?

Вопрос 2: Что такое очередь в node.js? Это та часть, где используется порт завершения epoll, kqueue или IO на windows? Это механизм обратного вызова для модуля, чтобы уведомить поток node.js о том, что некоторые операции ввода-вывода завершены? Как это работает?

2 ответа

Node.js не совсем справляется с этим, как вы и предполагали. Вместо этого он использует ОС для выполнения большей части асинхронного ввода-вывода. Он использует select/epoll/kqueue в зависимости от операционной системы. "Они" просто выдают вызов, и ОС перезванивает с потоком, фрагментами и т. Д. Что касается четной части этого, это встроено в V8, оно выполняет всю работу, привязывая обратные вызовы к определенным событиям так же, как это происходит в браузере. Наконец, вы можете взглянуть на libuv, который был написан вместе с узлом и теперь все поддерживается Joyent. Это открытый исходный код на Github, так что вы можете просматривать код, если вы действительно хотите детали =D

Я очень подозреваю, что Node.JS идет по тому же маршруту, что и Twisted, и использует только неблокирующие IO и greenlets. Потоки ОС кажутся довольно неэффективными для такого рода вещей.

Другие вопросы по тегам