CLI を使用して Azure Arc に直接接続されている Azure SQL Managed Instance をアップグレードする
この記事では、Azure CLI (az
) を使用して、直接的に接続された Azure Arc 対応データ コントローラーにデプロイされている Azure SQL Managed Instance をアップグレードする方法について説明します。
前提条件
ツールをインストールする
この記事のタスクに進む前に、次のツールをインストールします。
arcdata
拡張機能のバージョンとイメージのバージョンは関連しています。 アップグレードするイメージのバージョンに対応する適切な arcdata
拡張機能のバージョンがあることを、バージョン ログで確認します。
制限事項
マネージド インスタンスをアップグレードする前に、Azure Arc データ コントローラーを新しいバージョンにアップグレードする必要があります。
Active Directory 統合が有効になっている場合は、マネージド インスタンスをアップグレードする前に、Active Directory コネクタを新しいバージョンにアップグレードする必要があります。
データ コントローラーをアップグレードする前に、マネージド インスタンスをデータ コントローラーおよび Active Directory コネクタと同じバージョンにする必要があります。
現時点では、バッチ アップグレード プロセスは使用できません。
マネージド インスタンスをアップグレードする
ドライ ランを最初に実行できます。 ドライ ランにより、バージョン スキーマが検証され、アップグレードするインスタンスが一覧表示されます。 --dry-run
を使用してください。 次に例を示します。
az sql mi-arc upgrade --resource-group <resource group> --name <instance name> --dry-run
次のように出力されます。
Preparing to upgrade sql sqlmi-1 in namespace arc to data controller version.
****Dry Run****1 instance(s) would be upgraded by this commandsqlmi-1 would be upgraded to <version-tag>.
汎用
SQL Managed Instance General Purpose のアップグレード中は、ポッドが終了して新しいバージョンで再プロビジョニングされます。 それに起因し、新しいポッドが作成されるとき、わずかなダウンタウンが発生します。 中断を最小に抑えるため、接続再試行ロジックなど、アプリケーションに回復性を与える必要があります。 回復性の設計と Azure サービスの再試行ガイダンス の詳細については、「信頼性の重要な要素の概要」を参照してください。
Business Critical
複数のレプリカを使用した SQL Managed Instance Business Critical のアップグレード中は、次のことが行われます。
- セカンダリ レプリカ ポッドが終了して新しいバージョンで再プロビジョニングされます
- レプリカがアップグレードされると、プライマリはアップグレードされたレプリカにフェールオーバーされます
- 以前のプライマリ ポッドが終了して、新しいバージョンで再プロビジョニングされ、セカンダリ になります
フェールオーバーが発生するとき、短時間のダウンタイムが発生します。
アップグレード
マネージド インスタンスをアップグレードするには、次のコマンドを使用します。
az sql mi-arc upgrade --resource-group <resource group> --name <instance name> --desired-version <imageTag> [--no-wait]
例:
az sql mi-arc upgrade --resource-group myresource-group --name sql1 --desired-version v1.6.0_2022-05-02 [--no-wait]
モニター
CLI でアップグレードの進捗状況を監視できます。
CLI の例
az sql mi-arc show --resource-group <resource group> --name <instance name>
出力
コマンドの出力に、リソース情報が表示されます。 状態にアップグレード情報が示されます。
アップグレード中は、State
に Updating
が表示されます。Running Version
は現在のバージョンになります。
Status:
Log Search Dashboard: https://30.88.222.48:5601/app/kibana#/discover?_a=(query:(language:kuery,query:'custom_resource_name:sqlmi-1'))
Metrics Dashboard: https://30.88.221.32:3000/d/40q72HnGk/sql-managed-instance-metrics?var-hostname=sqlmi-1-0
Observed Generation: 2
Primary Endpoint: 30.76.129.38,1433
Ready Replicas: 1/1
Running Version: v1.5.0_2022-04-05
State: Updating
アップグレードが完了すると、State
に Ready
が表示されます。Running Version
は新しいバージョンになります。
Status:
Log Search Dashboard: https://30.88.222.48:5601/app/kibana#/discover?_a=(query:(language:kuery,query:'custom_resource_name:sqlmi-1'))
Metrics Dashboard: https://30.88.221.32:3000/d/40q72HnGk/sql-managed-instance-metrics?var-hostname=sqlmi-1-0
Observed Generation: 2
Primary Endpoint: 30.76.129.38,1433
Ready Replicas: 1/1
Running Version: v1.6.0_2022-05-02
State: Ready
トラブルシューティング
目的のバージョンが特定のバージョンに設定されている場合、ブートストラップ ジョブでは成功するまでそのバージョンへのアップグレードが試行されます。 アップグレードが成功すると、仕様の RunningVersion
プロパティが新しいバージョンに更新されます。 イメージ タグが正しくない、レジストリまたはリポジトリに接続できない、コンテナーに割り当てられた CPU またはメモリが不足している、ストレージが不足しているなどのシナリオでは、アップグレードが失敗する可能性があります。
次のコマンドを実行して、いずれかのポッドで
Error
状態が表示されているか、または再起動回数が多くなっているかを確認します。kubectl get pods --namespace <namespace>
イベントを調べてエラーがあるかどうかを確認するには、以下を実行します
kubectl describe pod <pod name> --namespace <namespace>
ポッド内のコンテナーの一覧を取得するには、以下を実行します
kubectl get pods <pod name> --namespace <namespace> -o jsonpath='{.spec.containers[*].name}*'
コンテナーのログを取得するには、以下を実行します
kubectl logs <pod name> <container name> --namespace <namespace>
一般的なエラーとそのトラブルシューティング方法を確認するには、「トラブルシューティング リソース」を参照してください。