2
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

Alibaba CloudのPolarDBの徹底分析(8)_PolarDB Serverlessの基礎

Last updated at Posted at 2023-02-03

1. PolarDBの種類

PolarDBには以下の2種類があります。

  • ユーザーがインスタンスのスペック(メモリとCPU)を明示的に指定する昔ながらの Provisioned
  • DBへのアクセストラフィック(インスタンスの負荷状況、つまりCPU、メモリ、ネットワークなど)に基づくデータベースのリソースが自動的にスケーリングできる Serverless

「Serverless」という言葉は、「サーバーがない」という意味ではなく、裏側では実際にインスタンスが存在しています。この言葉は「サーバーの管理を意識する必要がない」という意味で使われます。

比較項目 Provisioned Serverless
オートスケール範囲 ・ストレージのみ ・computing(CPU + メモリ)
・ストレージ
スケーリング方法 手動によるスケールアップ/スケールダウン 負荷に応じて自動的に変動
スケーリング時に切断あるか 30秒程度接続断発生 接続断なし
クラスタ構成 ・master node
・read-only node
・master node
・read-only node
課金方法 固定(スペック) 負荷に応じて変動
起動/停止 手動 自動
read-only node台数 15台 15台
対応バージョン 8.0
5.7
5.6
8.0
5.7

2. 従来のProvisioned 型における課題

スケールの観点から見ると、容量が足りなくなる場合は、ストレージはオートスケールしますが、コンピューティングレイヤーのオートスケールにはまだ対応していません。そのため、ワークロードに応じた最適なコンピューティングレイヤー(サーバのスペックや台数)の調整やコスト最適化を行うことは困難です。繁忙期のワークロードに必要なコンピューティングレイヤーを固定する必要があります。

  1. 繁忙時間帯のワークロードにも対応できるリソースを多めに&つねり確保する必要があり、時間帯によってアクセスの変動のあるシナリオではリソースの無駄が大きいです。
    p550765.png

  2. ユーザー側でインスタンス管理が必要で、管理コストが高い。(定期updateなど)

Provisioned型にも以下のスケールアウト・スケールイン(水平スケーリングとも言われていて、read-only nodeの増減)の方法もありますが、実用性が低くて、ほとんど使われていないようです。

  • 使われていない理由:
    • スケールアウト・スケールインは数分かかるため、トラフィックの増減になかなか追いつかない。
    • スケールアウト、スケールインはnode単位であるため、無駄が大きい。
      image.png
  • Provisioned型におけるスケールアウト・スケールイン(水平スケーリング)方法:
    1. Alibaba CloudのFunction Compute(AWSのLamdaのようなサービス)と連携し時刻指定のスケールアウト・スケールインを行う

      • トラフィックが頻繁に変動するシーンでは時刻の指定は難しくなります。
    2. PolarDB auto scaling機能を利用し、指定していたCPU平均使用率(現在はCPU使用率しか指定できなくて、メモリなどの使用率を見てauto scalingすることが対応できていない)を超えると、自動的にauto scalingする
      image.png

    3. サーバーのメトリック監視のサービスCloudMonitor(AWSのCloudWatchに似ているもの)と連携し、CPUだけではなく、メモリなどの使用率も含めて、ある閾値を超えると自動的にスケールアウト・スケールインする仕組みを作る

上記のスケールアウト、スケールインはあくまでもread-only nodeの増減なので、データベースの読み取り性能は拡張できるが、書き込み性能が拡張できません。
primary nodeのスペックを変更することによってスケールアップ/スケールダウン(垂直スケーリング)もできなくはないのですが、クラスターの再起動が必要になり、数分サービス停止する必要があるため、本番環境では安易にスペックが変更できないでしょう。

3. serverlessの詳細

