高可用性 MySQL データベースを作成する

重要

Azure Stack Hub ビルド 2108 以降では、アクセスが許可されているサブスクリプションに SQL と MySQL リソース プロバイダーが提供されます。 この機能の使用を開始する場合、または以前のバージョンからアップグレードする必要がある場合は、サポート ケースを開くと、サポート エンジニアがデプロイまたはアップグレード プロセスを説明します。

Azure Stack Hub オペレーターとして、MySQL Server データベースをホストするようにサーバーの仮想マシン (VM) を構成できます。 MySQL クラスターが正常に作成され、Azure Stack Hub によって管理されると、MySQL サービスにサブスクライブしているユーザーは高可用性 MySQL データベースを簡単に作成できます。

この記事では、Azure Stack Marketplace の項目を使用してレプリケーション クラスター付きの MySQL を作成する方法について説明します。 このソリューションは、複数の VM を使用して、コントロール プレーン ノードから構成可能な数のレプリカにデータベースをレプリケートします。 作成したクラスターは、Azure Stack Hub MySQL ホスティング サーバーとして追加することができます。また、ユーザーは高可用性 MySQL データベースを作成できるようになります。

重要

レプリケーション付きの MySQL Azure Stack Marketplace の項目は、すべての Azure クラウド サブスクリプション環境では利用できない場合があります。 このチュートリアルの以降の部分に進む前に、ご自身のサブスクリプションでマーケットプレースの項目を入手できることを確認してください。

ここでは、次の内容について学習します。

  • マーケットプレースの項目から MySQL Server クラスターを作成する。
  • MySQL Server クラスターを Azure Stack Hub MySQL ホスティング サーバーとして構成する。
  • 高可用性 MySQL データベースを作成する。

利用可能な Azure Stack Marketplace の項目を使用して、3 つの VM MySQL Server クラスターを作成および構成します。

開始する前に、MySQL Server リソース プロバイダーが正常にインストールされ、Azure Stack Marketplace で次の項目を利用できることを確認してください。

重要

MySQL クラスターを作成するには、以下のすべてが必要です。

  • MySQL とレプリケーション: これは、MySQL クラスターのデプロイに使用される Bitnami ソリューション テンプレートです。
  • Debian 8 "Jessie": Credativ によって提供される Microsoft Azure 用のバックポート カーネルを備えた Debian 8 "Jessie"。 Debian GNU/Linux は最も人気のある Linux ディストリビューションの 1 つです。
  • Linux 2.0 のカスタム スクリプト: カスタム スクリプト拡張機能は、VM のプロビジョニング後に VM カスタマイズ タスクを実行するためのツールです。 この拡張機能が VM に追加されると、Azure ストレージからスクリプトをダウンロードして VM 上で実行できます。 カスタム スクリプト拡張タスクは、Azure PowerShell コマンドレットと Azure クロスプラットフォーム コマンドライン インターフェイス (xPlat CLI) を使用して自動化することもできます。
  • Linux 拡張機能 1.4.7 の VM アクセス: VM アクセス拡張機能を使用すると、VM へのアクセスを回復できるように、パスワード、SSH キー、または SSH 構成をリセットできます。 また、この拡張機能を使用して、パスワードまたは SSH キーを使用して新しいユーザーを追加したり、ユーザーを削除したりすることもできます。 この拡張機能は、Linux VM をターゲットとしています。

Azure Stack Marketplace に項目を追加する方法については、「Azure Stack Marketplace の概要」を参照してください。

また、Linux VM のデプロイ後にログインするためには、PuTTY などの SSH クライアントが必要になります。

MySQL Server クラスターを作成する。

