目次
検証例
AWS CDK 構築例
複数の検証
AWS CDK 構築例を更新しました
AWS CDK スタックの検証
AWS CDK スタックの例
組み込み検証
結論

Python での AWS CDK 検証

Jan 20, 2025 pm 04:25 PM

AWS CDK Validation in Python

AWS CDK アプリケーションのライフサイクルには検証手順が含まれており、これについては公式ドキュメントの CDK アプリケーション合成の章で説明されています。

validate メソッドを実装するすべてのコンストラクトは自己検証され、正しいデプロイメントの状態にあることを確認できます。この段階で検証エラーが発生した場合は、通知されます。一般に、検証をできるだけ早く (通常は入力が取得されたらすぐに) 実行し、できるだけ早く例外をスローすることをお勧めします。検証を早期に実行すると、スタック トレースがより正確になり、コードが安全に実行を継続できるようになるため、信頼性が向上します。

TypeScript で AWS CDK 検証を処理する方法に関する優れた記事がいくつかありますが (下記リンク)、対応する Python の例は見つかりませんでした。 Python でいくつかの検証を作成した後、次の例はこれらの記事の例を補完します。

  • AWS CDK コンストラクトの検証チェック
  • 検証に AWS CDK を使用する (addValidation)

次の例は、AWS CDK v2.176.0 と Python 3.13.1 を使用して開発されました。

検証例

検証の実装は、エラー メッセージのリストを返す validate メソッドを使用して行われます。リストが空の場合、エラーはありません。複数のエントリは、この検証が失敗したさまざまな検証チェックに対応します。検証ロジックは @jsii.implements(IValidation) アノテーションが付けられたクラスにカプセル化されており、検証に正しい型であることを示します。この例では、検証に渡された Amazon S3 バケットがカスタム AWS KMS キーを使用しているかどうかのチェックがあり、Amazon S3 で使用されるデフォルトの暗号化と比較して、暗号化プロセスをより詳細に制御できます。

@jsii.implements(IValidation)
class KodlotS3KmsValidator:
    """检查S3存储桶是否使用自定义KMS密钥加密。"""

    def __init__(self, s3_bucket: s3.Bucket):
        self.s3_bucket = s3_bucket

    def validate(self) -> List[str]:
        error_messages: List[str] = []
        if self.s3_bucket.encryption_key is None:
            error_messages.append(f"存储桶必须使用自定义KMS密钥加密")
        return error_messages
ログイン後にコピー
ログイン後にコピー

AWS CDK 構築例

これは、スコープ ツリー内のコンストラクター ノードの add_validation メソッドを使用して単一の検証を追加する AWS CDK コンストラクトの基本的な例です。実装中に、カスタム AWS KMS キーが作成されたものの、Amazon S3 バケット構造のencryption_key パラメータに渡されなかったというバグがありました。

class KodlotS3Bucket(Construct):
    """带有验证的S3存储桶。"""

    def __init__(self, scope: Construct, construct_id: str, bucket_name: str) -> None:
        super().__init__(scope, construct_id)

        s3_kms_key = kms.Key(self, f"KodlotS3KmsKey{bucket_name.title()}")
        self.s3_bucket = s3.Bucket(
            self,
            f"KodlotS3{bucket_name.title()}",
            bucket_name=bucket_name,
            encryption_key=None,
        )

        self.node.add_validation(KodlotS3KmsValidator(self.s3_bucket))
ログイン後にコピー
ログイン後にコピー

このタイプのエラーは見落とされやすいため、検証が重要になります。この例を使用して CDK の構成またはデプロイメントを実行すると、次のエラーが発生します:

<code>RuntimeError: Error: 验证失败,错误如下:
  [KodlotS3Stack/KodlotBucket1] 存储桶必须使用自定义KMS密钥加密</code>
ログイン後にコピー
ログイン後にコピー

複数の検証