3.1 特徴

  • 一定時間内にアクセスがなかった場合は、データベースが完全停止できる
  • 完全停止期間中、computingの部分(CPU、メモリ)は無料となりますが、ストレージの部分はデータを削除しない限り、継続的に課金されます。
  • 完全停止の状態から起動するまでは数秒かかり、起動している途中ではサービスが利用できません。この問題を回避するために、完全にシャットダウンせず、最低限のリソースを確保しておく方法も考えられます。
  • アクセスが来たら、ゼロから自動的に起動する
  • アクセスの変化に応じてスケールアップ・ダウン(nodeのスペックが自動的に増減)する
    • スケーリングの単位は PCU (PolarDB Capacity Unit)である
    • 1 PCU = 1 core CPU + 2GB メモリ
      • 最小PCU: 1 PCU
      • 最大PCU: 32 PCU
    • クエリ実行中でも自動スケーリングを行なってくれる
    • スケーリングダウンの際、DBコネクションが切れることはありません。スケーリング中にポーズしたり、スループットが落ちることもありません。
  • まず垂直スケーリングし、一つのnodeが対応しきれない場合は、自動的にスケールアウト(read-only nodeが自動的に起動してくれる)
    • 一つのclusterの最大のnode数: 16個 (1 primay node + 15 read-only node )
    • 一つのnodeのPCUの範囲: 0 PCU ~ 32 PCU
    • 一つのclusterのPCU範囲: 0 PCU ~ 512 PCU (32*16)
      image.png

AWS Aurora Serverlessは1ACU あたり約2GBのメモリ、対応するCPU、ネットワークが組み合わせられます。
Aurora Serverless v2 インスタンスは、垂直スケーリング(scale up/down)には対応していますが、水平スケーリング(scale out/in)には対応していません。
Serverless v2 Reader nodeを追加するには、手動で追加する必要があります。

image.png

  • 通常時はスケールアップは 0.5 PCU 刻みで行われ、利用状況に応じて細やかなスケーリングを実現します。
    image.png

  • 現在の容量が大きいほど、スケーリングの増分が大きくなります。突発的に利用増加した場合はちまちま 0.5 PCU ずつスケールアップしていくのではなく、その時の PCU の大きさに応じてグッと大きく増加してくれる、というわけです。この仕組みのおかげで、高速スケーリングを実現しています。
    image.png

3.2 serverlessのメリット

  • PCUの範囲とインスタンス数の範囲を指定しておけば、負荷に応じたスケーリングをよしなにやってくれるため、capacity計画などの運用コストが若干低くなります。
  • Provisoned instanceはインスタンスタイプによる課金であるのに対し、Serverlessでは秒単位の利用数がメインとなり、Serverlessのほうが(使い方にもよりますが)大抵の場合コスト効率がよく、低い料金で利用できます。

3.3 利用シーン

  1. 不定期使用のアプリケーション
    • 例:社内でのみ使うアプリケーションであり、基本的に平日&日中のみ稼働する場合は、自動起動・シャットダウンできればかなりコスト削減できる見込み
  2. 可変・予測不能なワークロード(オートスケール狙い)
  3. 開発やステージング環境

本番環境でもほとんどのケースでは十分に利用できるレベルになっていたと言われていますが、瞬時的にトラフィックが大きく増加している時にスケーリングが間に合わなくて、数秒で想定した性能がでない場合もありうるため、しっかり負荷テストをして、性能を評価することをお勧めします。

3.4 料金

Left align Provisioned Serveless
computing 0.124$/時間
(g2.medium: 2 cores + 4GB memory)
1PCU 0.0977$/時間 * 2 = 0.1954$/時間
Proxy 無料 1PCUあたり 0.0489$/時間
storage 0.000552 USD/GB/時間 同様
I/O 無料 無料

■ 料金計算の例
・1ヶ月間の料金(以下の金額は全部米ドルで計算)
・メモリ最大16G
・ただし、常に16Gのメモリを使うわけではない。
・1日のうち4時間は16G(8PCU)、8時間は2G(1PCU)の処理を行い、それ以外は処理しないと想定する。

  • Provisioned型の場合

    • polar.mysql.mmg4.xlargeを選ぶこととする。
    • 0.982 × 24時間 × 30日 = 707.04
  • Serverless型の場合

    • 最小PCUを2、最大PCUを8とする。
    • (0.0977$ + 0.0489$) × 8PCU × 4時間 = 4.6912
    • (0.0977$ + 0.0489$) × 2PCU × 8時間 = 2.3456
    • (4.6912$ + 2.3456$) × 30日 = 211.104

