TiDB 3.0.0-rc.1 リリースノート
リリース日:2019年5月10日
TiDB バージョン: 3.0.0-rc.1
TiDB Ansible バージョン: 3.0.0-rc.1
概要
2019年5月10日にTiDB 3.0.0-rc.1がリリースされました。対応するTiDB Ansibleバージョンは3.0.0-rc.1です。このリリースでは、TiDB 3.0.0-beta.1と比較して、安定性、使いやすさ、機能、SQLオプティマイザー、統計、実行エンジンが大幅に改善されています。
TiDB
SQLオプティマイザー
- 列間の順序相関を使用してコスト見積りの精度を向上させます。相関を見積りに直接使用できない場合に、インデックススキャンの優先順位を制御するヒューリスティックパラメータ
tidb_opt_correlation_exp_factorを導入します#9839 - フィルタ#10053に関連する列がある場合、複合インデックスのアクセス条件を抽出するときに、インデックスのプレフィックス列をさらに一致させます。
- 結合に参加するテーブルの数が
tidb_opt_join_reorder_threshold未満の場合に、結合操作の実行順序を指定するには、動的プログラミング アルゴリズムを使用します#8816 - アクセス条件として複合インデックスを使用する場合、インデックス結合を構築する内部テーブル内のインデックスのプレフィックス列をさらに一致させる#8471
- NULL値を持つ単一列インデックスの行数推定の精度を向上#9474
- 論理最適化フェーズで集計関数を削除するときに、誤った実行を防ぐために
GROUP_CONCAT特別に処理します#9967 - フィルタが定数#9848場合、結合演算子の子ノードにフィルタを適切にプッシュダウンします。
- MySQL #10064との非互換性を防ぐために、論理最適化フェーズで列をプルーニングするときに
RAND()などのいくつかの関数を特別に処理します。 FAST ANALYZEサポートします。これは、領域全体をスキャンするのではなく、領域をサンプリングすることで統計収集を高速化します。この機能は変数tidb_enable_fast_analyzeによって制御されます#10258- SQL文の実行計画のバインドを実行することで実行の安定性を確保するSQL計画管理をサポートします。この機能は現在ベータ版であり、SELECT文のバインド実行計画のみをサポートします。本番環境での使用は推奨されません#10284
- 列間の順序相関を使用してコスト見積りの精度を向上させます。相関を見積りに直接使用できない場合に、インデックススキャンの優先順位を制御するヒューリスティックパラメータ
実行エンジン
サーバ
- TiDB の起動時にのみ DDL 所有者にブートストラップの実行を許可する#10029
- トランザクション分離レベルをSERIALIZABLE #10065に設定するときにTiDBがエラーを報告しないようにするために、変数
tidb_skip_isolation_level_check追加します。 - 暗黙的なコミット時間とSQL実行時間をスローログ#10294にマージする
- サポート
GRANT ROLE#9721 - TiDB を終了させる
whitelistプラグインのConnectionEventエラーを修正します#9889 - トランザクション履歴に読み取り専用ステートメントを誤って追加する問題を修正#9723
kill文を改善して SQL 実行を停止し、リソースをより早く解放する#9844- 設定ファイル#9855の有効性をチェックするための起動オプション
config-checkを追加する - 厳密なSQLモードが無効になっている場合にNULLフィールドを挿入する際の妥当性チェックを修正#10161
DDL
CREATE TABLEステートメントにpre_split_regionsオプションを追加します。このオプションは、テーブルの作成時にテーブルリージョンを事前に分割して、テーブルの作成後に大量の書き込みによって発生する書き込みホットスポットを回避することをサポートします#10138- 一部のDDL文の実行パフォーマンスを最適化する#10170
FULLTEXT KEY#9821ではフルテキストインデックスがサポートされていないという警告を追加します- TiDB #9820の古いバージョンにおける UTF8 および UTF8MB4 文字セットの互換性の問題を修正しました
- 表#9868の
shard_row_id_bitsの潜在的なバグを修正 - テーブルの文字セットを変更しても列の文字セットが変更されないバグを修正#9790
- 列のデフォルト値として
BINARY/BIT使用する場合のSHOW COLUMNの潜在的なバグを修正#9897 SHOW FULL COLUMNS文#10007でCHARSETCOLLATION説明を表示する際の互換性の問題を修正SHOW COLLATIONS文が TiDB #10186でサポートされている照合順序のみをリストする問題を修正しました
PD
- ETCD #1452アップグレード
- etcdとPDサーバーのログ形式を統一する
- 事前投票でLeaderを選出できない問題を修正
- 後続のリクエストをブロックしないように、失敗する可能性のある「提案」および「読み取り」リクエストを迅速にドロップすることをサポートします。
- リースのデッドロック問題を修正
- ホットストアがキー#1487の統計情報を正しく生成しない問題を修正
- 単一のPDノード#1485からPDクラスターを強制的に再構築するサポート
regionScatterer無効なOperatorStep#1482を生成する可能性がある問題を修正MergeRegionオペレータ#1495の短すぎるタイムアウト問題を修正- ホットリージョンのスケジュールに高い優先度を与えるサポート#1492
- PDサーバー側#1502でTSOリクエストの処理時間を記録するためのメトリックを追加します
- 対応する店舗IDと住所を店舗#1506に関連する指標に追加します。
GetOperatorサービス#1477サポートする- ストアが見つからないため、ハートビートストリームでエラーを送信できない問題を修正しました#1521
TiKV
エンジン
サーバ
ラフトストア
- 構成可能な
properties index distance#4517をサポート
- 構成可能な
コプロセッサー
- バッチインデックススキャンエグゼキュータ#4419を追加
- ベクトル化評価フレームワーク#4322を追加
- バッチエグゼキュータ#4433実行サマリーフレームワークの追加
- RPN式を構築するときに最大列をチェックして、評価panic#4481を引き起こす可能性のある無効な列オフセットを回避します。
BatchLimitExecutor#4469を加える- ReadPoolの元の
futures-cpupoolをtokio-threadpoolに置き換えてコンテキストスイッチ#4486を減らす - バッチ集計フレームワーク#4533を追加
BatchSelectionExecutor#4562を加える- バッチ攻撃機能の追加
AVG#4570 - RPN関数
LogicalAnd#4575を追加
その他
- メモリアロケータ#4370としてのサポート
tcmalloc
- メモリアロケータ#4370としてのサポート
ツール
TiDBBinlog
- unsigned int 型の主キー列のbinlogデータが負の#573場合にレプリケーションが中止される問題を修正しました。
- ダウンストリームが
pb場合は圧縮オプションを提供しません。ダウンストリーム名をpbからfileに変更します#559 - Pumpにローカルstorage#509への非同期フラッシュを許可する
storage.sync-log設定項目を追加する - PumpとDrainer#495間の通信のトラフィック圧縮をサポート
- 異なるSQLモード#511でのDDLクエリの解析をサポートするために、 Drainerに
syncer.sql-mode構成項目を追加します。 - レプリケーションを必要としないテーブルを除外するための構成項目を
syncer.ignore-table追加します#520
稲妻
- 行IDまたはデフォルトの列値を使用して、ダンプファイル#170で欠落した列データを入力します。
- SST の一部がインポートに失敗した場合でも、インポート成功が返される可能性があるインポーターのバグを修正しました#4566
- SST を TiKV #4412にアップロードする際のインポーターの速度制限をサポート
- 大きなテーブルに対するチェックサムと分析によるクラスターへの影響を軽減し、チェックサムと分析#156成功率を向上させるために、サイズによるテーブルインポートをサポートします。
- データソースファイルをTiDBのtypes.Datumとして直接解析し、KVエンコーダ#145からの余分な解析オーバーヘッドを削減することで、LightningのSQLエンコードパフォーマンスを50%向上しました。
- ログ形式を統合ログ形式 #162に変更
- 設定ファイルが見つからない場合に使用するコマンドラインオプションをいくつか追加します#157
同期差分インスペクター
TiDB アンシブル
- より多くの TiKV 監視パネルをサポートし、Ansible、Grafana、Prometheus #727のバージョンを更新しました。
- クラスターのステータスを表示するサマリーダッシュボード
- 問題のトラブルシューティングのためのトラブルシューティングダッシュボード
- 開発者が問題を分析するための詳細ダッシュボード
- Kafka バージョン#730の TiDB Binlogのダウンロードに失敗するバグを修正しました
- CentOS 7.0以降、Red Hat 7.0以降などのサポート対象オペレーティングシステムのバージョン制限を変更します#733
- ローリングアップデート中のバージョン検出モードをマルチ同時実行#736に変更
- README #740のドキュメントリンクを更新
- 冗長な TiKV 監視メトリックを削除し、トラブルシューティング用の新しいメトリックを追加します#735
table-regions.pyスクリプトを最適化して、表#739のリーダー分布を表示する- Drainer #745の設定ファイルを更新します
- SQL カテゴリ別にレイテンシを表示する新しいパネルで TiDB モニタリングを最適化#747
- Lightning設定ファイルを更新し、
tidb_lightning_ctlスクリプト#1e946f8追加します。