Skip to Main Content
ハンズオンNode.js
book

ハンズオンNode.js

by 今村 謙士
November 2020
Beginner to intermediate content levelBeginner to intermediate
536 pages
6h 42m
Japanese
O'Reilly Japan, Inc.
Content preview from ハンズオンNode.js

3章EventEmitterとストリーム

「2章 非同期プログラミング」で扱った非同期処理は、処理の要求とその結果が常に一対一でした。では、1回の要求に対して結果が複数回発生するような非同期処理は、どのように実装すればよいでしょうか。Promiseインスタンスは一度settled状態になったらそれ以降状態が変化しないため、そのような処理を実装するのには向きません。

本章では、この種の非同期処理を実現するためにNode.jsでどのような仕組みが用意されているかを見ていきます。

3.1 ObserverパターンとEventEmitter

「2章 非同期プログラミング」でnginxのイベントループについて触れましたが、Webサーバが接続を受け付ける処理は、1回の要求に対して結果が複数回発生する非同期処理と考えられます。ここでは、要求とはWebサーバの起動であり、結果とは起動したサーバに対するHTTPリクエストです。さらに、サーバから得たい結果はリクエストに関するものだけとは限りません。サーバの起動完了や停止、エラー発生のタイミングで何らかの処理を行いたければ、それらも結果として通知してもらう必要があります(図3-1)。

Webサーバの起動と関連する結果の通知

図3-1 Webサーバの起動と関連する結果の通知

Node.jsではhttpという標準モジュールを使ってWebサーバを起動できますが、このモジュールはObserverパターンを使ってこの要件を実現します。Observerパターンは、JavaScriptに限らずプログラミング言語一般でよく用いられるデザインパターンの1つです。このパターンでは、監視対象(Subject)に対して発生した何らかのイベントが、監視役(Observer)に逐一通知されます。ObserverはあらかじめSubjectに対して監視を行うための登録処理を行い、Subjectはイベント発生のタイミングで登録済みのObserverに対して通知処理を実行します。それぞれのSubjectには複数のObserverを登録できます。 ...

Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month,
and much more.
Start your free trial

You might also like

大規模データ管理 ―エンタープライズアーキテクチャのベストプラクティス

大規模データ管理 ―エンタープライズアーキテクチャのベストプラクティス

Piethein Strengholt, 村上 列
データサイエンス講義

データサイエンス講義

Rachel Schutt, Cathy O'Neil, 瀬戸山 雅人, 石井 弓美子, 河内 崇, 河内 真理子, 古畠 敦, 木下 哲也, 竹田 正和, 佐藤 正士, 望月 啓充
アルゴリズムクイックリファレンス 第2版

アルゴリズムクイックリファレンス 第2版

George T. Heineman, Gary Pollice, Stanley Selkow, 黒川 利明, 黒川 洋

Publisher Resources

ISBN: 9784873119236Other