18
8

TROCCO®のTerraform Provider(β版)ができたので最速で触ってみる

Last updated at Posted at 2024-08-09

はじめに

Terraformが使えるようになりました!!!(心の底からの叫び)

TROCCO®はデータ基盤の総合支援SaaSとして提供されてきて、これまでその設定をコード管理したいという要望は何度もお伺いしてきました。Git連携の機能はあったものの、リソースを変更する機能はなく、上手くお応えできないことに申し訳なく思っていました。

しかし、ついに、待ちに待った、Terraform Provider(β版)がリリースされました!!!!!(大拍手)

嬉しすぎて泣きそうになってしまったので、最速で触ってみた記事を書くことにした次第です!!!!!

  • Advancedプランから利用できる、TROCCO APIの利用が前提になります。
  • 現時点ではBigQueryのデータマート定義のみに対応しています。
  • β版ですので、今後仕様が変更になる可能性があります。
  • 以下の記載はWindows環境のものになるので、Macの方は適宜読み替えてください。

事前準備

Terraformのインストール

Terraformをインストールし、PATHを通して実行可能にしておきます。

TROCCO API KEYを発行する

TROCCO®にログインし、外部連携 > TROCCO API KEYからAPI KEYを発行しておきます。

Terraform Providerを使ってみる

TROCCO®のTerraform Providerにアクセスします。

image.png

※Terraformの命名規則でtroccoが小文字になっています(笑)

Terraformの初期設定をする

利用するディレクトリでmain.tfファイルを作成し、以下のファイルを作成します。

terraform main.tf
terraform {
  required_providers {
    trocco = {
      source = "registry.terraform.io/trocco-io/trocco"
    }
  }
}

provider "trocco" {
  region  = "japan"
}

コマンドプロンプトを起動し、set TROCCO_API_KEY={TROCCO_API_KEY}で環境変数にTROCCO API KEYを設定します。

続いて、terraform initでTerraformを初期化します。

Initializing the backend...
Initializing provider plugins...
- Finding latest version of trocco-io/trocco...
- Installing trocco-io/trocco v0.1.1...
- Installed trocco-io/trocco v0.1.1 (self-signed, key ID 4AD358D3E1334E66)
Partner and community providers are signed by their developers.
If you'd like to know more about provider signing, you can read about it here:
https://www.terraform.io/docs/cli/plugins/signing.html
Terraform has created a lock file .terraform.lock.hcl to record the provider
selections it made above. Include this file in your version control repository
so that Terraform can guarantee to make the same selections by default when
you run "terraform init" in the future.

Terraform has been successfully initialized!

You may now begin working with Terraform. Try running "terraform plan" to see
any changes that are required for your infrastructure. All Terraform commands
should now work.

If you ever set or change modules or backend configuration for Terraform,
rerun this command to reinitialize your working directory. If you forget, other
commands will detect it and remind you to do so if necessary.

これで初期設定は完了です。

なお、VSCodeで作業をする場合、HashiCorp Terraformの拡張機能を入れておくと便利です。

データマート定義を作成する

はじめに、Documentationを参考に、データマート定義を作成してみましょう。

Example UsageにあるMinimumでリソースを作成しましょう。記載の値をコピーし、先ほどのmain.tfファイルに追記します。このとき、bigquery_connection_idは自身の環境で有効なものを利用します。接続情報の編集画面を開き、URLに表示されるものがIDになります。

terraform main.tf
terraform {
  required_providers {
    trocco = {
      source = "registry.terraform.io/trocco-io/trocco"
    }
  }
}

provider "trocco" {
  region  = "japan"
}

resource "trocco_bigquery_datamart_definition" "minimum" {
  name                     = "example_minimum"
  is_runnable_concurrently = false
  bigquery_connection_id   = {BIGQUERY_CONNECTION_ID}
  query                    = "SELECT * FROM tables"
  query_mode               = "insert"
  destination_dataset      = "dist_datasets"
  destination_table        = "dist_tables"
  write_disposition        = "append"
}

保存して、terraform applyのコマンドを実行します。新しいリソースを作成するとなっている!!!

image.png

yesと記入してEnterを押すと・・・

image.png

できている!!!まじか!!!最高!!!

image.png

データマート定義を変更する

先ほどの設定情報を変更してみます。

terraform main.tf
terraform {
  required_providers {
    trocco = {
      source = "registry.terraform.io/trocco-io/trocco"
    }
  }
}

provider "trocco" {
  region = "japan"
}

resource "trocco_bigquery_datamart_definition" "minimum" {
  name                     = "example_minimum_hoge" # _hogeを追記する
  is_runnable_concurrently = false
  bigquery_connection_id   = 919
  query                    = "SELECT * FROM tables WHERE fuga = null" # WHERE fuga = nullを追記する
  query_mode               = "insert"
  destination_dataset      = "dist_datasets"
  destination_table        = "dist_tables"
  write_disposition        = "truncate" # truncateに変更
}

terraform applyを実行します。

どこがどう変更されるよ、ということが表示されます!

image.png

yesで実行されます!1 changedで変更されたのが分かります。

image.png

確かに変更されています!すごい。クエリまでキャプチャが届かなかったのはご愛嬌ということで(笑)

image.png

既存のデータマート定義を取り込む

これは現時点でまとめてやる方法がないのですが、既存の1つの設定は一応こういう手順で取込できるよ、ということでご紹介です。

