クラウドネイティブ、モダナイゼーション、DXなどの文脈でもてはやされているマイクロサービス。全ての企業が取り組むべきものなのか。デメリットも含めて再整理しよう。
マイクロサービスの普及はクラウドネイティブやアジャイル開発などのトレンドと連動しており、特にコンテナといったデプロイ手段と密接に関係している。
O'Reillyが2020年に実施した調査によると、調査対象1500社の中でマイクロサービスを全く利用していない企業は約4分の1にすぎなかったという。だが利用している企業(約75%)で5年以上利用していたのは約10%にすぎない。つまり、大半の企業は5年以内にマイクロサービスを採用したことになる。
マイクロサービスは具体的な技術ではない。ソフトウェアアーキテクチャの一つであり、アプリケーションやサービスを設計する際のアプローチの一つだ。マイクロサービスではアプリケーションを1つのモノリシックなエンティティーではなく、独立してデプロイできる小さなサービスに分解する。そのサービスがコミュニケーションし合い、アプリケーションに必要な機能を提供する。
このアプローチには幾つかメリットがある。コンポーネントを個別にスケーリングできることから、スケーラビリティの向上が容易だ。アプリケーション全体をスケーリングするのではなく、需要が多い一部のコンポーネントのみをスケーリングする。その場合、スケーリングするコンポーネントの新しいインスタンスを起動してワークロードのバランスを取る。
マイクロサービスはアジャイル開発にも適している。マイクロサービスはコンポーネントのサイズが小さいので改善しやすく、迅速にコードを更新できる。開発者がコードを理解するのも容易だ。その結果、信頼性も高まる可能性がある。タスクの種類に適したプログラミング言語があるため、コンポーネントによって使う言語を変えることも可能だ。
コンポーネントにエラーが発生した際は適切に分離されることから、ダウンタイムが減る可能性があるのもメリットの一つだ。あるマイクロサービスでエラーが起きても、その結果としてアプリケーションやサービス全体がダウンする恐れは減少する。
マイクロサービスには考慮すべきデメリットもある。各コンポーネントの開発はシンプルになるとしても、アプリケーションやサービス全体の管理は複雑になるかもしれない。
マイクロサービスには、さまざまなコンポーネントのインスタンスが数十から数百関係する可能性がある。そのデプロイのスケールを問わず、管理の複雑さは伴う。インスタンス間のコミュニケーションを管理するだけでなく、各インスタンスが想定するパラメーター内で動作し、必要とするよりも多くのリソースを消費しないように監視しなければならない。必要よりも多くのリソースを消費している場合は問題の兆候かもしれない。
マイクロサービスはテストやデバッグが難しくなる恐れがある。マイクロサービスのバグの原因を追跡するには、それぞれのログが必要だ。各マイクロサービスを適切にテストするには依存関係のあるサービスのテストを全て完了しておかなければならない。そのためアプリケーション全体のテストはさらに難しくなる。
特にマイクロサービスのデプロイでは監視が重要だ。コンポーネントが分散する性質により、従来のアプリケーションよりも監視は複雑になる。監視システムはさまざまなコンポーネント間で絡み合う依存関係も監視できなければならない。
マイクロサービスの運用方法はインフラにも影響する。需要の増加に合わせた自動スケーリングをサポートするには、マイクロサービスの新しいインスタンス用のリソースをAPIコールでプロビジョニングできなければならない。これはクラウドのようなソフトウェア定義のインフラを意味する。
マイクロサービスに基づくアプリケーションやサービスをビルドする際にはデータも厄介な問題になる。もっと正確に言うなら、データをどこに保存するかが問題だ。それは、各マイクロサービスが独自のデータストアを保持している可能性が高いからだ。ただし、共有リポジトリへのアクセスが必要なアプリケーションもある。
サービスが異なればストレージの要件も異なる。業界の中には、NoSQLデータベースが最も適しているという意見もあれば既にSQLを使っているならSQLにこだわるべきだという意見もある。
データについては他にもさまざまな意見がある。1つのデータベースを複数のサービスが共有するのが最善のアプローチであり、そうすればデータベースのバックアップとリストアの手順を再利用できるという専門家もいる。それでは単一障害点を生み出す恐れがあり、マイクロサービスの考え方に反するとする専門家もいる。
マイクロサービスはあらゆる企業、あらゆる種類のアプリケーションに適しているわけではない。とはいえ、マイクロサービスの採用は拡大し続けている。それは、マイクロサービスによってサービスのデプロイをより簡単にアジャイル化できるためだ。これは多くの企業が求めていることだ。
独立系アナリストのクライブ・ロングボトム氏は次のように話す。「マイクロサービスへと向かうのは最先端企業が多い。最先端企業ほど、新しいアーキテクチャについてオープンに考える傾向が強い。マイクロサービスを成功に導くのは革新的なことで、行うべきことを全面的に考え直す必要がある」
言葉を変えれば、マイクロサービスは既存アプリケーションのリファクタリングや更新を試みるよりも、一から構築する「グリーンフィールド」デプロイの方が適している可能性がある。
既に述べたように、コンテナはマイクロサービスと関連付けて考えられることが多いが、マイクロサービスなどの分散デプロイを実装する方法の一つにすぎない。他にも、軽量の仮想マシンを使う方法や非仮想化サーバで実行する方法もある。サーバレスコンピューティングもマイクロサービスを実装する方法の一つだ。
恐らく、仮想マシンよりもコンテナの方が適している。コンテナはリソースの消費量が少なく、仮想マシンを新たに起動するよりもコンテナのインスタンスを新たに起動する方がはるかに高速だからだ。コンテナは技術的にも成熟しており、エコシステムも幅広い。
O'Reillyの調査では興味深い結果が出ている。マイクロサービスの取り組みに成功したと回答した企業は平均よりも高い割合でコンテナを使っており、失敗した企業は高い割合でコンテナを使っていなかったという。
この結果は、マイクロサービスの実装においてコンテナの方が低リスクであることを示している可能性がある。重要なのは、アプリケーションや要件に適した技術を選ぶことだ。
Copyright © ITmedia, Inc. All Rights Reserved.
基幹システム運用の課題を解消すべく、ノーコード開発ツールを導入する動きが加速している。数あるツールの中からどのようにツール選定を進めたらよいのか、またどのような課題を解決できるのか、具体的なツールも含めて解説する。
老朽化したシステムの刷新に向けノーコード開発ツールを導入した「東亜建設工業」。その活用により、ベンダーに依存することなく柔軟性と持続可能性の高いシステムの構築を推進できる体制を実現している。同社の取り組みを詳しく紹介する。
社内業務の徹底的な効率化を目指す「八千代工業」。最初に導入したRPAでは、紙に依存した業務への対応は難しかったが、これらをデジタル化するためにノーコード開発ツールを使ってアプリを開発し、大きな成果を挙げている。
IT技術の重要性が高まる一方、IT人材不足が加速している。その不足を埋めるため、自社の業務システムをノーコードで開発する動きが広がっているが、ノーコード開発を導入する際には、将来的な全社DXを考慮してツールを選ぶ必要がある。
業務効率化に有効なシステム化だが、プロコードやローコードによる開発では場合によって複雑なコーディングが必要となり、かえって新たな課題を生みかねない。そこで登場したのが、スキル不要で使えるノーコード開発ソリューションだ。
なぜ、「kintone」が大企業の「Fit to Standard」に効果的なのか (2025/3/7)
ノーコードは、負の遺産であるアナログ業務をなくせるのか (2024/11/12)
手間もコストもかかるGUIのテストはどうすれば自動化できるのか (2024/6/4)
「システム内製化」が失敗しがちなのはなぜ? “従来のやり方”では駄目な理由 (2024/5/15)
金融機関のモダナイゼーション 最適解に導くには (2024/3/29)
お知らせ
米国TechTarget Inc.とInforma Techデジタル事業が業務提携したことが発表されました。TechTargetジャパンは従来どおり、アイティメディア(株)が運営を継続します。これからも日本企業のIT選定に役立つ情報を提供してまいります。
「パーソナライゼーション」&「A/Bテスト」ツール売れ筋TOP5(2025年4月)
今週は、パーソナライゼーション製品と「A/Bテスト」ツールの国内売れ筋各TOP5を紹介し...
Cookieを超える「マルチリターゲティング」 広告効果に及ぼす影響は?
Cookieレスの課題解決の鍵となる「マルチリターゲティング」を題材に、AI技術によるROI向...
「マーケティングオートメーション」 国内売れ筋TOP10(2025年4月)
今週は、マーケティングオートメーション(MA)ツールの売れ筋TOP10を紹介します。