3.5 気をつける点

  • 対応バージョン
    • 現時点ではMySQL 8.0MySQL 5.7しか対応できていない。
    • これからPostgreSQLも対応できるようになるそうです。

4. PolarDB Serverlessを使ってみる

4.1 新規作成

  • read-only nodeの数と 一つのnodeのPCU数を設定

    • read-only node数の範囲: 0 ~ 15個
    • 一つノードのPCU範囲: 1 ~ 32 PCU(今後64, 128にも拡張できるようになるようです。)
      image.png
  • 完全停止するかどうかを設定

    • デフォルトはoffになっています
    • onにする場合は、さらに検出の時間間隔を設定します。(その時間以内にアクセスが来なければ、cluster全体が停止になる。)
      image.png
  • 作成できたserverlessのcluster

    • Minimum Read-Only Node数を1に設定したため、read-only node + primary nodeは合計2つノードがあります。
      image.png
      image.png
  • 既存のインスタンスに対して、アクセス来ない場合は、完全停止にさせる方法:
    新規作成する時に、完全停止をONにしていない場合は、インスタンス作成後でも変更可能です。
    image.png

4.2 read-only node数を減らしてみる

  • 以下のServerlessのボタンを押下
    image.png
  • 最大read-only node数と最初read-only node数両方を0に変更
    image.png
  • read-only nodeが削除されている最中
    image.png
  • read-only nodeが削除されました。
    image.png

4.3 完全停止から起動

  • 一定時間以内にアクセスこなければ、clusterが完全停止になります。
    image.png
  • 手動起動と自動起動両方可能です。
    • 手動起動: cluster一覧画面で、該当のclusterを選択して、Start Clusterボタンをクリックして、起動する
      image.png
    • 自動起動:コマンドラインから接続してみると、だいたい10秒程度経ってから結果が戻ることがわかりました。
      image.png

4.4 負荷をかけてみる

実行前

image.png

image.png

sysbenchで負荷テスト用のデータを準備

  • データをinsertする時にCPU使用率が高くなると、PCUが上がることがわかります。
DBHOST= ***
DBPASS= ***
DBUSER= ***
echo 'CREATE DATABASE benchmarktest' | mysql -h ${DBHOST} -P 3306 -u ${DBUSER} -p

sysbench --db-driver=mysql \
      --mysql-host=${DBHOST}  \
      --mysql-user=${DBUSER} \
      --mysql-password=${DBPASS} \
      --mysql-db=benchmarktest \
      --table_size=50000000 \
      oltp_read_write \
      prepare

image.png

  • sysbenchを実行するために、Alibaba Cloud上でPolarDB Serveless instanceと同一VPC、どういつAZのsubnetを使っているECS(仮想サーバーのサービス、AWSでいうとEC2になります)を利用することがお勧めです。ローカルPCあるいは異なるAZ上のECSインスタンスからテストすると、ネットワークがボトルネックになりがちで、Serveless instanceのCPUの負荷がなかなか上がらないため、結果的にはscale up(PCU数の増加)がなかなか観測しにくいということです。
  • 以下のテストではECS ecs.g7.6xlarge(24vCPU,96 GiBメモリ)のインスタンスを使っています。

image.png

image.png

image.png

image.png

実行時

  • 実行コマンド
sysbench --db-driver=mysql \
      --mysql-host=${DBHOST}  \
      --mysql-user=${DBUSER} \
      --mysql-password=${DBPASS} \
      --mysql-db=benchmarktest \
      --time=600 \
      --threads=100 \
      --range_selects=off \
      --db-ps-mode=disable \
       --report-interval=10 \
      oltp_read_write \
      run
  • 実行結果

    • コマンドラインから10間隔でtps, qpsなどがかんたんに確認できる。
    • Servless instanceのCPUが食われると、PCUが自動的に上がることが観測しやすいため、PCUが変わらない場合は、timethreadsを調整してみてください。
      image.png
      image.png
  • 監視メトリックス:

    • CPU使用率,QPS,TPSなどのメトリックスの変化はPCUの数の変化とだいたい同じです。
      image.png

image.png

image.png

image.png

image.png

