v0.8.0
 Β· 14 min read
Release date: May 18, 2024
π Highlightsβ
- Flow Engine: which brings continuous aggregation capabilities.
- Column Type Modification: allows you to effortlessly alter the data type of columns within a table without the hassle of rebuilding the table or manually migrating data.
- Cluster Management Information Table: allows querying for information about the cluster. This functionality aids administrators in monitoring and managing the health status of the database cluster, facilitating prompt issue detection and resolution.
- Append-only Tables: You can now create tables in Append-only mode by setting the append mode during table creation.
- DROP DATABASE: enables swift deletion of all tables and resources under a database instance.
- EXPLAIN ANALYZE <QUERY>: analyze and optimize query statements swiftly in distributed mode.
Breaking changesβ
- fix!: use the right precision by @fengjiachun in #3794
- refactor!: unify sql options into OptionMap by @tisonkun in #3792
- refactor!: remove some admin APIs by @fengjiachun in #3821
- refactor!: remove duration type from gRPC by @fengjiachun in #3825
- refactor!: remove opentsdb tcp server by @shuiyisong in #3828
π Featuresβ
- feat(procedure): support to rollback by @WenyXu in #3625
- feat(flow): render map&related tests by @discord9 in #3581
- feat: add append mode to table options by @evenyag in #3624
- feat(fuzz): add create database target by @CookiePieWw in #3675
- feat: treat all number types as field candidates by @waynexia in #3670
- feat(fuzz): support to create metric table by @WenyXu in #3617
- feat: add checksum for checkpoint data by @tisonkun in #3651
- feat: try get pk values from cache when applying predicate to parquet by @waynexia in #3286
- feat(flow): transform substrait SELECT&WHERE&GROUP BY to Flow Plan by @discord9 in #3690
- feat: impl table_constraints table for information_schema by @killme2008 in #3698
- feat: add strict mode to validate protocol strings by @irenjj in #3638
- feat: get metasrv clusterinfo by @fengjiachun in #3696
- feat(promql): parameterize lookback by @etolbakov in #3630
- feat: add filter_deletedoption to avoid removing deletion markers by @v0y4g3r in #3707
- feat: check partition rule by @waynexia in #3711
- feat(drop_table): support to rollback table metadata by @WenyXu in #3692
- feat(fuzz): enable create-if-not-exists option by @CookiePieWw in #3732
- feat: add tinytext, mediumtext and longtext data types by @CookiePieWw in #3731
- feat: support invalidate schema name key cache by @realtaobo in #3725
- feat: support PromQL scalar by @Taylor-lagrange in #3693
- feat: impl show collation and show charset statements by @killme2008 in #3753
- feat: add preserve arg to sqlness runner by @waynexia in #3724
- feat: update dashboard to v0.5.0 by @ZonaHex in #3768
- feat: write manifests in background tasks by @evenyag in #3709
- feat: add ChangeColumnTypeforAlterKindby @KKould in #3757
- feat: support different types for CompatReaderby @KKould in #3745
- feat: impl Display for Statement by @irenjj in #3744
- feat: add validate method to CreateExpr by @waynexia in #3772
- feat(flow): render reduce by @discord9 in #3769
- feat: implement FlowTaskMetadataManager by @WenyXu in #3766
- feat: define CreateFlowTaskandDropFlowTaskby @WenyXu in #3801
- feat(fuzz): add create logical table target by @CookiePieWw in #3756
- feat(fuzz): add alter logical table target by @CookiePieWw in #3818
- feat: implement the FrontendInvokerby @WenyXu in #3824
- feat: improve error message for typo in IF NOT EXISTS by @tisonkun in #3817
- feat: impl parser and operator for CREATE FLOW by @waynexia in #3806
- feat: implement the CreateFlowProcedureby @WenyXu in #3810
- feat: support ALTER TABLE ... MODIFY COLUMN ... ...by @KKould in #3796
- feat: physical optimizer RemoveDuplicate to remove duplicate exec plans by @waynexia in #3839
- feat(fuzz): add insert logical table target by @CookiePieWw in #3842
- feat: adds information_schema cluster_info table by @killme2008 in #3832
- feat(flow): mirror insert req to flow node by @discord9 in #3858
- feat: metasrvs nodeinfo by @fengjiachun in #3873
- feat: limit total rows copied in COPY TABLE FROMstmt by @irenjj in #3819
- feat: support querying field column names in Prometheus HTTP API by @waynexia in #3880
- feat: pass QueryContexttoFlowRequestHeaderby @WenyXu in #3878
- feat: add metasrv start time to node info by @fengjiachun in #3883
- feat: implement drop flow parser by @WenyXu in #3888
- feat: implement drop flow procedure by @WenyXu in #3877
- feat: implement CacheContainer&TableFlownodeSetCacheby @WenyXu in #3885
- feat: Parquet reader builder supports building multiple ranges to read by @evenyag in #3841
- feat: introduce TableNameCache&TableInfoCache&TableRouteCacheby @WenyXu in #3895
- feat: introduce the CacheRegistryby @WenyXu in #3896
- feat: support to drop flow by @WenyXu in #3900
- feat: support distributed EXPLAIN ANALYZEby @waynexia in #3908
- feat: metaclient builder options with role by @fengjiachun in #3909
- feat: support to create & drop flow via grpc by @WenyXu in #3915
- feat: implement the CompositeTableRouteby @WenyXu in #3918
- feat: migrate orc-rs to datafusion-orc by @realtaobo in #3923
- feat: create database with options by @tizee in #3751
- feat(flow): render source/sink by @discord9 in #3903
- feat: introduce TableRouteCachetoPartitionRuleManagerby @WenyXu in #3922
- feat: limiting the size of query results to Dashboard by @realtaobo in #3901
- feat: support to invalidate flow cache by @WenyXu in #3926
- feat: create view by @killme2008 in #3807
- feat: use txn to impl cas by @fengjiachun in #3936
- feat(flow): add types for every plan enum variant by @discord9 in #3938
- feat(flow): flow worker by @discord9 in #3934
- feat(fuzz): add validator for inserted rows by @CookiePieWw in #3932
- feat(flow): query table schema&refactor by @discord9 in #3943
- feat: ignore internal columns in SHOW CREATE TABLEby @WenyXu in #3950
- feat(cli): export metric physical tables first by @WenyXu in #3949
- feat: support any precision in PromQL by @Taylor-lagrange in #3933
- feat(flow): avg func rewrite to sum/count by @discord9 in #3955
- feat(flow): flow node manager by @discord9 in #3954
- feat(flow): expire arrange according to time_index type by @discord9 in #3956
- feat: limit total rows copied in COPY TABLE FROM with LIMIT segment by @irenjj in #3910
- feat: remove timeout in the channel between frontend and datanode by @waynexia in #3962
- feat: skip read-only region when trying to flush on region full by @waynexia in #3966
- feat: support evaluate expr in range query param by @Taylor-lagrange in #3823
- feat(flow): tumble window func by @discord9 in #3968
- feat(cli): prevent exporting physical table data by @WenyXu in #3978
π Bug Fixesβ
- fix(readme): fix link of Ingester-js by @DiamondMofeng in #3668
- fix: DeserializedValueWithBytes::from_innermisusing by @WenyXu in #3676
- fix: cli export "create table" with quoted names by @dimbtp in #3684
- fix(alter_table): ignore request outdated error by @WenyXu in #3715
- fix: remove ttl option from metadata region by @waynexia in #3726
- fix: set is_time_index properly on updating physical table's schema by @waynexia in #3770
- fix: the dropping_regionsguards should be dropped on procedure done by @MichaelScofield in #3771
- fix: operating region guards should be dropped when procedure is done by @MichaelScofield in #3775
- fix: consider both db param and extended db header in Prometheus HTTP API by @waynexia in #3776
- fix: do not remove deletion markers when window time range overlaps by @v0y4g3r in #3773
- fix: promql scalar when input empty batch by @Taylor-lagrange in #3779
- fix: post process result on query full column name of prom labels API by @waynexia in #3793
- fix: fix fuzz test ci by @WenyXu in #3795
- fix: prune row groups correctly for columns with the same name by @evenyag in #3802
- fix: push down order hint of the query again by @evenyag in #3797
- fix: wrong handler implementation of prometheus remote write by @waynexia in #3826
- fix: broken link in contributing guide by @waynexia in #3831
- fix: compiler warnings on Windows by @evenyag in #3844
- fix: count_wildcard_to_time_index_rule doesn't handle table reference properly by @waynexia in #3847
- fix: retrieve all info instead of checking on demand by @WenyXu in #3846
- fix: register regions during procedure recovery by @WenyXu in #3859
- fix: return metric name instead of query in Prometheus /series API by @waynexia in #3864
- fix: add data type to vector cache key by @evenyag in #3876
- fix: memory leak in unit test of telemetry by @waynexia in #3897
- by @waynexia
- fix: sort unstable HTTP result in label values query by @waynexia in #3920
- fix: potential deadlock by @WenyXu in #3930
- fix(metric engine): label mismatch in metric engine by @v0y4g3r in #3927
- fix: prevent exporting metric physical table data by @WenyXu in #3970
- fix: prevent registering logical regions with AliveKeeper by @WenyXu in #3965
- fix: changing column data type can't process type alias by @killme2008 in #3972
- fix: tql parser hang on abnormal input by @waynexia in #3977
π Refactorβ
- refactor: pass http method to metasrv http handler by @tisonkun in #3667
- refactor(flow): func spec api&use Error not EvalError in mfp by @discord9 in #3657
- refactor: bundle the lightweight axum test client by @tisonkun in #3669
- refactor: refactor alter table procedure by @WenyXu in #3678
- refactor: drop table procedure by @WenyXu in #3688
- refactor: check error type before logging by @sunng87 in #3697
- refactor: Move manifest manager lock to MitoRegionby @evenyag in #3689
- refactor: use toml2docs to generate config docs by @zyy17 in #3704
- refactor: remove redundant try_flush invocations by @tisonkun in #3706
- refactor: merge RegionHandleResult into RegionHandleResponse by @tisonkun in #3721
- refactor(meta): Ensure all moving values remain unchanged between two transactions by @WenyXu in #3727
- refactor: avoid unnecessary cloning by @WenyXu in #3734
- refactor: avoid unnecessary alloc by using unwrap_or_else by @etolbakov in #3742
- refactor(flow): split render.rs and other minor changes by @discord9 in #3750
- refactor: move the version string to common by @MichaelScofield in #3783
- refactor: simplify the PaginationStream by @WenyXu in #3787
- refactor(flow): refine comments and code by @zhongzc in #3785
- refactor: log statement on error by Display by @tisonkun in #3803
- refactor: refactor DatanodeManagertoNodeManagerby @WenyXu in #3811
- refactor: DfUdfAdapter to bridge ScalaUdf by @tisonkun in #3814
- refactor: remove location_opt and DebugFormat by @waynexia in #3830
- refactor: use secrecy SerectString to hold secrets option by @tisonkun in #3804
- refactor: rename flow task to flow by @WenyXu in #3833
- refactor: remove catalog prefix by @WenyXu in #3835
- refactor: remove TableMetaKeytrait by @WenyXu in #3837
- refactor: move database client to test by @dimbtp in #3820
- refactor: remove re-export from logging by @waynexia in #3865
- refactor: passing QueryContext to RegionServer by @Kelvinyu1117 in #3829
- refactor: add the main cli entry point struct Command{}and simplifymain()by @zyy17 in #3850
- refactor: move Pluginstoplugins.rsand use rwlock by @zyy17 in #3862
- refactor(logstore): remove Entry::namemspace by @v0y4g3r in #3875
- refactor: move mirror insertion tasks to the background runtime by @WenyXu in #3879
- refactor: remove MixOptions and use StandaloneOptions only by @zyy17 in #3893
- refactor: add procedure_loadermacro by @WenyXu in #3906
- refactor: make txn easy to use by @fengjiachun in #3905
- refactor: Remove PhysicalPlan trait and use ExecutionPlan directly by @evenyag in #3894
- refactor: refactor frontend cache by @WenyXu in #3912
- refactor: rename metasrv_addr to metasrv_addrs by @fengjiachun in #3921
- refactor: add tracing options in xOptions by @zyy17 in #3919
- refactor: add Configurabletrait by @zyy17 in #3917
- refactor(naming): use the better naming for pubsub by @zyy17 in #3960
π Documentationβ
- docs: update memtable config example by @evenyag in #3712
- docs: add style guide by @waynexia in #3730
- docs: add how-to-write-fuzz-tests.md by @WenyXu in #3763
- docs: run fuzz tests in dev mode & disable sanitizer by @WenyXu in #3871
- docs: correct v0.7 benchmark report by @waynexia in #3907