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

TiDB 3.0.4 リリースノート



発売日:2019年10月8日

TiDB バージョン: 3.0.4

TiDB Ansible バージョン: 3.0.4

  • 新機能

    • SQL レベルでパフォーマンスの問題をトラブルシューティングするためにperformance_schema.events_statements_summary_by_digestシステム テーブルを追加します。
    • TiDBのSHOW TABLE REGIONS構文にWHERE句を追加する
    • Reparoにworker-counttxn-batch設定項目を追加して回復速度を制御します
  • 改善点

    • TiKV でバッチリージョン分割コマンドと空分割コマンドをサポートし、分割パフォーマンスを向上
    • TiKV で RocksDB の二重リンクリストをサポートし、逆スキャンのパフォーマンスを向上
    • クラスタの状態をより適切に診断するために、TiDB Ansibleに2つのperfツールiosnoopfuncslower追加します。
    • 冗長なフィールドを削除して、TiDB のスロークエリログの出力を最適化します。
  • 行動の変化

    • デフォルト値のtxn-local-latches.enablefalseに更新して、TiDB のローカルトランザクションの競合をチェックするデフォルトの動作を無効にします。
    • TiDBにグローバルスコープのシステム変数をtidb_txn_mode追加し、悲観的ロックの使用を許可します。ただし、TiDBはデフォルトで依然として楽観的ロックを採用していることに注意してください。
    • TiDB スロー クエリ ログのIndex_idsフィールドをIndex_namesに置き換えて、スロー クエリ ログの使いやすさを向上させます。
    • TiDB構成ファイルにsplit-region-max-numパラメータを追加して、 SPLIT TABLE構文で許可されるリージョンの最大数を変更します。
    • SQL実行がメモリ制限を超えたときにリンクを切断する代わりにOut Of Memory Quotaエラーを返します
    • 誤操作を避けるため、TiDBの列のAUTO_INCREMENTの属性の削除を禁止します。この属性を削除するには、 tidb_allow_remove_auto_incのシステム変数を変更します。
  • 修正された問題

    • コメントされていない TiDB 固有の構文PRE_SPLIT_REGIONSデータ複製中に下流データベースでエラーを引き起こす可能性がある問題を修正しました。
    • カーソルを使用してPREPARE + EXECUTEの結果を取得するときに、遅いクエリログが正しくないという TiDB の問題を修正しました。
    • PDで隣接する小さな領域を結合できない問題を修正
    • TiKV の問題を修正しました。アイドル状態のクラスターでファイル記述子がリークすると、プロセスの実行時間が長くなると TiKV プロセスが異常終了することがあります。
  • 寄稿者

    このリリースにご協力いただいたコミュニティの以下の貢献者の方々に感謝申し上げます。