image.png

  • scale upとCPU上昇とのタイムラグを確認してみる
    • 詳細なタイムラグを確認しやすくためには、まず監視データ表示の時間間隔をデフォルトの60Sから5Sに変更する
      image.png
  • 5秒単位で確認する場合は、ほぼscale upとCPU上昇はほぼ同じペースで変化しているため、タイムラグは5秒以内であることが言えそうです。

追記:

  • PolarDBの開発チームに確認したところで、やはりscale upのタイムラグは平均で10秒前後です。
  • テストの結果は5秒ぐらいもありましたが、必ず5秒とは保証できないようです。

image.png
image.png

5. まとめ

  • 「PolarDB Serverlessは、DBの負荷に応じたスケーリングを自動で行ってくれます。そのため、これまで必要だったDBのキャパシティ計画や手動でのスペック変更といった運用が不要になり、専門のDBAがいなくてもデータベースの運用が容易になります。
  • DBへのアクセスが変動する利用シーンでは、従来のプロビジョンドインスタンスに比べてコストが半分以下になることも多いです(利用方法によります)。
  • CPUやメモリの変化に応じた自動スケーリングは、5秒以内に行えるそうです。開発環境やテスト環境、社内環境などの負荷の低いワークロードだけでなく、変動の多い本番環境にも十分対応できるレベルになっています。

6. Q&A

  1. Q:スケールインあるいはスケールダウンする時に、既存のコネクションや実行しているトランザクションに影響がありますか。
    A:既存のコネクションや実行しているトランザクションに影響がありません。
    最大コネクション数を超える新しいコネクションで接続しようとすると、エラーになります。

  2. Q: 手動によるノードの追加や削除やノードのスペック変更ができますか。
    A: そもそもServerlessのコンセプトとしては自動scalingすることでコスト削減と運用保守に必要な人的なリソース削減するため、手動変更はできません。

  3. Q:CPUやメモリなどの使用率を設定することによって、スケーリングのタイミングを制御することができますか。
    A: 手動で制御できません。 ServerlessはCPU、メモリ、コネクション数の変化を総合的に見て、スケーリングのタイミングを自動制御する仕組みです。
    この仕組はこれからも徐々に改善しづつ、最適化することになります。

  4. Q: 既存のProvisoned instanceをどうやってSevervlessに変更できますか。
    A: 現在は新しいSevervles instanceを作成して、Alibaba CloudのDTSサービスを利用して、データをProvisoned instanceからSevervles instanceに移行するという方法があります。この方法はちょっと手間掛かりそうです。
    これからは以下の2つ方法も計画しているようです。

    • 既存のProvisoned instanceをかんたんに(コンソール画面上で直接変更)変更できること
    • Provisoned instanceのsnapshotを作成して、snapshotからSevervles instanceを作成すること
  5. Q: 今現在消費されているPCU数をどうやって確認できますか。

    • 方法1: clusterの監視ページでPCU数やCPUとメモリの使用率などのメトリック数が確認できる。
      image.png

    • 方法2: Billing Managementで一時間単位で各リソースの消費状況も確認できます。

  6. Q: 完全停止期間内では、本当にリソース(PCU)を消費しないのですか。
    A: その通りです。

  7. Q: 垂直スケーリング(scale up/down)と水平スケーリング(scale out/in)は順番ありますか。
    A:まず垂直スケーリングを行い、一つのノードだけでは対応しきれなくなった場合に、次に水平スケーリングを行う。

  8. Q: Serverless instance と Provisoned instanceをどう使い分けしますか。

    • Serverless instance:変動のあるworkloadに適しています。
    • Provisoned instance:
      安定したworkloadに適しています。メモリサイズ、CPU パワー、I/O 帯域幅などが事前定義された DB インスタンスクラスを選択します。ワークロードが変更された場合、ライターとリーダーのインスタンスクラスを手動で変更します。クラスター内のライターとリーダーのインスタンスクラスを変更しながら、短時間の停止の発生が許容される場合は有効に機能します。
  9. Q: Serverless instanceの最大ストレージ容量?
    A: 必要の分に応じて完全に自動拡張し、最大のストレージ容量はインスタンスのスペック(ACU数)と関係なくて、一律100Tです。

Provisoned instanceでは最大ストレージ容量がインスタンスのスペックと関係があります。

2
1
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
2
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?