TiDB 4.0 RC.2 リリースノート

発売日: 2020年5月15日

TiDB バージョン: 4.0.0-rc.2

互換性の変更

  • ティビ

    • 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
  • ティクヴ

    • 暗号化関連の設定をセキュリティ関連の設定に移動します。つまり、TiKV設定ファイルの[encryption] [security.encryption] #7810に変更します。
  • ツール

    • TiDB Lightning

      • 互換性を向上させるために、データをインポートするときにデフォルトのSQLモードをONLY_FULL_GROUP_BY,NO_AUTO_CREATE_USERに変更します#316
      • tidb-backend モード#312で PD または TiKV ポートへのアクセスを禁止する
      • ログ情報をデフォルトでtmpファイルに出力し、 TiDB Lightningの起動時にtmpファイルのパスを出力します#313

重要なバグ修正

  • ティビ

    • WHERE節に同等の条件が 1 つしかない場合に間違ったパーティションが選択される問題を修正#17054
    • WHERE句に文字列列#16660のみが含まれている場合に、誤ったインデックス範囲を構築することで誤った結果が発生する問題を修正しました。
    • トランザクション内のDELETEの操作#16991の後にPointGet番目のクエリを実行するときに発生するpanic問題を修正しました。
    • エラーが発生したときにGCワーカーがデッドロックに遭遇する可能性がある問題を修正#16915
    • TiKV 応答が遅いがダウンしていない場合に、不要な RegionMiss 再試行を回避する#16956
    • MySQLプロトコルのハンドシェイクフェーズでクライアントのログレベルをDEBUGに変更して、ログ出力#16881を妨げる問題を解決します。
    • TRUNCATE操作#16776の後に、テーブルで定義されたPRE_SPLIT_REGIONS情報に従ってリージョンが事前に分割されない問題を修正しました。
    • 2 フェーズコミット#16876の 2 番目のフェーズで TiKV が利用できない場合に再試行によって発生するゴルーチンの急上昇の問題を修正しました。
    • 一部の式をプッシュダウンできない場合のステートメント実行のpanic問題を修正#16869
    • パーティションテーブル#17124での IndexMerge 操作の誤った実行結果を修正
    • メモリトラッカー#17234のミューテックスの競合によって発生するwide_tableのパフォーマンス低下を修正
  • TiFlash

    • データベースまたはテーブルの名前に特殊文字が含まれている場合、アップグレード後にシステムが正常に起動できない問題を修正しました。

新機能

  • ティビ

    • データのバックアップと復元のためのコマンドBACKUPRESTOREのサポートを追加#16960
    • コミット前に単一リージョン内のデータ量を事前チェックし、データ量がしきい値#16959超えた場合にリージョンを事前分割する機能をサポートします。
    • 最後に実行されたステートメントがプランキャッシュ#16830にヒットしたかどうかを示すために、スコープSessionを持つ新しいLAST_PLAN_FROM_CACHE変数を追加します。
    • スローログとテーブル#16904 SLOW_LOG Cop_time情報を記録することをサポート
    • Go Runtime #16928のメモリ状態を監視するメトリクスを Grafana に追加する
    • 一般ログ#16946forUpdateTSおよびRead Consistency分離レベル情報を出力することをサポート
    • TiKVリージョン#16925でのロック解決の重複リクエストの折りたたみをサポート
    • SET CONFIGステートメントを使用して PD/TiKV ノード#16853の構成を変更することをサポートします。
    • CREATE TABLE#16813auto_randomオプションを支持する
    • TiKV がリクエストをより適切にスケジュールおよび処理できるように、DistSQL リクエストに TaskID を割り当てます#17155
    • MySQLクライアントにログインした後、TiDBサーバーのバージョン情報を表示する機能をサポート#17187
    • GROUP_CONCAT関数#16990ORDER BY節をサポートする
    • スローログにPlan_from_cache情報を表示して、ステートメントがプラン キャッシュ#17121にヒットしたかどうかを示す機能をサポートします。
    • TiDBダッシュボードにTiFlashマルチディスク展開の容量情報を表示できる機能を追加
    • ダッシュボードでSQL文を使用してTiFlashログを照会する機能を追加
  • ティクヴ

    • 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 Lightning

      • tidb-lightning-ctlにfetch-modeサブコマンドを追加して、TiKVクラスタモード#287を印刷します。
    • ティCDC

      • cdc cli (changefeed) #546を使用してレプリケーションタスクの管理をサポート
    • バックアップと復元 (BR)

      • バックアップ中のGC時間の自動調整をサポート#257
      • データの復元時にPDパラメータを調整して復元を高速化します#198

