アプリケーションをサーバーレス対応にする 3 つの方法

アプリケーションをサーバーレス対応にする 3 つの方法

[51CTO.com クイック翻訳] 従来の PaaS または IaaS 環境で実行されるアプリケーションと比較すると、サーバーレス プラットフォーム上のアプリケーションには、パフォーマンス、ストレージなどの点で独自の要件があります。

AWS、Microsoft、Google を含むすべての主要なクラウド プロバイダーは、一連の関数を使用してユーザーが単純なアプリケーションや非常に複雑なアプリケーションを組み立てることができるサーバーレス プラットフォームを立ち上げました。しかし、このプラットフォーム上でクラウド アプリケーションを正常に実行するには、開発チームが設計プロセスを改善する必要があります。

[[231651]]

サーバーレス アプリケーションを構築するときに開発者が従うべき重要な原則がいくつかあります。

  • 小さな独立したアプリケーション コンポーネントを開発します。
  • ステートレス関数を実装します。
  • 短期間の一時的な機能を計画します。

1. より小型で独立したコンポーネント

基本的に、サーバーレス関数は単一のタスクを実行するように設計されています。そのため、開発チームは機能を小さく保ち、これらの独立したアプリケーション コンポーネントを中心に開発プロセスを調整する必要があります。

関数をトリガーするイベントの種類に基づいて、関数を独自のライブラリに分割することをお勧めします。基本的に、開発者はイベントに応答するように各機能を最初から設計する必要があります。同じイベントが複数の関数をトリガーする場合は、それらを同じ関数ライブラリに含めます。これにより、開発者は関数をトリガーしたイベントに基づいて関数を識別しやすくなります。

個々の機能には、開発環境、テスト環境、運用環境全体で機能が一貫して起動されるようにするための構成データも含める必要があります。また、npm や webpack などのツールを使用して、各関数内の依存関係を宣言および分離することも重要です。

2. ステートレスを選択

開発チームは、関数の状態がアプリケーション自体の外部に保存されるステートレス サービスとして関数を実装することを検討する必要があります。構成データの一部として管理され、リポジトリ内の関数とともに保存されるデータストアとデータベースを参照するように関数を構成できます。

一部のサーバーレス プラットフォームでは、関数の呼び出し間で保持されるローカル ストレージが提供されます。開発者はより複雑な関数にこれを使用したくなるかもしれませんが、このローカル ストレージは関数呼び出し間で常に保持されるわけではなく、保持された場合でも一貫性がない可能性があります。

可能な場合は常に、サポート サービスを使用して、ステートフル データをデータベース、別のストレージ領域、またはキャッシュに保存します。サポート サービスとは、キャッシュ サービス (Memcached など)、データ ストア (CouchDB など)、データベース (MySQL など) など、関数が通常の操作の一部として使用するネットワーク経由の外部サービスです。

3. 一時的な計画

サーバーレス関数の利点の 1 つは、PaaS、コンテナー、仮想マシンで実行される大規模なアプリケーションでは数秒または数分かかるのに対し、数ミリ秒で起動でき、同様にすばやく停止できることです。したがって、需要に対応するために多数の関数を追加したり、並列実行されている関数を連携させて計算を完了し、計算が完了したら関数を停止したりすることが容易になります。

実際、サーバーレス アプリケーションは、本質的に一時的なものです。

つまり、サーバーレス プラットフォームのメリットを最大限に活用するには、開発者は、通常アプリケーションにバンドルされているコンポーネントの多くを関数のコア ロジックから削除する必要があります。開発者は次のことを行う必要があります。

  • ウォームアップ機能に必要なデータ ソース。
  • 外部のログ記録および追跡インフラストラクチャの構築。そして
  • セキュリティを管理します。

予熱

関数をウォームアップするには、関数をデプロイする前に、関数がデータベースと通信するために必要なインフラストラクチャを設定する必要があります。

