Terraform を使用して Azure 仮想マシンを作成する

Terraform を使用して Azure 仮想マシンを作成する

以前、Terraform を使用して Proxmox 仮想マシンをデプロイする方法についての記事を書きました。それは、Core i7-8700 + 64G Homelab 上に構築された仮想マシン環境であり、常に私の実験環境となっていました。昨年 Microsoft MVP に参加して Azure クレジットを取得するまでは、特に最近はマルチクラスター環境でテストを行うことが多いため、より多くのリソースが必要になったり、イメージが頻繁にプルされたりするときには Azure 仮想マシンを使用することを選択しました。

Azure 上で仮想マシンを作成するときは、Web ページ CLI から始めましたが、複雑な構成が必要な場合は Terraform を使用するようになりました。この記事では、Terraform を使用して Azure 仮想マシンの作成を構成する方法について説明します。

Terraform[1]は、インフラストラクチャ・アズ・コード・ソフトウェア・ツールです。 Terraform を使用すると、インフラストラクチャ (仮想マシン、ロード バランサ、データベースなどのクラウド リソースとローカル リソースを含む) の望ましい状態を記述するコードを記述し、クラウド リソースとローカル リソースを安全、柔軟、効率的に構築、変更、バージョン管理できます。

前提条件

始める前に、次のものがあることを確認してください。

  • Azure アカウント
  • テラフォームCLI[2]
  • Azure CLI[3]

認証

自動化したいので、最初のステップは認証の問題を解決することです。結局、毎回手動で認証を行うのは非現実的であり、怠け者の特性に合わないのです。

TerraformのAzureプロバイダー[4]は5つの認証方法[5]をサポートしています。ローカルでのみ使用するため、この記事では認証にAzure CLI [6]を使用します。

認証を有効にするには、次のコマンドを実行します。認証する前に、https://portal.azure.com/#settings/directory にアクセスしてテナント情報を取得してください。

 az ログイン--テナント xxxx

コマンドを実行すると、ページが自動的にブラウザにジャンプし、認証プロセスが完了します。

認証が成功すると、コマンドを通じてアカウント情報を表示できます。

 az アカウント表示
{
"環境名" : "AzureCloud"
"ホームテナントID" : "00000000-0000-0000-0000-000000000000"
「id」 : 「00000000-0000-0000-0000-000000000000」
"isDefault" : true
「テナントによって管理」 : [ ]
「名前」 : 「Microsoft Azure スポンサーシップ」
「状態」 : 「有効」
"テナント ID" : "00000000-0000-0000-0000-000000000000" ,
「ユーザー」 : {
「名前」 : [email protected]
「タイプ」 : 「ユーザー」
}
}

複数のサブスクリプションがある場合は、現在のアカウントで使用されているサブスクリプションを設定する必要があります。

 az アカウントセット--サブスクリプション 00000000-0000-0000-0000-0000-000000000000

コード

このスクリプトは GitHub に送信されており、https://github.com/addozhang/terraform-azure-sample にアクセスして入手できます。

コードをローカルに複製します。

 gitクローンhttps://github.com/addozhang/terraform-azure-sample.git

スクリプトは次の 2 つの部分で構成されます。

  • リソース グループ: Azure 上のすべてのリソースは、リソース グループの下に作成されます。仮想マシンを作成する前に、リソース グループを作成するか、既存のリソース グループを使用する必要があります。リソース グループを作成すると、仮想ネットワークとサブネットも作成されます。
  • virtual-machine: 名前が示すように、仮想マシン リソースを作成します。

リソースグループを作成する

リソース グループ ディレクトリに移動し、次のコマンドを実行して Terraform を初期化し、Azure プロバイダーをダウンロードします。

テラフォーム初期化

入力パラメータは variables.tf ファイルで定義されます: リソース グループ名と場所。次のコマンドを実行してリソース グループを作成します。作成時にパラメータを使用して名前と場所を指定することもできます。

コマンドを実行して、Terraform コードを確認します。

テラフォーム検証

コードを適用するには、次のコマンドを実行します。

 # リソースグループディレクトリで実行
テラフォーム適用
# または
terraform を適用- var "name=demo" - var "location=eastasia"

作成されたリソースを表示するには、terraform state list​ を使用します。または、terrafor show を使用して詳細なリソース情報を表示します。

 terraform 状態リスト

azurerm_resource_group .デモ
azurerm_subnet .デモ
azurerm_virtual_network .デモ

仮想マシンの作成

仮想マシンのディレクトリに入り、コマンドを実行して初期化します。

テラフォーム初期化

