バックアップリソースの使用

このドキュメントでは、 tidbcloud_backupリソースを使用してTiDB Cloudクラスターのバックアップを作成する方法を学習できます。

tidbcloud_backupリソースの特徴は次のとおりです。

  • TiDB 専用クラスターのバックアップを作成します。
  • TiDB 専用クラスターのバックアップを削除します。

前提条件

  • TiDB Cloud Terraform プロバイダーを入手する
  • バックアップおよび復元機能は、TiDB サーバーレス クラスターでは使用できません。バックアップ リソースを使用するには、TiDB 専用クラスターを作成していることを確認してください。

バックアップ リソースを使用してバックアップを作成する

  1. バックアップ用のディレクトリを作成して入力します。

  2. backup.tfファイルを作成します。

    例えば:

    terraform { required_providers { tidbcloud = { source = "tidbcloud/tidbcloud" } } } provider "tidbcloud" { public_key = "your_public_key" private_key = "your_private_key" } resource "tidbcloud_backup" "example_backup" { project_id = "1372813089189561287" cluster_id = "1379661944630234067" name = "firstBackup" description = "create by terraform" }

    ファイル内のリソース値 (プロジェクト ID やクラスター ID など) を独自の値に置き換える必要があります。

    Terraform を使用してクラスター リソース (たとえば、 example_cluster ) を保守している場合は、実際のプロジェクト ID とクラスター ID を指定せずに、次のようにバックアップ リソースを構成することもできます。

    resource "tidbcloud_backup" "example_backup" { project_id = tidbcloud_cluster.example_cluster.project_id cluster_id = tidbcloud_cluster.example_cluster.id name = "firstBackup" description = "create by terraform" }
  3. terraform applyコマンドを実行します。

    $ terraform apply tidbcloud_cluster.example_cluster: Refreshing state... [id=1379661944630234067] Terraform used the selected providers to generate the following execution plan. Resource actions are indicated with the following symbols: + create Terraform will perform the following actions: # tidbcloud_backup.example_backup will be created + resource "tidbcloud_backup" "example_backup" { + cluster_id = "1379661944630234067" + create_timestamp = (known after apply) + description = "create by terraform" + id = (known after apply) + name = "firstBackup" + project_id = "1372813089189561287" + size = (known after apply) + status = (known after apply) + type = (known after apply) } Plan: 1 to add, 0 to change, 0 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:
  4. yesを入力してバックアップを作成します。

    Enter a value: yes tidbcloud_backup.example_backup: Creating... tidbcloud_backup.example_backup: Creation complete after 2s [id=1350048] Apply complete! Resources: 1 added, 0 changed, 0 destroyed.
  5. バックアップのステータスを確認するにはterraform state show tidbcloud_backup.${resource-name}を使用します。

    $ terraform state show tidbcloud_backup.example_backup # tidbcloud_backup.example_backup: resource "tidbcloud_backup" "example_backup" { cluster_id = "1379661944630234067" create_timestamp = "2022-08-26T07:56:10Z" description = "create by terraform" id = "1350048" name = "firstBackup" project_id = "1372813089189561287" size = "0" status = "PENDING" type = "MANUAL" }
  6. 数分間待ちます。次に、 terraform refershを使用してステータスを更新します。

    $ terraform refresh tidbcloud_cluster.example_cluster: Refreshing state... [id=1379661944630234067] tidbcloud_backup.example_backup: Refreshing state... [id=1350048] $ terraform state show tidbcloud_backup.example_backup # tidbcloud_backup.example_backup: resource "tidbcloud_backup" "example_backup" { cluster_id = "1379661944630234067" create_timestamp = "2022-08-26T07:56:10Z" description = "create by terraform" id = "1350048" name = "firstBackup" project_id = "1372813089189561287" size = "198775" status = "SUCCESS" type = "MANUAL" }

ステータスがSUCCESSに変わると、クラスターのバックアップが作成されたことを示します。バックアップ作成後は更新できないので注意してください。

これで、クラスターのバックアップが作成されました。バックアップを使用してクラスターを復元する場合は、 復元リソースを使用することができます。

バックアップを更新する

バックアップは更新できません。

バックアップを削除する

バックアップを削除するには、対応するbackup.tfファイルが存在するバックアップ ディレクトリに移動し、 terraform destroyコマンドを実行してバックアップ リソースを破棄します。

$ terraform destroy Plan: 0 to add, 0 to change, 1 to destroy. Do you really want to destroy all resources? Terraform will destroy all your managed infrastructure, as shown above. There is no undo. Only 'yes' will be accepted to confirm. Enter a value: yes

ここでterraform showコマンドを実行しても、リソースがクリアされているため、何も得られません。

$ terraform show

このページは役に立ちましたか?

Playground
新規
登録なしで TiDB の機能をワンストップでインタラクティブに体験できます。
製品
TiDB Cloud
TiDB
価格
PoC お問い合わせ
エコシステム
TiKV
TiFlash
OSS Insight
© 2024 PingCAP. All Rights Reserved.
Privacy Policy.