これを行うには、関数ハンドラーをコアロジックから分離します。寒い日に車をアイドリングさせてパフォーマンスを向上させるのと同じように、アイドル イベント ハンドラーは、関数が呼び出されると最適なパフォーマンスで実行されるようにします。 AWS CloudFormation や Azure Event Hubs などのツールがウォームアッププロセスをサポートします。

外部ログとトレース

関数は迅速かつ適切にシャットダウンできる必要があります。サーバーレス プラットフォームには組み込みのローカル ストレージが含まれていますが、外部のログ記録およびトレース サービス (サーバーレス フレームワーク自体に組み込まれています) を構成するか、関数の実行中にログ データを収集して保存するためのカスタム ツールを設定することが重要です。

AWS X-Ray や Azure Application Insights などのツールは、ログ記録とトレースに役立ちます。

安全性

サーバーレス アプリケーションは、ハッカーにとって別の潜在的な攻撃ベクトルとなります。適切なセキュリティ対策が講じられていない場合、ハッカーが機能を有効にして機密データにアクセスする可能性があります。開発者は、他のアプリケーションがタスクを実行するために必要な最小限のアクセス権のみを持つように機能を保護する必要があります。

原題: サーバーレス プラットフォーム向けにアプリケーションを準備する 3 つの方法、著者: George Lawton

[51CTOによる翻訳。パートナーサイトに転載する場合は、元の翻訳者と出典を51CTO.comとして明記してください。

<<:  クラウドコンピューティングは一般の人々とはあまり関係がないのでしょうか?実際、誰もがそれなしでは生きていけません。

>>:  オープンソースモデルにおけるクラウドコンピューティングとビッグデータの現状

推薦する

トレンドに囚われた

喬さんは今でも、大学時代に同級生と靴の投機をした経験を思い出すと、「値段が上がれば売る。上がらなけれ...

SEO ブログがなぜ人気がないのかご存知ですか?

なぜこのようなタイトルを思いついたのか不思議に思うかもしれません。あなたのブログは SEO ブログで...

x5x: 月額わずか 1.5 ユーロで無制限の VPS、ロシア、オランダ、米国

x5x.ru は、2006 年から運営されているロシアのホスティング会社です。その事業には、仮想ホス...

タグのランキングのヒントと最適化のアイデア

ショートビデオ、セルフメディア、インフルエンサーのためのワンストップサービス1. タグにあまり人気の...

クラウド マスター データ管理 (MDM) がエンタープライズ IT の次の「爆発点」となるのはなぜでしょうか?

以前、私は有名企業の CIO にインタビューしました。当初のトピックはハイブリッド クラウドとマルチ...

VMware が世界のデジタル インフラストラクチャに本質的なセキュリティを提供

VMware (NYSE: VMW) は、VMworld 2020 において、世界のデジタル インフ...

IDC: パブリッククラウド支出は2020年第1四半期に101億ドルに達した

[[331458]]インターナショナル・データ・コーポレーション(IDC)が6月26日に発表したレポ...

3分かけて検索エンジンの祖先について知ろう

サンシャイン ハウスが検索エンジンとは何かと尋ねた場合、一般的に 2 つの答えがあります。1. それ...

報告書によると、クラウドは将来の成長にとって「極めて重要」

Spark ビジネス グループ内のクラウド専門家である CCL の新しい調査によると、「コスト」と「...

私の国のクラウドコンピューティング市場は2023年に3000億人民元を超えると予想されています

近年、我が国はデジタル経済の構築において大きな成果を上げています。新しいインフラストラクチャの重要な...

水曜日は穏やかではない:今週のKステーションの嵐がやってくる

朝早くにウェブサイトのインデックスを見て、おお、金塊だ!と思った。私が持っていた企業ウェブサイトのホ...

微博マーケティングの4大ブランド価値

ショートビデオ、セルフメディア、インフルエンサーのためのワンストップサービスデジタル時代の重要なマー...

ブログ開発はどんな困難に直面しますか?ボトルネック期間を突破するには?

インターネット上では、Zac の個人ブログ「SEO Post Every Day」、Lu Songs...