仮想マシンを作成するためのパラメータがさらにあります。具体的なパラメータ定義については、variables.tf​ を参照してください。 terraform.tfvars ファイルを通じてパラメータ値を設定できます。ここで、使用するサブスクリプション ID を指定する必要があります。

コードとパラメータのチェックを実行します。

テラフォーム検証

コマンドを実行して仮想マシンを作成します。

 # 仮想マシンディレクトリで実行
テラフォーム適用

たとえば、仮想マシンの数 vm_count​ を 3 に設定し、上記のコマンドを実行した後にリソースを確認します。

 terraform 状態リスト

azurerm_linux_virtual_machine .demo [ 0 ]
azurerm_linux_virtual_machine .demo [ 1 ]
azurerm_linux_virtual_machine .demo [ 2 ]
azurerm_network_interface .demo [ 0 ]
azurerm_network_interface .demo [ 1 ]
azurerm_network_interface .demo [ 2 ]
azurerm_public_ip.デモ[ 0 ]
azurerm_public_ip.デモ[ 1 ]
azurerm_public_ip.デモ[ 2 ]

terraform show コマンドを使用すると、パブリック IP アドレスなどのリソースに関する詳細情報を表示できます。

参考文献

[1] テラフォーム: https://developer.hashicorp.com/terraform/intro

[2] Terraform CLI: https://developer.hashicorp.com/terraform/downloads

[3] Azure CLI: https://learn.microsoft.com/en-us/cli/azure/install-azure-cli

[4] Azureプロバイダー: https://registry.terraform.io/providers/hashicorp/azurerm/latest/docs

[5] 5つの認証方法: https://registry.terraform.io/providers/hashicorp/azurerm/latest/docs#authenticating-to-azure

[6] Azure CLIメソッド: https://registry.terraform.io/providers/hashicorp/azurerm/latest/docs/guides/azure_cli

<<:  【クラウドネイティブ】Apache Livy on k8s 解説と実践操作

>>:  Kubernetes Ingress はどのように機能しますか?

推薦する

Baidu のリッチメディア広告プラットフォームについて簡単に説明します: Hong Media

インターネットの初期の段階では、インターネット広告は画像やテキストを使用して表示されることがほとんど...

クラウド コンピューティング アプリケーションのアーキテクチャ例

アーキテクチャレビューこのプロセスで取り上げられるアーキテクチャの詳細は、オープンソース テクノロジ...

Googleの6回目のペナルティが確定

Google には、SEO 担当者が発見して研究するさまざまなペナルティやフィルタリング メカニズム...

クラウド コンピューティングが進化し、変化している 7 つの方法

[[392108]]サーバーなしでコンピューティングを行うことはできますか?それともコードなしでプロ...

一部の共同購入ウェブサイトは地元市場に目を向け、2012年に収益化を達成することを期待している。

エコノミック・ボイスによると、グループ購入業界は2012年に200億元規模に達するだろう。これは、M...

APPプロモーション:6大Androidアプリマーケットにおける基本的なASO最適化を徹底解説!

始めたばかりの頃は、オンラインでさまざまな記事やチュートリアルを読み、さまざまな分野を探索し、絶えず...

Hostgator: Spring、US cpanel 無制限ホスティング、30% 割引、中小規模の個人および商用ウェブサイト構築に最適

Hostgator の今春のプロモーション第 1 弾が始まりました。cPanel を使用した共有ホス...

大手企業がクラウド コンピューティングの覇権を競い合う! 5Gと疫病はどんな新たな変化をもたらすのでしょうか?

パソコンやインターネットに続き、クラウドコンピューティングが IT 業界に新たな改革の波を起こしまし...

コンテナとKubernetesがあらゆるものを実行できる可能性を秘めている理由

[[281973]] 「Kubernetes がダンプ トラックである理由」では、ダンプ トラックが...

UCloud AIサービスがソーシャルソフトウェアBluedの「win-win」実現を支援

モバイルインターネットの時代では、人々はソーシャルメディアなしでは生きられず、ほとんどの人が携帯電話...

hosteons: GTT などの回線を追加した後、VPS を再評価する

HosteonsはINAPデータセンターがGTTなどの回線を追加したことを公式に通知し、ウェブマスタ...

1人のSEOが独立してウェブサイトの最適化をサポートできますか?

今日、QQグループで、a5の毎日のQ&Aから「SEOを行う小さな会社で、1人だけで対応できま...

SaaS サービス プロバイダーのセキュリティを評価する 10 のポイント

ますます多くの企業にとって、SaaS (Software as a Service) は重要なビジネ...

Kafka エキスパートになるためのヒント: プロデューサーの詳細な実践概要

著者についてZhang Jinwei 氏は、Tencent Cloud のメッセージ キュー特別サポ...