AI アシスタントによる Azure ドキュメントの自動化
大規模環境での Azure リソース グループ (RG) の管理と文書化は、時間がかかり、複雑になる場合があります。しかし、どのようなリソースが存在するかだけでなく、それらがどのように相互に関連しているかを説明するドキュメントを生成するプロセスを自動化できたらどうでしょうか?
この記事では、単純な Python スクリプト が OpenAI や Azure OpenAI などの LLM (大規模言語モデル) をどのように活用できるかを検討します。 は、ARM テンプレートからの包括的なマークダウン ドキュメントの作成を自動化します。このツールを強力にしているのは、複雑なエージェント フレームワークや重いインフラストラクチャを使用しているのではなく、純粋な Python と Azure CLI や OpenAI の API などの確立されたツールを組み合わせていることです。他の AI プロバイダーや、Ollama または他の同様のツールを使用するローカル LLM と併用することもできます。
複雑なエージェント フレームワークは不要
よくある誤解は、LLM の力を効果的に利用するには精巧なエージェント フレームワークが必要であるということです。実際には、既存のツールと単純なスクリプトを使用して、強力な自動化されたワークフローを実現できます。このソリューションでは、以下を組み合わせます:
- Python: 一般的にインストールされ、広く使用されているスクリプト言語として。
- Azure CLI: Azure リソース グループから ARM テンプレートを取得します。
- OpenAI API 呼び出し: ARM テンプレートから人間が読めるドキュメントを生成します。
- マークダウン: ドキュメントの出力形式として。ナレッジ ベースに簡単に統合できます。
結果は?複雑なツールや AI を活用したオーケストレーションを必要とせずにドキュメントを作成する、クリーンで効率的なスクリプト。
Azure アシスタントのソース コード
ソース コードは、Github リポジトリ: itlackey/azure-assistants で入手できます。現在、これには、Azure CLI と OpenAI API を利用して ARM テンプレートからマークダウン ドキュメントを生成する単一の Python スクリプトが含まれています。興味がある場合、または必要がある場合は、他のタスクを自動化するための追加のツールやスクリプトでリポジトリが更新されることがあります。
スクリプトの仕組み
このツールの中心となるのは document_resource_groups.py スクリプトです。次の 4 つのことを行います:
- 現在の Azure サブスクリプション内のすべてのリソース グループを取得。
- az CLI を使用して、Azure リソース グループから ARM テンプレートをエクスポートします。
- 私たちはテンプレートを解析し、OpenAI 互換 API に送信します。
- LLM は、ナレッジ ベースに含める準備ができている マークダウン ドキュメントを生成するために使用されます。
リソースグループのリスト
最初のステップは、Azure サブスクリプション内のすべてのリソース グループを取得することです。これは、Python スクリプトから az CLI コマンドを使用して行われます。次に、それらをループして ARM テンプレートを取得します。
result = subprocess.run( ["az", "group", "list", "--query", "[].name", "-o", "tsv"], stdout=subprocess.PIPE, text=True, ) resource_groups = result.stdout.splitlines()
ARM テンプレートのエクスポート
ここでも、スクリプトは Azure CLI を使用して、現在のサブスクリプション内の各リソース グループの ARM テンプレートを取得します。これらのテンプレートには、ネットワークやセキュリティの設定を含む、すべてのリソースの詳細な構成情報が含まれています。
export_command = [ "az", "group", "export", "--name", resource_group_name, "--include-parameter-default-value", "--output", "json", ]
LLM を使用した要約
次に、スクリプトは要約のために ARM テンプレートを OpenAI (または Azure OpenAI) に送信します。ここで魔法が起こります。複雑なエージェントのワークフローに飛び込む代わりに、単純なシステム メッセージとユーザー プロンプトが、洞察力に富んだドキュメントを生成するのに十分なコンテキストを LLM に提供します。
response = client.chat.completions.create(model=model, messages=messages)
プロンプトは、予期される出力テンプレートを提供し、LLM に次のことを指示します。
- 各リソースをリストして説明します。
- リソースが互いにどのように関係しているかを説明します。
- 重要なネットワーク構成を強調表示します。
これにより、LLM は複雑なオーケストレーションを必要とせずに、構造化された読みやすいドキュメントを作成できます。
マークダウンドキュメントの生成
最後のステップは、リソース グループの詳細を含むマークダウン ファイルを生成することです。前付には、リソース グループ名、日付、タグなどのメタデータが含まれます。 AI が生成したドキュメントがドキュメントのコンテンツとして追加されます。
front_matter = f"---\n" front_matter += f'title: "{resource_group_name}"\n' front_matter += f"date: {date}\n" front_matter += f"internal: true\n"
Markdown は汎用形式であるため、この出力を多くのドキュメント システムやナレッジ マネジメント システムに簡単に統合できます。
AI プロンプトのカスタマイズ
このスクリプトの重要な機能は、LLM に送信されるプロンプトをカスタマイズできることです。ここでユーザーは希望する出力の種類を微調整できます:
- システム メッセージ: リソース、関係、ネットワーキングの説明に重点を置いたドキュメントを生成するように LLM をガイドします。
例:
You are an experienced Azure cloud architect helping to create reference documentation that explains the resources within an Azure Resource Manager (ARM) template. The documentation you create is intended for use in a knowledge base. Your role is to describe the resources in a clear and human-readable way, providing details on the following: - What resources exist in the ARM template. - How the resources relate to each other. - The purpose of each resource (if possible). - Highlighting network configurations and data locations such as storage accounts and databases. - Be sure to include IP addresses in the documentation when they are available. - Include information about virtual network peering. - It is very important that you also include any potential security issues that you may find.
- ユーザー プロンプト: 要約されるリソース グループに基づいて動的に生成されます。
例:
Provide detailed documentation of the following ARM template for resource group: {template_content} The purpose of this documentation is to...
これらのプロンプトを柔軟かつシンプルに保つことで、スクリプトは高品質のドキュメントを提供しながら過剰なエンジニアリングを回避します。
スクリプトの実行
注: このスクリプトを実行する前に、az CLI と python3 をマシンにインストールしておく必要があります。
スクリプトの設定と実行は簡単です:
- Azure にログインします: Azure CLI で認証されていることを確認します。
result = subprocess.run( ["az", "group", "list", "--query", "[].name", "-o", "tsv"], stdout=subprocess.PIPE, text=True, ) resource_groups = result.stdout.splitlines()
- スクリプトを実行してマークダウンドキュメントを生成します。
export_command = [ "az", "group", "export", "--name", resource_group_name, "--include-parameter-default-value", "--output", "json", ]
スクリプトは各リソース グループを処理し、その ARM テンプレートを生成し、出力ディレクトリにマークダウン ファイルを作成します。
出力例
スクリプトが生成するものの例を次に示します:
response = client.chat.completions.create(model=model, messages=messages)
この出力は簡潔、読みやすい、理解しやすいであり、まさに内部文書やナレッジベースのエントリに必要なものです。
結論
Azure Assistants は、既存のツール と基本的な Python スキルを使用して、LLM で強力な結果を達成する方法を示す完璧な例です。シンプルなスクリプトを Azure CLI および OpenAI の API と組み合わせることで、Azure リソース グループに関する明確で包括的なドキュメントを生成できる場合、複雑なエージェント フレームワークは必要ありません。
このツールは、適切なプロンプトと強固な構造を備えていれば、基本的なスクリプト スキルを持つ誰でも AI を活用してクラウド ドキュメントを自動化し、DevOps チームやインフラストラクチャ チームにとって貴重なアシスタントとなることを示しています。
以上がAI アシスタントによる Azure ドキュメントの自動化の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック











PythonはゲームとGUI開発に優れています。 1)ゲーム開発は、2Dゲームの作成に適した図面、オーディオ、その他の機能を提供し、Pygameを使用します。 2)GUI開発は、TKINTERまたはPYQTを選択できます。 TKINTERはシンプルで使いやすく、PYQTは豊富な機能を備えており、専門能力開発に適しています。

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

限られた時間でPythonの学習効率を最大化するには、PythonのDateTime、時間、およびスケジュールモジュールを使用できます。 1. DateTimeモジュールは、学習時間を記録および計画するために使用されます。 2。時間モジュールは、勉強と休息の時間を設定するのに役立ちます。 3.スケジュールモジュールは、毎週の学習タスクを自動的に配置します。

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

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

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

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

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