アプリケーションをサーバーレス対応にする 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として明記してください。

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

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

推薦する

nexusbytes: ロサンゼルスの高性能 VPS、トリプルネットワーク バックホール GTT、Ryzen 9 3900X+NVMe SSD

Nexusbytes は 2006 年に設立され、高品質の仮想ホスティングおよび VPS サービスを...

ユーザーエクスペリエンス分析に基づくウェブサイトページの最適化を改善するための戦略

ご存知のとおり、検索エンジンにおけるユーザー エクスペリエンスの重要性はますます高まっています。ユー...

インターネット製品の位置付けは盲目的に決めるべきではない

製品をどのようにポジショニングするか?製品の特徴とターゲット顧客に基づいて、製品を直接ポジショニング...

debian/ubuntu で独自の DNS を構築する

この記事の目的は、Bind9 を介して独自のサーバー (VPS) 上に独自の DNS サーバーを簡単...

福州警察はフィッシングサイトのソースコードを作成して販売していたグループを壊滅させた

記者が昨日、市公安局から得た情報によると、警察は6か月以上の綿密な捜査を経て、1日にフィッシングサイ...

購入するか構築するか: ハイブリッド クラウドのジレンマを解決する方法

今日、企業は急速に変化するテクノロジーに対応するために革新を期待し、クラウド コンピューティング テ...

Baiduウェブマスターツールの主な機能の長所と短所

ウェブサイト運営者にとって SEO データ分析の重要性は自明であり、現在インターネット上には数多くの...

VMware 仮想化プラットフォームの計画と設計ソリューション

1. 需要分析XX 銀行の現在の仮想化プラットフォームは 3 年前に構築され、運用が開始されました。...

Pinduoduo: 田舎が都市を囲んでいる!

「田舎から都市を包囲する」、政治史で試されてきたこの真理は、Pinduoduo によって商業戦争に再...

ipage - 無制限の米国ホスティングが 25% オフ / ドメイン名無料 / 3 年間 71 ドル

下のリンクから購入し、割引コードを入力して購入ページに入ります。1年間の購入で42ドル、3年間の購入...

ウェブサイトの最適化とプロモーション - ウェブサイトディレクトリへの登録

ウェブマスターの皆さん、外部リンクを構築する方法をいくつご存知ですか? それとも、友好的なリンクの交...

ウェブサイトのSEOは必ずしも静的である必要はない

国内では、多くの「SEO 専門家」が顧客の Web サイトに対して最初に行う診断結果は、ページを静的...

Baidu、Toutiao、Tencentがインターネット教育を狙っている!

百度と今日頭条が再び主要メディアの見出しを飾った。彼らが最後に一緒にいたのは4月26日だった。両者は...

abelohost: 著作権侵害の苦情を無視し、有名なオフショアホスティングプロバイダー「Alipay\WeChat」へのアクセス

最近のニュース:2017年にオフショアホスティングの運営を開始したこの商人は、支払い方法として「Al...