このセクションの手順を使用して、レプリケーション付き MySQL マーケットプレース項目を使用して MySQL Server クラスターをデプロイします。 このテンプレートで、高可用性 MySQL クラスターで構成された 3 つの MySQL Server インスタンスがデプロイされます。 既定で、次のリソースが作成されます。

  • 仮想ネットワーク
  • ネットワーク セキュリティ グループ
  • ストレージ アカウント
  • 可用性セット
  • 3 つのネットワーク インターフェイス (既定の VM ごとに 1 つ)。
  • パブリック IP アドレス (プライマリ MySQL クラスター VM の場合)
  • MySQL クラスターをホストする 3 つの Linux VM
  1. ユーザー ポータルにサインインします。

    • 統合システム デプロイの場合、ポータル アドレスはソリューションのリージョンと外部ドメイン名によって変わります。 https://portal.<region>.<FQDN> という形式になります。
    • Azure Stack Development Kit (ASDK) の場合、このポータルのアドレスは https://portal.local.azurestack.external です。
  2. サブスクリプションがまだ割り当てられていない場合は、ダッシュボードから [サブスクリプションの取得] を選択します。 ブレードで、サブスクリプションの名前を入力し、オファーを選択します。 誤って削除されないように、MySQL クラスターのデプロイは独自のサブスクリプションに保持することをお勧めします。

  3. +[ リソースの作成]>[計算] の順に選択し、[MySQL with Replication]\(レプリケーション付き MySQL\) を選択します。

    Azure Stack Hub でのカスタム テンプレートのデプロイ

  4. [基本] ページで基本的なデプロイ情報を提供します。 既定値を確認し、必要に応じて変更して [OK] を選択します。

    少なくとも、以下の情報を指定します。

    • デプロイ名 (既定値は mymysql)。

    • アプリケーションのルート パスワード。 特殊文字を含めずに 12 文字の英数字のパスワードを入力します。

    • アプリケーション データベース名 (既定値は bitnami)。

    • 作成する MySQL データベースのレプリカ VM の数 (既定値は 2)。

    • 使用するサブスクリプションを選択します。

    • 使用するリソース グループを選択するか、新しく作成します。

    • 場所を選択します (バージョン 2107 前の ASDK の場合、既定値は local)。

      デプロイの基礎 -- レプリケーション付きの MySQL の作成

  5. [Environment Configuration]\(環境の構成\) ページに次の情報を入力し、[OK] を選択します。

    • Secure Shell (SSH) 認証に使用するパスワードまたは SSH パブリック キー。 パスワードを使用する場合は、英字、数字を含める必要があります。また、特殊文字を含めることも可能です

    • VM サイズ (既定値は Standard D1 v2 VM)。

    • データ ディスク サイズ (GB 単位)

      環境の構成 -- レプリケーション付きの MySQL の作成

  6. デプロイの [概要] を確認します。 必要に応じて、カスタマイズしたテンプレートとパラメーターをダウンロードして、[OK] を選択します。

    概要 -- レプリケーション付きの MySQL の作成

  7. [購入] ページで [作成] を選択して、デプロイを開始します。

    [購入] ページ -- レプリケーション付きの MySQL の作成

    Note

    デプロイには約 1 時間かかります。 続行する前に、デプロイが完了し、MySQL クラスターの構成が完了していることを確認してください。

  8. すべてのデプロイが正常に完了したら、リソース グループ項目を確認し、mysqlip パブリック IP アドレス項目を選択します。 クラスターのパブリック IP アドレスと完全な FQDN をメモします。

    この MySQL クラスターを利用する MySQL ホスティング サーバーを作成できるように、この IP アドレスを Azure Stack Hub オペレーターに提供する必要があります。

ネットワーク セキュリティ グループ規則を作成する

既定では、MySQL からホスト VM へのパブリック アクセスは構成されません。 Azure Stack Hub MySQL リソース プロバイダーが MySQL クラスターを接続して管理するには、受信ネットワーク セキュリティ グループ (NSG) 規則を作成する必要があります。

  1. 管理者ポータル上で、MySQL クラスターのデプロイ時に作成されたリソース グループに移動して、ネットワーク セキュリティ グループ (default-subnet-sg) を選択します。

    Azure Stack Hub 管理者ポータル上でネットワーク セキュリティ グループを選択します

  2. [受信セキュリティ規則] を選択してから、[追加] を選択します。

    [宛先ポート範囲] に「3306」と入力し、必要に応じて [名前] フィールドと [説明] フィールドに説明を入力します。

    .txt ファイルを開いて

  3. [追加] を選択して、受信セキュリティ規則のダイアログを閉じます。

MySQL クラスターへの外部アクセスを構成する