TiDB

  • SQLオプティマイザー
    • フィードバック#12170で分割すると無効なクエリ範囲が生成される可能性がある問題を修正しました
    • 結果に無効なキー#12094が含まれている場合はエラーを返すのではなく、 SHOW STATS_BUCKETSのステートメントの返されたエラーを16進数で表示します。
    • クエリにSLEEP関数(たとえばselect 1 from (select sleep(1)) t;) )が含まれている場合、列プルーニングによってクエリ#11953中に無効なsleep(1)発生する問題を修正しました。
    • クエリがテーブルデータではなく列数のみに関係する場合は、インデックススキャンを使用してIOを削減します#12112
    • MySQL #12100との互換性を保つために、 use index()でインデックスが指定されていない場合はインデックスを使用しない
    • CMSketch統計のTopNレコードの数を厳密に制限して、ステートメント数が TiDB のトランザクション#11914のサイズ制限を超えたためにANALYZEステートメントが失敗する問題を修正します。
    • Update#12483に含まれるサブクエリを変換するときに発生したエラーを修正します
    • Limit演算子をIndexLookUpReader実行ロジック#12378にプッシュすることで、 select ... limit ... offset ...文の実行パフォーマンスを最適化します。
  • SQL実行エンジン
    • PREPARED文が正しく実行されなかった場合に、SQL文をログに出力します#12191
    • UNIX_TIMESTAMP関数を使用してパーティショニング#12169実装する場合にパーティション プルーニングをサポートする
    • AUTO_INCREMENT MAX int64MAX uint64誤って割り当てた場合にエラーが報告されない問題を修正しました#12162
    • SHOW TABLE … REGIONSSHOW TABLE .. INDEX … REGIONS構文にWHERE節を追加する#12123
    • SQL実行がメモリ制限#12127を超えたときにリンクを切断する代わりにOut Of Memory Quotaエラーを返す
    • JSON_UNQUOTE関数がJSONテキスト#11955を処理するときに誤った結果が返される問題を修正
    • 最初の行のAUTO_INCREMENT列に値を割り当てるときにLAST INSERT ID間違っているという問題を修正しました(たとえば、 insert into t (pk, c) values (1, 2), (NULL, 3)#12002
    • PREPARE#12351GROUPBY解析ルールが間違っている問題を修正
    • ポイントクエリ#12340で権限チェックが正しく行われない問題を修正
    • 監視レコード#12331に、ステートメントPREPAREsql_typeによる期間が表示されない問題を修正しました。
    • ポイントクエリ内のテーブルの別名の使用をサポートします(例: select * from t tmp where a = "aa"#12282
    • BIT 型の列#12423に負の数を挿入するときに負の値を符号なしとして処理しない場合に発生するエラーを修正しました。
    • 時間の誤った丸めを修正します(たとえば、 2019-09-11 11:17:47.999999666 2019-09-11 11:17:48に丸められる必要があります) #12258
    • 表現ブロックリストの使い方を改良します(例えば、 < Itに相当します) #11975
    • 存在しない関数エラーのメッセージにデータベースプレフィックスを追加します(例: [expression:1305]FUNCTION test.std_samp does not exist#12111
  • サーバ
    • 最後のステートメントがCOMMIT #12180ときに前のステートメントを出力するために、スロークエリログにPrev_stmtフィールドを追加します。
    • 冗長なフィールドを削除してスロークエリログの出力を最適化する#12144
    • TiDB #12095のローカルトランザクションの競合をチェックするデフォルトの動作を無効にするには、デフォルト値のtxn-local-latches.enablefalseに更新します。
    • TiDB スロークエリログのIndex_idsフィールドをIndex_namesに置き換えて、スロークエリログ#12061の使いやすさを向上させます。
    • TiDBにグローバルスコープのシステム変数tidb_txn_mode追加し、悲観的ロック#12049使用を許可します。
    • スロークエリログにBackoffフィールドを追加して、2PC #12335のコミットフェーズのバックオフ情報を記録します。
    • カーソルを使用してPREPARE + EXECUTEの結果を取得するときにスロークエリログが正しくない問題を修正しました(たとえば、 PREPARE stmt1FROM SELECT * FROM t WHERE a > ?; EXECUTE stmt1 USING @variable#12392
    • サポートtidb_enable_stmt_summaryこの機能を有効にすると、TiDBはSQL文をカウントし、その結果はシステムテーブルperformance_schema.events_statements_summary_by_digest #12308を使用して照会できます。
    • tikv-client のログレベルを調整します(たとえば、ログレベルbatchRecvLoop failsERRORからINFOに変更します) #12383
  • DDL
    • tidb_allow_remove_auto_inc変数を追加します。列のAUTO INCREMENT属性の削除はデフォルトで無効になっています#12145
    • コメントされていない TiDB 固有の構文PRE_SPLIT_REGIONSデータ複製#12120中に下流データベースでエラーを引き起こす可能性がある問題を修正しました
    • 設定ファイルにsplit-region-max-num変数を追加して、リージョンの最大許容数を調整できるようにします#12097
    • リージョンを複数のリージョンに分割する機能をサポートし、リージョン分散中のタイムアウトの問題を修正しました#12343
    • 2つのインデックス#12344によって参照されるAUTO_INCREMENT列を含むインデックスの場合にdrop index文が失敗する問題を修正
  • モニター
    • tikvclient #12093の gRPC 接続エラーの数をカウントするconnection_transient_failure_count監視メトリックを追加します。

TiKV

  • Raftstore
    • Raftstore が空のリージョン#5414のキーの数を不正確にカウントする問題を修正しました
    • RocksDB の二重リンクリストをサポートし、逆スキャン#5368のパフォーマンスを向上しました。
    • 分割パフォーマンスを向上させるために、バッチリージョン分割コマンドと空分割コマンドをサポートします#5470
  • サーバ
    • -Vコマンドの出力形式が2.X #5501の形式と一致しない問題を修正
    • Titanを3.0ブランチ#5517の最新バージョンにアップグレードします
    • grpcio を v0.4.5 #5523にアップグレード
    • gRPC コアダンプの問題を修正し、OOM #5524回避するために共有メモリをサポートします。
    • TiKV の問題を修正しました。アイドル状態のクラスターでファイル記述子がリークすると、プロセスの実行時間が長くなると TiKV プロセスが異常終了することがあります#5567
  • ストレージ
    • TiDBの悲観的ロックをMySQLのものと可能な限り一致させるためにtxn_heart_beat APIをサポートする#5507
    • ポイントクエリのパフォーマンスが一部の状況で低下する問題を修正#5495 #5463

PD

  • 隣接する小さな領域を結合できない問題を修正#1726
  • pd-ctlのTLS有効化パラメータが無効である問題を修正#1738
  • PD演算子が誤って削除されるスレッドセーフの問題を修正#1734
  • リージョンシンカー#1739のTLSをサポート

ツール

  • TiDBBinlog
    • Reparoの設定項目worker-counttxn-batch追加して回復速度#746制御します
    • Drainerのメモリ使用量を最適化し、同時実行の効率を高めます#737
  • TiDB Lightning
    • チェックポイントからデータを再インポートするとTiDB Lightning がpanicを起こす可能性がある問題を修正#237
    • AUTO_INCREMENTのアルゴリズムを最適化して、 AUTO_INCREMENT#227のオーバーフローのリスクを軽減します。

TiDB アンシブル

  • TiSparkをv2.2.0 #926にアップグレード
  • TiDB構成項目pessimistic_txnのデフォルト値をtrue #933に更新します。
  • node_exporter #938にシステムレベルの監視メトリックを追加します
  • クラスタの状態をより適切に診断するために、TiDB Ansibleに2つのperfツールiosnoopfuncslower追加します#946
  • パスワードの有効期限が切れた場合などに発生する長い待機時間に対処するために、rawモジュールをシェルモジュールに置き換えます#949
  • TiDB構成項目txn_local_latchesのデフォルト値をfalseに更新します
  • Grafanaダッシュボードの監視メトリックとアラートルールを最適化する#962 #963 #969
  • 展開およびアップグレードの前に構成ファイルを確認する#934 #972

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