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

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

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

推薦する

「経済観察者」、SAP Greater China 社長 Ji Bingmeng 氏へのインタビュー |成功は夢と細部の完璧な組み合わせから生まれる

パンデミックのため、マーク・ギブスさんは今年の大半を香港の自宅で勤務し、11歳の娘と多くの時間を過ご...

ビッグ3がハイブリッドマルチクラウドゲームで勝てない理由

[[426312]]データの意味は洞察を提供することであり、洞察の意味はビジネスを促進することです。...

Fanhuan.comがTaobao.comのキーワードをホームページに最適化できる理由

2012年7月初旬、BaiduはTaobaoアフィリエイトに対する新たな禁止措置を開始し、これはBa...

プログラマーになりたいですか?あなたを孫悟空に変える 28 のオンライン学習ウェブサイト!

フルタイムのプログラマーになるために転職を検討している人、Web サイトを構築しようとしている人、ま...

Baidu 入札の図解分析 - 期間分析

多くの場合、Baidu の入札者はセグメント化された期間分析を実行しません。実際、入札コストは毎分毎...

ダブル11当日、速達で2400万個の荷物が集められたが、遅くとも20日まで発送されなかった。

国家郵政局は昨日、「ダブル11」のピーク時の速達注文数は約2400万個で、昨年より41%増加したと発...

キーワード密度がSEOランキング最適化に与える影響についての簡単な説明

ウェブページのキーワードの密度は、ウェブサイトのキーワードランキングに直接影響するという格言がありま...

SEO スキル: Baidu Share を使用してエンタープライズ ユーザー エクスペリエンスの信頼性を向上させる

Baidu Shareはかつて多くのSEO担当者、特にSEO分野のベテランであるZac氏に求められて...

G-Bank のクラウドネイティブ ビジネス レジリエンスの探求と実践

導入Bank Gは、フルスタッククラウドプラットフォームを基盤として、クラウドネイティブ技術の応用を...

1万語の解釈:2019年のブランドマーケティングキーワードトップ10!

2019 年のマーケティング業界を振り返ると、一言で言えば「マーケティング業界は変わった」です。画面...

権威の高いウェブサイトのためのSEOの方向性:コンテンツの質が勝利する

みなさんこんにちは。私はMuzi Chengzhouです。私は最近、検索エンジンの動向、特に Goo...

SEOにおける記事タイトルとページ説明の役割

2018年最もホットなプロジェクト:テレマーケティングロボットがあなたの参加を待っています今日、Xi...

Zhuanzhuan Sun Xuan: マイクロサービスアーキテクチャで中古品取引プラットフォームを構築する方法

中国電子技術標準化研究所が主催し、51CTOが主催する「第7回中国クラウドコンピューティング標準およ...

現在の SEO トレーニングはあなたにとってどのような価値がありますか?

SEO トレーニングは現在すでに非常に人気があります。インターネット初心者で SEO でお金を稼ぎた...

関連性の高い外部リンクの重み値が高い理由を分析する2つの側面

外部リンクはウェブサイトの最適化に欠かせない要素であるため、多くの友人が外部リンクに興味を持っている...