TiDBSysbenchパフォーマンステストレポート-v5.2.0とv5.1.1

テストの概要

このテストは、オンライントランザクション処理(OLTP)シナリオでのTiDBv5.2.0とTiDBv5.1.1のSysbenchパフォーマンスを比較することを目的としています。結果は、v5.1.1と比較して、v5.2.0のポイント選択のパフォーマンスが11.03%向上し、他のシナリオのパフォーマンスがわずかに低下することを示しています。

テスト環境(AWS EC2)

ハードウェア構成

サービスの種類EC2タイプインスタンス数
PDm5.xlarge3
TiKVi3.4xlarge3
TiDBc5.4xlarge3
Sysbenchc5.9xlarge1

ソフトウェアバージョン

サービスの種類ソフトウェアバージョン
PDv5.1.1およびv5.2.0
TiDBv5.1.1およびv5.2.0
TiKVv5.1.1およびv5.2.0
Sysbench1.1.0-ead2689

パラメータ設定

TiDBv5.2.0とTiDBv5.1.1は同じ構成を使用します。

TiDBパラメータ設定

log.level: "error" performance.max-procs: 20 prepared-plan-cache.enabled: true tikv-client.max-batch-wait-time: 2000000

TiKVパラメータ設定

storage.scheduler-worker-pool-size: 5 raftstore.store-pool-size: 3 raftstore.apply-pool-size: 3 rocksdb.max-background-jobs: 8 raftdb.max-background-jobs: 4 raftdb.allow-concurrent-memtable-write: true server.grpc-concurrency: 6 readpool.unified.min-thread-count: 5 readpool.unified.max-thread-count: 20 readpool.storage.normal-concurrency: 10 pessimistic-txn.pipelined: true server.enable-request-batch: false

TiDBグローバル変数構成

set global tidb_hashagg_final_concurrency=1; set global tidb_hashagg_partial_concurrency=1; set global tidb_enable_async_commit = 1; set global tidb_enable_1pc = 1; set global tidb_guarantee_linearizability = 0; set global tidb_enable_clustered_index = 1;

テスト計画

  1. TiUPを使用してTiDBv5.2.0およびv5.1.1をデプロイします。
  2. Sysbenchを使用して16個のテーブルをインポートします。各テーブルには、1,000万行のデータが含まれています。
  3. 各テーブルでanalyze tableのステートメントを実行します。
  4. さまざまな同時実行テストの前に、復元に使用されるデータをバックアップします。これにより、各テストのデータの一貫性が保証されます。
  5. read_writeクライアントを起動して、 point_select 、およびupdate_indexのテストを実行しupdate_non_index 。 HAProxyを介してTiDBでストレステストを実行します。テストには5分かかります。
  6. 各タイプのテストが完了したら、クラスタを停止し、手順4でクラスタをバックアップデータで上書きして、クラスタを再起動します。

テストデータを準備する

次のコマンドを実行して、テストデータを準備します。

sysbench oltp_common \ --threads=16 \ --rand-type=uniform \ --db-driver=mysql \ --mysql-db=sbtest \ --mysql-host=$aws_nlb_host \ --mysql-port=$aws_nlb_port \ --mysql-user=root \ --mysql-password=password \ prepare --tables=16 --table-size=10000000

テストを実行します

次のコマンドを実行して、テストを実行します。

sysbench $testname \ --threads=$threads \ --time=300 \ --report-interval=1 \ --rand-type=uniform \ --db-driver=mysql \ --mysql-db=sbtest \ --mysql-host=$aws_nlb_host \ --mysql-port=$aws_nlb_port \ run --tables=16 --table-size=10000000

試験結果

ポイントセレクトパフォーマンス

スレッドv5.1.1 QPSv5.1.1 95%の遅延(ミリ秒)v5.2.0 QPSv5.2.0 95%レイテンシ(ミリ秒)QPSの改善
150143014.132.35174402.51.2321.95%
300199133.063.682720181.6436.60%
600389391.652.18393536.42.111.06%
900468338.822.97447981.983.3-4.35%
1200448348.525.18468241.294.654.44%
1500454376.797.04483888.426.096.49%

v5.1.1と比較して、v5.2.0のポイント選択のパフォーマンスは11.03%向上しています。

Point Select

非インデックスパフォーマンスの更新

スレッドv5.1.1 QPSv5.1.1 95%の遅延(ミリ秒)v5.2.0 QPSv5.2.0 95%レイテンシ(ミリ秒)QPSの改善
15031198.686.4330714.736.09-1.55%
30043577.1510.4642997.929.73-1.33%
60057230.1817.3256168.8116.71-1.85%
90065325.1123.164098.0422.69-1.88%
120071528.2628.6769908.1528.67-2.26%
150076652.533.1274371.7933.72-2.98%

v5.1.1と比較すると、v5.2.0のインデックス以外の更新のパフォーマンスは1.98%低下しています。

Update Non-index

インデックスのパフォーマンスを更新する

スレッドv5.1.1 QPSv5.1.1 95%の遅延(ミリ秒)v5.2.0 QPSv5.2.0 95%レイテンシ(ミリ秒)QPSの改善
15015641.0413.221532013.46-2.05%
30019787.7321.8919161.3522.69-3.17%
60024566.7436.8923616.0738.94-3.87%
90027516.5750.1126270.0454.83-4.53%
120029421.1063.3228002.6569.29-4.82%
150030957.8477.1928624.4495.81-7.54%

v5.0.2と比較すると、v5.1.0の更新インデックスのパフォーマンスは4.33%低下しています。

Update Index

読み取り/書き込みパフォーマンス

スレッドv5.1.1 QPSv5.1.1 95%の遅延(ミリ秒)v5.2.0 QPSv5.2.0 95%レイテンシ(ミリ秒)QPSの改善
15068471.0257.876924654.831.13%
30086573.0997.5585340.4294.10-1.42%
600101760.75176.73102221.31173.580.45%
900111877.55248.83109276.45257.95-2.32%
1200117479.4337.94114231.33344.08-2.76%
1500119662.91419.45116663.28434.83-2.51%

v5.0.2と比較すると、v5.1.0の読み取り/書き込みパフォーマンスは1.24%低下します。

Read Write

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