事前にGUIから設定を作成しておきます。

image.png

合わせて、main.tfにリソース名のみを追加しておきます。

terraform main.tf
terraform {
  required_providers {
    trocco = {
      source = "registry.terraform.io/trocco-io/trocco"
    }
  }
}

provider "trocco" {
  region = "japan"
}

resource "trocco_bigquery_datamart_definition" "minimum" {
  name                     = "example_minimum_hoge" # _hogeを追記する
  is_runnable_concurrently = false
  bigquery_connection_id   = {BIGQUERY_CONNECTION_ID}
  query                    = "SELECT * FROM tables WHERE fuga = null" # WHERE fuga = nullを追記する
  query_mode               = "insert"
  destination_dataset      = "dist_datasets"
  destination_table        = "dist_tables"
  write_disposition        = "truncate" # truncateに変更
}

# 取り込みたい設定用のリソースを追記する
resource "trocco_bigquery_datamart_definition" "import_test" {
}

取り込みたいデータマート定義のID(URLの末尾)をもとに、取り込むためのコマンドを実行します。

terraform import "trocco_bigquery_datamart_definition.import_test" 47661

main.tfに記載するために、terraform state show "{リソースID}"で取り込んだ情報を取得します。

image.png

この設定情報をmain.tfに転記し、terraform applyを実行すると・・・read-onlyの値が入力されているよと怒られます(笑)

image.png

これは、main.tfにあるのは設定したい情報で、terraform.tfstateの過去の適用時の情報を見ながら新規作成するのか更新するのかといった判断をするのに対して、tfファイル内にIDまで振られてしまっているからになります。

そこで、怒られたIDを削除してterraform applyしてyesとすると、既存の設定をTerraformの管理下におけるようになります!!!

データマート定義の削除

main.tfから追加した設定を除外し、再度terraform applyします。

trocco_bigquery_datamart_definition.minimum: Refreshing state... [name=example_minimum_hoge]
trocco_bigquery_datamart_definition.import_test: Refreshing state... [name=import_test]

Terraform used the selected providers to generate the following execution plan. Resource actions are indicated with the following symbols:
  - destroy

Terraform will perform the following actions:

  # trocco_bigquery_datamart_definition.import_test will be destroyed
  # (because trocco_bigquery_datamart_definition.import_test is not in configuration)
  - resource "trocco_bigquery_datamart_definition" "import_test" {
      - bigquery_connection_id   = 919 -> null
      - destination_dataset      = "import" -> null
      - destination_table        = "dest_table" -> null
      - id                       = 47661 -> null
      - is_runnable_concurrently = false -> null
      - name                     = "import_test" -> null
      - query                    = <<-EOT
            SELECT
              *
            FROM
              import.ref_table
        EOT -> null
      - query_mode               = "insert" -> null
      - resource_group_id        = 1142 -> null
      - write_disposition        = "truncate" -> null
    }

Plan: 0 to add, 0 to change, 1 to destroy.

Do you want to perform these actions?
  Terraform will perform the actions described above.
  Only 'yes' will be accepted to approve.

  Enter a value: yes

trocco_bigquery_datamart_definition.import_test: Destroying... [name=import_test]
trocco_bigquery_datamart_definition.import_test: Destruction complete after 0s

Apply complete! Resources: 0 added, 0 changed, 1 destroyed.

これでdestroyされ、Terraformで管理されていた設定が削除されました!

細かい設定もできるよ!!!

詳細はTerraform Providerに記載されていますが、細かい設定も利用することができます!!!

カスタム変数も設定できます!

  custom_variable_settings = [
    {
      name  = "$string$",
      type  = "string",
      value = "foo",
    },
    {
      name      = "$timestamp$",
      type      = "timestamp",
      quantity  = 1,
      unit      = "hour",
      direction = "ago",
      format    = "%Y-%m-%d %H:%M:%S",
      time_zone = "Asia/Tokyo",
    }
  ]

スケジュールも設定できます!!!

  schedules = [
    {
      frequency = "hourly"
      minute    = 0
      time_zone = "Asia/Tokyo"
    },
    {
      frequency = "daily"
      hour      = 0
      minute    = 0
      time_zone = "Asia/Tokyo"
    },
    {
      frequency   = "weekly"
      day_of_week = 0
      hour        = 0
      minute      = 0
      time_zone   = "Asia/Tokyo"
    },
    {
      frequency = "monthly"
      day       = 1
      hour      = 0
      minute    = 0
      time_zone = "Asia/Tokyo"
    }
  ]

通知設定もできます!!!

  notifications = [
    {
      destination_type  = "slack"
      slack_channel_id  = 1
      notification_type = "job"
      notify_when       = "finished"
      message           = "@here Job finished."
    },
    {
      destination_type  = "email"
      email_id          = 1
      notification_type = "record"
      record_count      = 100
      record_operator   = "below"
      message           = "Record count is below 100."
    }
  ]

ラベルも設定できます!!!

  labels = [
    {
      name = "test_label_1"
    },
    {
      name = "test_label_2"
    }
  ]

さいごに

これでTROCCO®のデータマート定義について、作成/変更/新規取込/削除の処理ができました。まだできてほやほやのTerraform Providerではありますが、今後の発展が期待されます・・・!!

18
8
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
18
8