バグの修正

  • ティビ

    • 複数の演算子での式実行にベクトル化を使用するかどうかを決定するロジックを改善#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実行すると間違った値が返される問題を修正#16831
    • IndexMerge #16947の候補パスを計算するときにインデックスのTableFilter失われる問題を修正
    • MergeJoinヒントを使用し、 TableDual演算子が存在する場合に物理クエリ プランを生成できない問題を修正しました#17016
    • ステートメントサマリーテーブル#17018Stmt_Type列目の値の大文字と小文字の誤りを修正しました。
    • 異なるユーザーが同じtmp-storage-path #16996を使用するとサービスを開始できないため、 Permission Deniedエラーが報告される問題を修正しました。
    • 結果の型がCASE WHEN #16995などの複数の入力列によって決定される式に対して、 NotNullFlag結果の型が誤って設定される問題を修正しました。
    • ダーティストアが存在する場合にグリーンGCが未解決のロックを残す可能性がある問題を修正#16949
    • 複数の異なるロックを持つ単一のキーに遭遇したときに、グリーン GC が未解決のロックを残す可能性がある問題を修正#16948
    • サブクエリが親クエリ列#16952を参照しているため、 INSERT VALUEステートメントに間違った値が挿入される問題を修正しました。
    • Float#16666AND演算子を使用した場合に誤った結果になる問題を修正しました
    • 高価なログ#16907WAIT_TIMEフィールドの誤った情報を修正
    • 悲観的トランザクションモード#16897SELECT FOR UPDATE文がスローログに記録できない問題を修正
    • EnumまたはSetタイプの列でSELECT DISTINCT実行したときに発生する誤った結果を修正しました#16892
    • SHOW CREATE TABLE#16864auto_random_baseの表示エラーを修正
    • WHERE#16559string_valueの誤った値を修正
    • GROUP BYウィンドウ関数のエラーメッセージがMySQL #16165のものと一致しない問題を修正
    • データベース名に大文字の#17167が含まれている場合にFLASH TABLEステートメントの実行が失敗する問題を修正しました
    • Projection Executor #17118の不正確なメモリトレースを修正しました
    • 異なるタイムゾーンのSLOW_QUERYテーブルで時間フィルタリングが正しく行われない問題を修正#17164
    • 仮想生成列#17126IndexMerge使用された場合に発生するpanic問題を修正しました
    • INSTRLOCATE関数#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
    • ステートメントサマリーテーブル#17086EXEC_COUNT列目にあるプリペアドステートメントのレコードの問題を修正
    • ステートメントサマリーシステム変数#17129を設定するときに値が検証されない問題を修正
    • プランキャッシュが有効な場合に、オーバーフロー値を使用してUNSIGNED BIGINT主キーを照会するとエラーが報告される問題を修正#17120
    • Grafana TiDB サマリーダッシュボード#17105でマシン インスタンスとリクエスト タイプによる QPS 表示が誤っていた問題を修正
  • ティクヴ

    • 復元後に多くの空の領域が生成される問題を修正#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

    • pd-ctl #2399region keyコマンドを使用するときに発生する404問題を修正しました
    • TSO と ID 割り当てのモニター メトリックが Grafana ダッシュボード#2405に表示されない問題を修正しました。
    • pd-recoverがDockerイメージ#2406に含まれていない問題を修正
    • データディレクトリのパスを絶対パスに解析して、TiDBダッシュボードにPD情報が正しく表示されない問題を修正しました#2420
    • pd-ctl #2416scheduler config shuffle-region-schedulerコマンドを使用したときにデフォルトの出力がない問題を修正しました
  • TiFlash

    • 一部のシナリオで使用容量の情報が誤って報告される問題を修正
  • ツール

    • TiDBBinlog

      • ダウンストリームがKafka #962の場合にmediumint型のデータが処理されない問題を修正
      • DDL 内のデータベース名がキーワード#961場合に、reparo が DDL ステートメントの解析に失敗する問題を修正しました。
    • ティCDC

      • TZ環境変数が設定されていない場合に間違ったタイムゾーンが使用される問題を修正#512

      • いくつかのエラーが正しく処理されないため、サーバーが終了したときに所有者がリソースをクリーンアップしない問題を修正しました#528

      • TiKV #531に再接続するときにTiCDCが停止する可能性がある問題を修正

      • テーブルスキーマ#534初期化時にメモリ使用量を最適化する

      • watchモードを使用してレプリケーションステータスの変更を監視し、準リアルタイム更新を実行してレプリケーション遅延を削減します#481

    • バックアップと復元 (BR)

      • BRがauto_random属性#241を持つテーブルを復元した後、データを挿入するとduplicate entryエラーが発生する可能性がある問題を修正しました。

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

Playground
登録なしで TiDB の機能をワンストップでインタラクティブに体験できます。
製品
TiDB Dedicated
TiDB Serverless
TiDB
価格
PoC お問い合わせ
エコシステム
TiKV
TiFlash
OSS Insight
© 2024 PingCAP. All Rights Reserved.
Privacy Policy.