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

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
  • 実行エンジン

    • 3つの演算子TableReader IndexLookupReader #10003メモリ使用量の追跡と制御をサポートしますIndexReader
    • コプロセッサのタスク数、実行時間/待機時間の平均/最長/90%、実行時間または待機時間が最も長い TiKV のアドレスなど、スロー ログ内のコプロセッサ タスクに関する詳細情報の表示をサポートします#10165
    • プレースホルダなしの準備済みDDL文をサポートする#10144
  • サーバ

    • TiDB の起動時にのみ DDL 所有者にブートストラップの実行を許可する#10029
    • トランザクション分離レベルをSERIALIZABLE #10065に設定するときにTiDBがエラーを報告しないようにするために、変数tidb_skip_isolation_level_check追加します。
    • 暗黙的なコミット時間とSQL実行時間をスローログ#10294にマージする
      • SQL ロールのサポート (RBAC権限管理)
      • サポートSHOW GRANT #10016
      • サポートSET DEFAULT ROLE #9949
    • サポート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 文字セットの互換性の問題を修正しました
    • #9868shard_row_id_bitsの潜在的なバグを修正
    • テーブルの文字セットを変更しても列の文字セットが変更されないバグを修正#9790
    • 列のデフォルト値としてBINARY / BIT使用する場合のSHOW COLUMNの潜在的なバグを修正#9897
    • SHOW FULL COLUMNS#10007CHARSET COLLATION説明を表示する際の互換性の問題を修正
    • 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

  • エンジン

    • 読み取りトラフィックの統計情報が不正確になる可能性がある問題を修正#4436
    • 範囲#4503削除するときにプレフィックス抽出プログラムがpanicを起こす可能性がある問題を修正しました
    • メモリ管理を最適化してメモリ割り当てとコピーを削減Iterator Key Bound Option #4537
    • 学習者のログギャップを考慮しないと、場合によってはpanicが発生する可能性がある問題を修正しました#4559
    • 異なるcolumn families #4612間でのblock cache共有をサポート
  • サーバ

    • コンテキストスイッチのオーバーヘッドをbatch commands #4473削減
    • シークイテレータステータス#4470の有効性をチェックする
  • ラフトストア

    • 構成可能なproperties index distance #4517をサポート
  • コプロセッサー

    • バッチインデックススキャンエグゼキュータ#4419を追加
    • ベクトル化評価フレームワーク#4322を追加
    • バッチエグゼキュータ#4433実行サマリーフレームワークの追加
    • RPN式を構築するときに最大列をチェックして、評価panic#4481を引き起こす可能性のある無効な列オフセットを回避します。
    • BatchLimitExecutor #4469を加える
    • ReadPoolの元のfutures-cpupooltokio-threadpoolに置き換えてコンテキストスイッチ#4486を減らす
    • バッチ集計フレームワーク#4533を追加
    • BatchSelectionExecutor #4562を加える
    • バッチ攻撃機能の追加AVG #4570
    • RPN関数LogicalAnd #4575を追加
  • その他

    • メモリアロケータ#4370としてのサポートtcmalloc

ツール

  • 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
  • 同期差分インスペクター

    • チェックポイントをサポートし、検証ステータスを記録し、再起動後に最後に保存したポイントから検証を続行します#224
    • チェックサム#215計算してデータの整合性をチェックするための構成項目only-use-checksum追加します

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追加します。

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