TiDB 4.0 RC.2 リリースノート
発売日:2020年5月15日
TiDB バージョン: 4.0.0-rc.2
互換性の変更
TiDB
- TiDB Binlogが有効な場合、単一トランザクションのサイズ制限(100 MB)が削除されました。現在、トランザクションのサイズ制限は 10 GB です。ただし、TiDB Binlogが有効で、ダウンストリームが Kafka の場合は、Kafka #16941のメッセージサイズ制限である 1 GB に合わせて
txn-total-size-limitパラメータを設定してください。 CLUSTER_LOGテーブル#17003照会するときに時間範囲が指定されていない場合は、デフォルトの時間範囲を照会するのではなく、エラーを返して指定された時間範囲を要求するように動作を変更します。CREATE TABLEステートメントを使用してパーティションテーブルを作成するときに、サポートされていないsub-partitionまたはlinear hashオプションが指定された場合、オプションが無視されたパーティションテーブルではなく、通常のテーブルが作成されます#17197
- TiDB Binlogが有効な場合、単一トランザクションのサイズ制限(100 MB)が削除されました。現在、トランザクションのサイズ制限は 10 GB です。ただし、TiDB Binlogが有効で、ダウンストリームが Kafka の場合は、Kafka #16941のメッセージサイズ制限である 1 GB に合わせて
TiKV
- 暗号化関連の設定をセキュリティ関連の設定に移動します。つまり、TiKV設定ファイルの
[encryption][security.encryption]#7810に変更します。
- 暗号化関連の設定をセキュリティ関連の設定に移動します。つまり、TiKV設定ファイルの
ツール
重要なバグ修正
TiDB
WHERE節に同等の条件が 1 つしかない場合に間違ったパーティションが選択される問題を修正#17054WHERE句に文字列列#16660のみが含まれている場合に誤ったインデックス範囲を構築することで誤った結果が発生する問題を修正しました。DELETE操作#16991後にトランザクション内のPointGetクエリを実行するときに発生するpanic問題を修正しました- エラーが発生したときにGCワーカーがデッドロックに遭遇する可能性がある問題を修正しました#16915
- TiKVの応答が遅いがダウンしていない場合に不要なRegionMissの再試行を回避する#16956
- MySQLプロトコルのハンドシェイクフェーズでクライアントのログレベルを
DEBUGに変更して、ログ出力#16881を妨げる問題を解決します。 TRUNCATE操作#16776後に、テーブルで定義されたPRE_SPLIT_REGIONS情報に従ってリージョンが事前に分割されない問題を修正しました。- 2 フェーズコミットの 2 番目のフェーズで TiKV が利用できない場合に再試行によって発生するゴルーチンの急上昇の問題を修正しました#16876
- 一部の式をプッシュダウンできない場合のステートメント実行のpanic問題を修正#16869
- パーティションテーブル#17124でのIndexMerge操作の誤った実行結果を修正
- メモリトラッカー#17234のミューテックスの競合によって引き起こされる
wide_tableのパフォーマンス低下を修正しました
TiFlash
- データベースまたはテーブルの名前に特殊文字が含まれている場合、アップグレード後にシステムが正常に起動できない問題を修正しました。
新機能
TiDB
- データのバックアップと復元のためのコマンド
BACKUPとRESTOREサポートを追加#16960 - コミット前に単一リージョン内のデータ量を事前チェックし、データ量がしきい値#16959を超えた場合にリージョンを事前分割する機能をサポートします。
- 最後に実行されたステートメントがプランキャッシュ#16830にヒットしたかどうかを示す、スコープ
Sessionを持つ新しいLAST_PLAN_FROM_CACHE変数を追加します。 - スローログと
SLOW_LOG#16904のCop_time情報を記録することをサポート - Grafana に Go Runtime #16928のメモリ状態を監視するメトリクスを追加します
- 一般ログ#16946に
forUpdateTSおよびRead Consistency分離レベル情報を出力することをサポート - TiKVリージョン#16925でのロック解決の重複リクエストの折りたたみをサポート
SET CONFIGステートメントを使用して PD/TiKV ノード#16853の構成を変更することをサポートしますCREATE TABLEの文のauto_randomオプションを支持する#16813- TiKV がリクエストをより適切にスケジュールして処理できるように、DistSQL リクエストに TaskID を割り当てます#17155
- MySQLクライアント#17187にログインした後、TiDBサーバーのバージョン情報を表示する機能をサポート
GROUP_CONCAT関数#16990のORDER BY節をサポートする- スローログに
Plan_from_cache情報を表示して、ステートメントがプラン キャッシュ#17121にヒットしたかどうかを示すことをサポート - TiDBダッシュボードにTiFlashマルチディスク構成の容量情報を表示できる機能を追加
- ダッシュボードでSQL文を使用してTiFlashログを照会する機能を追加
- データのバックアップと復元のためのコマンド
TiKV
- tikv-ctl の暗号化デバッグをサポートし、暗号化storageが有効な場合に tikv-ctl を使用してクラスターを操作および管理できるようになりました#7698
- スナップショット#7712のロックカラムファミリーの暗号化をサポート
- Grafanaダッシュボードのヒートマップを使用して、 Raftstoreのレイテンシーサマリーを表示し、ジッターの問題をより適切に診断します#7717
- gRPC メッセージのサイズの上限設定をサポート#7824
- Grafanaダッシュボードに暗号化関連の監視メトリクス#7827追加する
- アプリケーション層プロトコルネゴシエーション(ALPN) #7825サポート
- Titan #7818に関する統計情報を追加する
- 同じトランザクション内の別のタスクによってタスクの優先度が下げられるのを回避するために、クライアントによって提供されたタスクIDを統合読み取りプールの識別子として使用することをサポートします#7814
batch insertリクエスト#7718のパフォーマンスを向上させる
PD
- ノードをオフラインにするときにピアを削除する際の速度制限を排除#2372
TiFlash
- GrafanaのRead IndexのCountグラフの名前をOpsに変更します
- システム負荷が低いときにファイル記述子を開くためのデータを最適化して、システムリソースの消費を削減します。
- データstorage容量を制限するために容量関連の設定パラメータを追加します
ツール
バグ修正
TiDB
- 複数の演算子#16383での式実行にベクトル化を使用するかどうかを決定するロジックを改善
IndexMergeヒントがデータベース名を正しくチェックできない問題を修正#16932- シーケンスオブジェクト#17037切り捨てを禁止する
INSERT/UPDATE/ANALYZE/DELETEステートメントがシーケンスオブジェクト#16957で実行できる問題を修正しました- ブートストラップフェーズの内部SQL文がステートメントサマリーテーブル#17062で内部クエリとして正しくマークされない問題を修正しました。
- TiFlashではサポートされているがTiKVではサポートされていないフィルタ条件が
IndexLookupJoin演算子#17036にプッシュダウンされたときに発生するエラーを修正しました - 照合順序が有効になった後に発生する可能性のある
LIKEの同時実行の問題を修正#16997 - 照合順序が有効になった後、
LIKE関数がRangeクエリインデックスを正しく構築できない問題を修正しました#16783 Plan Cache文がトリガーされた後に@@LAST_PLAN_FROM_CACHE実行すると間違った値が返される問題を修正#16831IndexMerge#16947の候補パスを計算するときにインデックスのTableFilter失われる問題を修正しましたMergeJoinヒントを使用し、TableDual演算子が存在する場合に物理クエリプランを生成できない問題を修正しました#17016- ステートメントサマリーテーブル#17018の
Stmt_Type列目の値の大文字と小文字の誤りを修正しました。 - 異なるユーザーが同じ
tmp-storage-path#16996を使用するとサービスを開始できないため、Permission Deniedエラーが報告される問題を修正しました。 - 結果の型が
CASE WHEN#16995などの複数の入力列によって決定される式に対して、NotNullFlag結果の型が誤って設定される問題を修正しました。 - ダーティストアが存在する場合にグリーンGCが未解決のロックを残す可能性がある問題を修正#16949
- 複数の異なるロックを持つ単一のキーに遭遇したときに、グリーンGCが未解決のロックを残す可能性がある問題を修正しました#16948
- サブクエリが親クエリ列#16952を参照しているため、
INSERT VALUEステートメントに間違った値が挿入される問題を修正しました。 Float値#16666にAND演算子を使用したときに誤った結果が出る問題を修正しました- 高価なログ#16907の
WAIT_TIMEフィールドの誤った情報を修正 - 悲観的トランザクションモード#16897で
SELECT FOR UPDATE文がスローログに記録できない問題を修正 EnumまたはSetタイプの列でSELECT DISTINCT実行したときに発生する誤った結果を修正#16892SHOW CREATE TABLE文#16864のauto_random_baseの表示エラーを修正WHERE節#16559のstring_valueの誤った値を修正するGROUP BYウィンドウ関数のエラーメッセージがMySQL #16165と一致しない問題を修正しました- データベース名に大文字の#17167含まれている場合に
FLASH TABLE文の実行が失敗する問題を修正しました - 投影実行プログラム#17118の不正確なメモリトレースを修正しました
- 異なるタイムゾーンの
SLOW_QUERYテーブルで時間フィルタリングが正しく行われない問題を修正しました#17164 - 仮想生成列#17126で
IndexMergeが使用された場合に発生するpanic問題を修正 INSTRとLOCATE関数#17068の大文字化の問題を修正tidb_allow_batch_cop構成を有効にした後にtikv server timeoutエラーが頻繁に報告される問題を修正#17161- Float型に対して
XOR演算を実行した結果がMySQL 8.0 #16978と一致しない問題を修正 - サポートされていない
ALTER TABLE REORGANIZE PARTITION文が実行されてもエラーが報告されない問題を修正#17178 EXPLAIN FORMAT="dot" FOR CONNECTION IDサポートされていないプランに遭遇したときにエラーが報告される問題を修正#17160- ステートメントサマリーテーブル#17086の
EXEC_COUNT列目にあるプリペアドステートメントのレコードの問題を修正しました。 - ステートメントサマリーシステム変数#17129を設定するときに値が検証されない問題を修正しました
- プランキャッシュが有効な場合に、オーバーフロー値を使用して
UNSIGNED BIGINT主キーをクエリするとエラーが報告される問題を修正しました#17120 - Grafana TiDB サマリーダッシュボード#17105で、マシンインスタンスとリクエストタイプによる QPS 表示が誤っていた問題を修正しました。
TiKV
- 復元後に多くの空の領域が生成される問題を修正#7632
- 順序がずれたインデックス読み取り応答を受け取ったときにRaftstoreがpanic問題を修正#7370
- 統合スレッドプールが有効な場合に、無効なstorageまたはコプロセッサ読み取りプール構成が拒否されない可能性がある問題を修正しました#7513
- TiKVサーバーがシャットダウンされたときの
join操作のpanic問題を修正しました#7713 - 診断API #7776経由でTiKVスローログを検索しても結果が返されない問題を修正
- TiKVノードが長時間実行されると顕著なメモリ断片化が発生する問題を修正#7556
- 無効な日付が格納されている場合にSQL文の実行が失敗する問題を修正#7268
- GCS #7739からバックアップデータを復元できない問題を修正
- 保存時の暗号化中にKMSキーIDが検証されない問題を修正#7719
- 異なるアーキテクチャのコンパイラにおけるコプロセッサーの根本的な正確性の問題を修正#7714 #7730
- 暗号化が有効になっている場合の
snapshot ingestionエラーを修正#7815 - 設定ファイル#7817書き換え時に発生する
Invalid cross-device linkエラーを修正 - 設定ファイルを空のファイルに書き込むときに間違った toml 形式になる問題を修正しました#7817
- Raftstoreで破棄されたピアがリクエストを処理できる問題を修正#7836
PD
TiFlash
- 一部のシナリオで使用容量の情報が誤って報告される問題を修正しました
ツール
TiDBBinlog
TiCDC
バックアップと復元 (BR)
- BRが
auto_random属性#241を持つテーブルを復元した後にデータを挿入するとduplicate entryエラーが発生する可能性がある問題を修正しました。
- BRが