構成のさまざまな側面をテストする複数のバリデーターを使用することが可能であり、このような共通のパターンが見つかった場合は、それらをさまざまな構成に再利用できます。この例では、Amazon S3 バケットが静的 Web サイトホスティング用に誤って設定されていないことを確認するための検証チェックが追加されています。この場合、これはエラーになります。

@jsii.implements(IValidation)
class KodlotS3NotWebsiteValidator:
    """检查S3存储桶未配置为静态网站托管。"""

    def __init__(self, s3_bucket: s3.Bucket):
        self.s3_bucket = s3_bucket

    def validate(self) -> List[str]:
        error_messages: List[str] = []
        if self.s3_bucket.is_website:
            error_messages.append(f"存储桶不能用于静态网站托管")
        return error_messages
ログイン後にコピー
ログイン後にコピー

AWS CDK 構築例を更新しました

追加のバリデーターを使用して、Web サイトのホスティングが Amazon S3 バケット用に設定されているかどうかを確認するには、以下に示すようにサンプル CDK 構造を更新します。今回は、カスタム AWS KMS キーを渡さなかったという元のエラーが保持されます。さらに、website_index_document が誤って Amazon S3 バケット構造に渡され、静的ウェブサイトのホスティングに使用されることが示されています。

@jsii.implements(IValidation)
class KodlotS3KmsValidator:
    """检查S3存储桶是否使用自定义KMS密钥加密。"""

    def __init__(self, s3_bucket: s3.Bucket):
        self.s3_bucket = s3_bucket

    def validate(self) -> List[str]:
        error_messages: List[str] = []
        if self.s3_bucket.encryption_key is None:
            error_messages.append(f"存储桶必须使用自定义KMS密钥加密")
        return error_messages
ログイン後にコピー
ログイン後にコピー

今回、Amazon S3 バケットには 2 つの異なる問題があり、どちらも以下に示すように検証メカニズムによって報告されています。この例を使用して CDK の構成またはデプロイメントを実行すると、次のエラーが発生します:

class KodlotS3Bucket(Construct):
    """带有验证的S3存储桶。"""

    def __init__(self, scope: Construct, construct_id: str, bucket_name: str) -> None:
        super().__init__(scope, construct_id)

        s3_kms_key = kms.Key(self, f"KodlotS3KmsKey{bucket_name.title()}")
        self.s3_bucket = s3.Bucket(
            self,
            f"KodlotS3{bucket_name.title()}",
            bucket_name=bucket_name,
            encryption_key=None,
        )

        self.node.add_validation(KodlotS3KmsValidator(self.s3_bucket))
ログイン後にコピー
ログイン後にコピー

これは、クラウド インフラストラクチャ内のさまざまな構成の問題を収集し、何度も再実行して修正することなく、それらをすべて解決できるため、非常に強力です。

AWS CDK スタックの検証

検証は AWS CDK 構造に限定されず、AWS CDK スタック レベルにも追加できることを覚えておく価値があります。ここでは、たとえば、特定のスタックに不要なリソースが含まれていないかどうかを確認できます。スタックに AWS Lambda リソースを含めないという要件がある場合は、以下で説明する検証を使用してその要件をシミュレートできます。ノード構造の子を使用すると、Python の組み込み isinstance 関数を使用して、リソースが AWS CDK 関数のインスタンスであるかどうかを確認できます。

<code>RuntimeError: Error: 验证失败,错误如下:
  [KodlotS3Stack/KodlotBucket1] 存储桶必须使用自定义KMS密钥加密</code>
ログイン後にコピー
ログイン後にコピー

AWS CDK スタックの例

スタックに検証を追加するには、コンストラクターと同じ add_validation メソッドを使用します。 KodlotS3Stack は、AWS Lambda 関数を含めてはいけないスタックとして識別されるため、サンプル スタックの検証をテストするのに適した場所です。以下で説明するような、開発者が AWS Lambda 関数リソースを定義する開発中にエラーが発生した場合、検証が有効になります。

