第9章. メッセージバスで街に出る
この作品はAIを使って翻訳されている。ご意見、ご感想をお待ちしている:translation-feedback@oreilly.com
この章では、イベントをアプリケーションの内部構造にとってより基本的なものにしていく。 図9-1のような、イベントはオプションの副次的なものである状態から、アプリケーションの内部構造をより基本的なものに変えていく。
図9-1. 前:メッセージ・バスはオプションのアドオンである
...図9-2のような状況になると、すべてがメッセージバスを経由するようになり、我々のアプリは根本的にメッセージプロセッサーへと変貌を遂げる。
図9-2. メッセージ・バスは今やサービス・レイヤへの主要な入り口である。
チップ
この章のコードはGitHubのchapter_09_all_messagebusブランチにある:
git clone https://github.com/cosmicpython/code.git cd code git checkout chapter_09_all_messagebus # or to code along, checkout the previous chapter: git checkout chapter_08_events_and_message_bus
新たな要求が新たなアーキテクチャへと導く
リッチ・ヒッキーは、実世界のプロセスを管理し、長時間稼動するソフトウェアを意味する「位置づけソフトウェア」について語る。例としては、倉庫管理システム、物流スケジューラー、給与計算システムなどがある。
物理的なオブジェクトと信頼できない人間という現実の世界では、常に予期せぬことが起こるからだ。例えばこうだ:
-
棚卸しの際、3つの
SPRINGY-MATTRESSesが屋根からの雨漏りによって水害を受けていることが判明した。 -
RELIABLE-FORKの荷物が必要書類に不備があり、税関で数週間留め置かれた。その後、3台のRELIABLE-FORKが安全性テストに不合格となり、廃棄された。 -
世界的なスパンコールの不足により、次のロットの製造が不可能となった。
SPARKLY-BOOKCASE.
このような状況では、すでにシステムに入っているバッチの数量を変更する必要性について学ぶ。 おそらく誰かがマニフェストの数字を間違えたか、トラックからソファが落ちたのだろう。企業との会話に従って、この状況を図9のようにモデル化する、1この状況を図9-3のようにモデル化する。
図9-3. バッチ量が変更されたとは、割り当て解除と再割り当てを意味する。
[ditaa, apwp_0903] +----------+ /----\ +------------+ +--------------------+ ...
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.
Read now
Unlock full access