MySQL クラスターを Azure Stack Hub MySQL Server ホストとして追加する前に、外部アクセスを有効にする必要があります。

  1. SSH クライアントを使用して (この例では PuTTY を使用)、パブリック IP にアクセスできるコンピューターからプライマリ MySQL マシンにログインします。 通常、プライマリ MySQL VM 名は末尾が 0 であり、パブリック IP が割り当てられています。

    パブリック IP を使用して、ユーザー名 bitnami と、前に作成した特殊文字を含まないアプリケーション パスワードを入力して、VM にログインします。

    LinuxLogin

  2. SSH クライアント ウィンドウで、次のコマンドを使用して、bitnami サービスがアクティブで実行中であることを確認します。 プロンプトが表示されたら、もう一度 bitnami パスワードを入力します。

    sudo service bitnami status

    bitnami サービスを確認する

  3. Azure Stack Hub MySQL ホスティング サーバーが MySQL に接続し、SSH クライアントを終了するために使用するリモート アクセス ユーザー アカウントを作成します。

    前に作成したルート パスワードを使用して、次のコマンドを実行して MySQL に root としてログインします。 新しい管理者ユーザーを作成し、環境に合わせて <username> および <password> を置き換えます。 この例では、作成されたユーザーの名前は sqlsa であり、強力なパスワードが使用されています。

    mysql -u root -p
    create user <username>@'%' identified by '<password>';
    grant all privileges on *.* to <username>@'%' with grant option;
    flush privileges;
    

    管理者ユーザーを作成する

  4. 新しい MySQL ユーザー情報をメモします。

    Azure Stack Hub オペレーターには、このユーザー名とパスワードと共に、クラスターのパブリック IP アドレスまたはパブリック IP の完全な FQDN を渡し、この MySQL クラスターを使用して MySQL ホスティング サーバーを作成できるようにする必要があります。

Azure Stack Hub MySQL ホスティング サーバーを構成する

MySQL Server クラスターが作成されて適切に構成されたら、Azure Stack Hub オペレーターはそれを Azure Stack Hub MySQL ホスティング サーバーとして追加する必要があります。

以前に MySQL クラスターのリソース グループを作成したときにメモした、MySQL クラスターのプライマリ VM のパブリック IP、またはパブリック IP の完全な FQDN を必ず使用してください (mysqlip)。 また、オペレーターは、MySQL クラスター データベースにリモート アクセスするために作成した MySQL Server の認証資格情報を知っておく必要があります。

Note

この手順は、Azure Stack Hub オペレーターが Azure Stack Hub 管理者ポータルから実行する必要があります。

Azure Stack Hub オペレーターは、MySQL クラスターのパブリック IP と MySQL の認証ログイン情報を利用して、新しい MySQL クラスターを使用して MySQL ホスティング サーバーを作成できるようになりました。

また、MySQL データベースの作成をユーザーが利用できるプランとオファーが作成済みであることも確認してください。 Operator は Microsoft.MySqlAdapter サービスをプランに追加し、高可用性データベース専用の新しいクォータを作成する必要があります。 プランの作成の詳細については、「サービス、プラン、オファー、サブスクリプションの概要」を参照してください。

ヒント

Microsoft.MySqlAdapter サービスは、MySQL Server リソース プロバイダーがデプロイされるまでプランに追加することができません。

高可用性 MySQL データベースを作成する

MySQL クラスターが Azure Stack Hub オペレーターによって Azure Stack Hub MySQL ホスティング サーバーとして作成、構成、追加された後、MySQL Server データベース機能を含むサブスクリプションを持つテナント ユーザーは、このセクションの手順に従って、高可用性 MySQL データベースを作成できます。

Note

これらの手順は、MySQL Server 機能 (Microsoft.MySQLAdapter サービス) を提供するサブスクリプションを持つテナント ユーザーとして、Azure Stack Hub ユーザー ポータルから実行します。

  1. ユーザー ポータルにサインインします。

    • 統合システム デプロイの場合、ポータル アドレスはソリューションのリージョンと外部ドメイン名によって変わります。 https://portal.<region>.<FQDN> という形式になります。
    • Azure Stack Development Kit (ASDK) の場合、このポータルのアドレスは https://portal.local.azurestack.external です。
  2. + リソースの作成>Data + Storage を選択し、MySQL Databaseします。

    名前、照合順序、使用するサブスクリプション、デプロイに使用する場所などの必須のデータベースのプロパティを指定します。

    Azure Stack Hub ユーザー ポータル上で MySQL データベースを作成する

  3. [SKU] を選択し、使用する適切な MySQL ホスティング サーバー SKU を選択します。 この例では、Azure Stack Hub オペレーターは、MySQL クラスター データベースの高可用性をサポートするために MySQL-HA SKU を作成しました。

    Azure Stack Hub ユーザー ポータル上で SKU を選択する

  4. [ログイン]>[Create a new login]\(新しいログインの作成\) の順に選択し、新しいデータベースに使用する MySQL の認証資格情報を入力します。 完了したら [OK][作成] の順に選択し、データベースのデプロイ プロセスを開始します。

    Azure Stack Hub ユーザー ポータル上でログインを追加する

  5. MySQL データベースのデプロイが正常に完了したら、データベースのプロパティを確認し、新しい高可用性データベースへの接続に使用する接続文字列を見つけます。

    Azure Stack Hub ユーザー ポータル上で接続文字列を表示する

次のステップ

MySQL リソースプロバイダーを更新する