リリース 3.1.1
概要
Apache Doris 3.1.1は、重要なバグ修正、パフォーマンス最適化、安定性向上に焦点を当てたメンテナンスリリースです。このリリースでは、compaction、ロード、クエリ処理、クラウド機能に関する数多くの修正が含まれており、本番環境でのより高い堅牢性を実現しています。
新機能
主要機能
データ統合・ストレージ
[feat](hdfs)HDFS HA設定検証を追加(#55675、#55764)[feat](checker)checkerにtablet stats key整合性チェックを追加(#54754、#55663)[feat](outfile)outfileとexportでCSVフォーマットの圧縮タイプをサポート(#55392、#55561)[feat](cloud)cloud group commit stream load BE forwardモードをサポート(#55326、#55527)
パフォーマンス・最適化
改善
パフォーマンス最適化
[opt](cloud)metaサービスの空のrowsetプレッシャーを軽減(#54395、#55171、#55604、#55742、#55837、#55934)[Opt](mow)MOWロードパフォーマンスとCPU使用率を最適化(#55073、#55733、#55771、#55767)[opt](hive)hive.recursive_directoriesのデフォルト値をtrueに設定(#55737、#55905)[opt](recycler)多数のAws::Internal::GetEC2MetadataClientHTTPコールを回避(#55546、#55682)[opt](mow)CPU使用量削減のためスタックキャプチャを無効化(#55368、#55526)[opt](txn lazy commit)convert tmp rowsetsバッチをより適応的に改善(#55035、#55573)[opt](nereids)大きな文字列を複合型にキャストするパフォーマンスを向上(#55476、#55521)[opt](nereids)文字列範囲の簡素化をサポート(#55378、#55456)[opt](nereids)normalize windowを最適化(#54947、#55046)[opt](nereids)OLAPテーブルが自動パーティションを持つ場合のinsertコマンドの並列処理を最適化(#54983、#55030)
システム拡張
[enhancement](Log)一部のログをinfoからdebugに変更(#55808、#55841)[enhancement](filecache)複数のキャッシュインスタンス間での並列キャッシュクリア(#55259、#55437)[enhancement](sc)隠しカラムでのschema changeを拒否(#53376、#55385)[enhancement](backup)バックアップ中のドロップされたテーブルとパーティションを処理(#52935、#54989)[enhancement](cloud)Dorisバージョン2.1から3.1へのクラウドrestoreを修正(#55110)[enhancement](type)timeとdatetime間のキャストをサポート(#53734、#54985)
インフラストラクチャ改善
[refactor](credential)統一アーキテクチャでvended credentialsシステムをリファクタリング(#55912)[refactor](cloud)cloud restore create tablet RPCを複数のバッチに分離(#55691)[opt](editlog)FEが異常な場合に特定のeditlog例外をスキップする機能を追加(#54090、#55204)
重要なバグ修正
Compaction・ストレージ
[fix](sc)alter_version以下のバージョンで空のrowsetバージョンホール埋めをスキップ(#56209、#56212)[fix](compaction)compaction後に入力rowsetが早期に削除されてクエリが失敗する問題を修正(#55382、#55966)[fix](compaction)compactionジョブの冪等性を保つためのtablet作成の冪等化(#56061、#56108)[fix](compaction)segcompactionでrowset meta FSを使用し、RPCクライアントの準備チェックを追加(#55951、#55988)[fix](compaction)compaction中にcompactionスコア0のタブレットをスキップ(#55550、#55570)
クエリ処理・関数
[fix](fold constant)absの戻り値型は引数の型と同じにする(#56190、#56210)[fix](fold constant)float/doubleがNaNの場合はBE constant foldを実行しない(#55425、#55874)[Fix](function)unix_timestampの間違ったdecimalを修正(#55013、#55962)[fix](nereids)精度の損失やcast nullによる比較述語の簡素化を修正(#55884、#56110)[fix](nereids)join reorderでeq関数が存在しない例外をスローする実行エラーを修正(#54953、#55667)[fix](nereids)window expressionエイリアスのexpr id再利用を修正(#55286、#55486)[fix](nereids)count()集約関数との比較にint literalの代わりにbigintを使用(#55545、#55590)[fix](nereids)巨大な式を生成する際にprojectのマージを停止(#55293、#55519)
データロード・インポート
[fix](load)S3ロード接続チェックの失敗を修正(#56123)[fix](load)完了したロードの間違った進行状況を修正(#55509、#55530)[fix](load)ingestion loadエラーケースによるBE coreを修正(#55500)[fix](load)MEM_LIMIT_EXCEEDで失敗したroutine loadタスクが再スケジュールされない問題を修正(#55481、#55616)
クラウド・分散機能
[fix](cloud)replayUpdateCloudReplicaの不要なテーブルロックを削除(#55579、#55955)[fix](cloud)calc_sync_versionsはfull compactionを考慮すべき(#55630、#55710)[fix](warmup)CloudTablet::complete_rowset_segment_warmupcoredumpを修正(#55932)
データベース操作
[fix](database)dbのリネームとテーブル作成の競合状態を修正(#55054、#55991)[fix](create table)データベースの同時リネームがテーブル作成とreplayの失敗を引き起こす問題を修正(#54614、#56039)[fix](table)テーブルロック内でdrop editlogを移動(#55705、#55947)[fix](schema change)light schema change有効化後にタブレットカラムが再構築されない問題を修正(#55909、#55939)
データ型・シリアライゼーション
[fix](variant)JSON文字列へのシリアライゼーション時のnull値処理を修正(#55876、#56138)[fix](variant)sparseカラムが空の場合の互換性エラーを修正(#55817)[fix](variant)variantのmax_sparse_column_statistics_sizeを拡張(#55124、#55752)
外部データソース
[fix](paimon)Paimon native readerがlate materializationを使用しない問題を修正(#55894、#55917)[fix](paimon)キャッシュキーにdlf.catalog.idを追加してPaimon DLFカタログキャッシュ問題を修正(#55875、#55888)[fix](paimon)PaimonからDorisタイプマッピングでの過大なCHAR/VARCHARフィールドを処理(#55051、#55531)[fix](maxcompute)MC述語をプッシュダウンする際の存在しないテーブルカラムによるNereidsExceptionを修正(#55635、#55746)[fix](maxcompute)MaxComputeカタログの国際ユーザーがアクセスできない問題を修正(#55256、#55560)[fix](hudi)パーティションカラムのみ(データフィールドなし)が必要なHudi JNIテーブルのクエリを修正(#55466、#55662)[fix](hive)NULL DEFINED AS ''のHiveテキストテーブルのクエリを修正(#55626、#55661)[fix](iceberg)metadataスキャナーに不足しているiceberg-aws依存関係を追加(#55741、#55743)[fix](iceberg rest)Icebergのデフォルト値を使用したOAuth2トークンリフレッシュ(#55578、#55624)
メモリ・リソース管理
[fix](memtracker)memtrackerによってメモリが消費されない問題を修正(#55796、#55823)[fix](mow)BaseTablet::get_rowset_by_ids()でのMOW coredumpを修正(#55539、#55601)[fix](mow)MOW aggキャッシュバージョンチェックを修正(#55330、#55475)[fix](move-memtable)誤ってスキップされたセグメントのセグメント番号不一致を修正(#55092、#55471)[fix](filecache)cloudモード時のセグメントキャッシュのfd num制限を解除(#55610、#55638)
セキュリティ・暗号化
その他の修正
[fix](mtmv)パーティションテーブルにパーティションがない場合のMTMVリフレッシュ不可を修正(#55468、#56085)[fix](plugin)pluginディレクトリ互換性の問題を修正(#56060)[fix](http stream)SQLの解析が失敗した場合にHTTPストリームが例外をスローするように修正(#55863、#55891)[fix](backup)2GBを超えるバックアップmeta/job情報をサポート(#55608、#55867)[fix](mysql protocol)masterへの転送時にmore stmt existsフラグを正しく設定(#55711、#55871)[fix](connection)タイムアウトによる接続切断時にセッション関連データが消去されない問題を修正(#55008、#55809、#55396)[fix](wal)実行失敗時のWAL abort txn replayの失敗を修正(#55881、#55924)[fix](restore)オーバーヘッド削減のためrestoreされたテーブル/パーティション/リソースをクリア(#55757、#55784)[fix](index)未使用のupdate indexを削除(#55514、#55704)[fix](txn lazy commit)txn lazy commitとschema changeの競合を修正(#55349、#55701)[fix](qe)SSLモードでのクエリエラーを修正(#53134、#55628)[fix](catalog)非負のID生成を保証するためMath.absをビット演算ANDに置換(#55183、#55689)[fix](function)array_agg_foreachの間違った結果を修正(#55075、#55420)
インフラストラクチャ・開発
ビルド・依存関係
[chore](build)ビルドスクリプトを最適化(#56027、#56028)[chore](thirdparty)aws-sdk-cppを1.11.119から1.11.219にアップグレード(#54780、#54971)[chore](build)opensslでlibevent依存関係を更新(#54652、#54857)[chore](config)ASANが動作するようbrpc::usercode_in_pthreadの設定を追加(#54656、#54829)
テスト・品質
[chore](case)一部の失敗ケースを修正(#56140、#56167)[fix](case)一部の失敗ケースを修正(#56019、#56035)[fix](test)安定化のためリグレッションテストを修正し、期待されるログレベルを変更(#55169、#55898)[fix](case)一部の失敗ケースを修正(#55739、#55769)[fix](case)リグレッションケースを修正:cse.groovy(#53434、#55897)[fix](cases)test_hudi_snapshotケース失敗を修正(#55761、#55791)[fix](case)一部の失敗ケースを修正(#55811、#55835)[fix](case)MV待機タスクは最新のもののみを考慮すべき(#55802、#55830)[fix](case)ケースを修正:variant build index(#55613、#55648)[Fix](case)show data p2ケースを修正(#55449、#55494)[fix](test)非同期MVのshow create table失敗を修正(#55278、#55480)[fix](test)cloudモードで一部のテストをスキップ(#55448、#55535)[Fix](case)一部のケースを修正(#55606、#55656)[test](export)export parallelism where exprケースを追加(#55636、#55659)[test](iceberg)Polarisテストを追加(#55484、#55557)[test](nereids)SQLキャッシュ/ソート済みパーティションキャッシュのUTを追加(#55520、#55536)[test](docker)HMSとGCS上のPaimonに適応(#55473、#55512)[test](warmup)不安定な定期warmupケースを修正