@jsii.implements(IValidation)
class KodlotS3NotWebsiteValidator:
    """检查S3存储桶未配置为静态网站托管。"""

    def __init__(self, s3_bucket: s3.Bucket):
        self.s3_bucket = s3_bucket

    def validate(self) -> List[str]:
        error_messages: List[str] = []
        if self.s3_bucket.is_website:
            error_messages.append(f"存储桶不能用于静态网站托管")
        return error_messages
ログイン後にコピー
ログイン後にコピー

この例の CDK 構成またはデプロイメントを実行すると、次のエラーが発生します:

class KodlotS3Bucket(Construct):
    """带有验证的S3存储桶。"""

    def __init__(self, scope: Construct, construct_id: str, bucket_name: str) -> None:
        super().__init__(scope, construct_id)

        s3_kms_key = kms.Key(self, f"KodlotS3KmsKey{bucket_name.title()}")
        self.s3_bucket = s3.Bucket(
            self,
            f"KodlotS3{bucket_name.title()}",
            bucket_name=bucket_name,
            encryption_key=None,
            website_index_document="index.html",
        )

        self.node.add_validation(KodlotS3KmsValidator(self.s3_bucket))
        self.node.add_validation(KodlotS3NotWebsiteValidator(self.s3_bucket))
ログイン後にコピー

組み込み検証

AWS CDK がクラウド インフラストラクチャの特定の側面に対するチェックをすでに提供しているかどうかを確認することも重要です。 Amazon S3 のコンテキストでは、バケット名を k1 に設定すると、名前の長さが不正になり、次の組み込みエラーが発生することがわかります:

<code>RuntimeError: Error: 验证失败,错误如下:
  [KodlotS3Stack/KodlotBucket1] 存储桶必须使用自定义KMS密钥加密
  [KodlotS3Stack/KodlotBucket1] 存储桶不能用于静态网站托管</code>
ログイン後にコピー

同様に、バケット名を k_1 として設定し、その中に不正なアンダースコア文字が含まれる場合、次の組み込みエラーが発生します:

@jsii.implements(IValidation)
class KodlotNoLambdaInStackValidator:
    """检查给定堆栈中未定义任何Lambda函数。"""

    def __init__(self, stack: cdk.Stack):
        self.stack = stack

    def validate(self) -> List[str]:
        error_messages: List[str] = []
        for construct in self.stack.node.children:
            if isinstance(construct, _lambda.Function):
                error_messages.append(f"堆栈不能包含任何Lambda函数")
        return error_messages
ログイン後にコピー

結論

AWS CDK 検証は、開発者が単体テストや統合テストと組み合わせて使用​​して、クラウド コンピューティング インフラストラクチャの全体的な品質を確認できる便利なメカニズムです。よくある構成ミスを見つけて標準を定義できると、異なるコンポーネント間で共有できる再利用可能な検証が可能になります。検証は、AWS CDK コンストラクトや AWS CDK スタックなど、AWS CDK によって定義されたさまざまなレベルで追加できます。 AWS CDK がいくつかの一般的な検証をキャプチャしていることは良いことです。これらはさまざまなクラウド サービスやリソースの基礎であり、常にチェックする必要があり、本番環境でデプロイメント エラーが発生する可能性が低くなります。

コード ブロックは保持され、画像は正しく参照されます。全体的な構造と意味は変わりませんが、より自然な流れになるよう、また直接の繰り返しを避けるために表現が変更されています。

以上がPython での AWS CDK 検証の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Python vs. C:曲線と使いやすさの学習 Python vs. C:曲線と使いやすさの学習 Apr 19, 2025 am 12:20 AM

Pythonは学習と使用が簡単ですが、Cはより強力ですが複雑です。 1。Python構文は簡潔で初心者に適しています。動的なタイピングと自動メモリ管理により、使いやすくなりますが、ランタイムエラーを引き起こす可能性があります。 2.Cは、高性能アプリケーションに適した低レベルの制御と高度な機能を提供しますが、学習しきい値が高く、手動メモリとタイプの安全管理が必要です。

