📣
TiDB Cloud Essential はパブリックプレビュー中です。このページは自動翻訳されたものです。原文はこちらからご覧ください。

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

    • 暗号化関連の設定をセキュリティ関連の設定に移動します。つまり、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

重要なバグ修正

  • TiDB

    • WHERE節に同等の条件が 1 つしかない場合に間違ったパーティションが選択される問題を修正#17054
    • WHERE句に文字列列#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

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

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

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

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

バグ修正

  • 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実行すると間違った値が返される問題を修正#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文の実行が失敗する問題を修正しました
    • 投影実行プログラム#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 表示が誤っていた問題を修正しました。
  • 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

    • 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文の解析に失敗する問題を修正しました
    • TiCDC

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

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

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

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

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

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

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

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