Pythonの学習:2時間の毎日の研究で十分ですか? Pythonの学習:2時間の毎日の研究で十分ですか? Apr 18, 2025 am 12:22 AM

Pythonを1日2時間学ぶだけで十分ですか?それはあなたの目標と学習方法に依存します。 1)明確な学習計画を策定し、2)適切な学習リソースと方法を選択します。3)実践的な実践とレビューとレビューと統合を練習および統合し、統合すると、この期間中にPythonの基本的な知識と高度な機能を徐々に習得できます。

Python vs. C:パフォーマンスと効率の探索 Python vs. C:パフォーマンスと効率の探索 Apr 18, 2025 am 12:20 AM

Pythonは開発効率でCよりも優れていますが、Cは実行パフォーマンスが高くなっています。 1。Pythonの簡潔な構文とリッチライブラリは、開発効率を向上させます。 2.Cのコンピレーションタイプの特性とハードウェア制御により、実行パフォーマンスが向上します。選択を行うときは、プロジェクトのニーズに基づいて開発速度と実行効率を比較検討する必要があります。

Python vs. C:重要な違​​いを理解します Python vs. C:重要な違​​いを理解します Apr 21, 2025 am 12:18 AM

PythonとCにはそれぞれ独自の利点があり、選択はプロジェクトの要件に基づいている必要があります。 1)Pythonは、簡潔な構文と動的タイピングのため、迅速な開発とデータ処理に適しています。 2)Cは、静的なタイピングと手動メモリ管理により、高性能およびシステムプログラミングに適しています。

Python Standard Libraryの一部はどれですか:リストまたは配列はどれですか? Python Standard Libraryの一部はどれですか:リストまたは配列はどれですか? Apr 27, 2025 am 12:03 AM

PythonListSarePartOfThestAndardarenot.liestareBuilting-in、versatile、forStoringCollectionsのpythonlistarepart。

Python:自動化、スクリプト、およびタスク管理 Python:自動化、スクリプト、およびタスク管理 Apr 16, 2025 am 12:14 AM

Pythonは、自動化、スクリプト、およびタスク管理に優れています。 1)自動化:OSやShutilなどの標準ライブラリを介してファイルバックアップが実現されます。 2)スクリプトの書き込み:Psutilライブラリを使用してシステムリソースを監視します。 3)タスク管理:スケジュールライブラリを使用してタスクをスケジュールします。 Pythonの使いやすさと豊富なライブラリサポートにより、これらの分野で優先ツールになります。

科学コンピューティングのためのPython:詳細な外観 科学コンピューティングのためのPython:詳細な外観 Apr 19, 2025 am 12:15 AM

科学コンピューティングにおけるPythonのアプリケーションには、データ分析、機械学習、数値シミュレーション、視覚化が含まれます。 1.numpyは、効率的な多次元配列と数学的関数を提供します。 2。ScipyはNumpy機能を拡張し、最適化と線形代数ツールを提供します。 3. Pandasは、データ処理と分析に使用されます。 4.matplotlibは、さまざまなグラフと視覚的な結果を生成するために使用されます。

Web開発用のPython:主要なアプリケーション Web開発用のPython:主要なアプリケーション Apr 18, 2025 am 12:20 AM

Web開発におけるPythonの主要なアプリケーションには、DjangoおよびFlaskフレームワークの使用、API開発、データ分析と視覚化、機械学習とAI、およびパフォーマンスの最適化が含まれます。 1。DjangoandFlask Framework:Djangoは、複雑な用途の迅速な発展に適しており、Flaskは小規模または高度にカスタマイズされたプロジェクトに適しています。 2。API開発:フラスコまたはdjangorestFrameworkを使用して、Restfulapiを構築します。 3。データ分析と視覚化:Pythonを使用してデータを処理し、Webインターフェイスを介して表示します。 4。機械学習とAI:Pythonは、インテリジェントWebアプリケーションを構築するために使用されます。 5。パフォーマンスの最適化:非同期プログラミング、キャッシュ、コードを通じて最適化

See all articles