Releases: StarRocks/starrocks
3.3.2
Release date: August 8, 2024
New Features
-
Supports renaming columns within StarRocks internal tables. #47851
-
Supports reading Iceberg views. Currently, only Iceberg views created through StarRocks are supported. #46273
-
[Experimental] Supports adding and removing fields of STRUCT-type data. #46452
-
Supports specifying the compression level for ZSTD compression format during table creation. #46839
-
Added the following FE dynamic parameters to limit table boundaries. #47896
Including:
auto_partition_max_creation_number_per_load
max_partition_number_per_table
max_bucket_number_per_partition
max_column_number_per_table
-
Supports runtime optimization of table data distribution, ensuring optimization tasks do not conflict with DML operations on the table. #43747
-
Added an observability interface for the global hit rate of Data Cache. #48450
-
Added the SQL function array_repeat. #47862
Improvements
-
Optimized the error messages for Routine Load failures due to Kafka authentication failures. #46136 #47649
-
Stream Load supports using
\t
and\n
as row and column delimiters. Users do not need to convert them to their hexadecimal ASCII codes. #47302 -
Optimized the asynchronous statistics collection method for write operators, addressing the issue of increased latency when there are many import tasks. #48162
-
Added the following BE dynamic parameters to control resource hard limits during loading, reducing the impact on BE stability when writing a large number of tablets. #48495
Including:
load_process_max_memory_hard_limit_ratio
enable_new_load_on_memory_limit_exceeded
-
Added consistency checks for Column IDs within the same table to prevent Compaction errors. #48498
-
Supports persisting PIPE metadata to prevent metadata loss due to FE restarts. #48852
Bug Fixes
- The process could not end when creating a dictionary from an FE Follower. #47802
- Inconsistent information returned by the SHOW PARTITIONS command in shared-data clusters and shared-nothing clusters. #48647
- Data errors caused by incorrect type handling when loading data from JSON fields to
ARRAY<BOOLEAN>
columns. #48387 - The
query_id
column ininformation_schema.task_runs
cannot be queried. #48876 - During Backup, multiple requests for the same operation are submitted to different Brokers, causing request errors. #48856
- Downgrading to versions earlier than v3.1.11 or v3.2.4 causes Primary Key table index decompression failures, leading to query errors. #48659
Downgrade Notes
If you have used the renaming column feature, you must rename the columns to their original names before downgrading your cluster to an earlier version. You can check the audit log of your cluster after upgrading to identify any ALTER TABLE RENAME COLUMN
operations and the original names of the columns.
3.1.14
Release date: July 29, 2024
Improvements
- Stream Load now supports using
\t
and\n
as row and column delimiters. Users do not need to convert them to their hexadecimal ASCII codes. #47302
Bug Fixes
Fixed the following issues:
- Frequent INSERT and UPDATE operations on Primary Key tables may cause write and query delays in the database. #47838
- When a Primary Key table encounters data persistence failures, the persistent index may fail to capture the error, leading to data loss and reporting the error "Insert found duplicate key". #48045
- Materialized views may report insufficient permissions when refreshed. #47561
- Materialized view reports the error "For input string" when refreshed. #46131
- During materialized view refresh, the lock is held excessively long, causing the Leader FE to be restarted by the deadlock detection script. #48256
- Queries against views with the IN clause in its definition may return inaccurate results. #47484
- Global Runtime Filter causes incorrect results. #48496
- MySQL protocol
COM_CHANGE_USER
does not supportconn_attr
. #47796
Behavior Changes
- When users create a non-partitioned table without specifying the bucket number, the minimum bucket number the system sets for the table is
16
(instead of2
based on the formula2*BE or CN count
). If users want to set a smaller bucket number when creating a small table, they must set it explicitly. #47005
3.3.1
Release date: July 18, 2024
New Features
- [Preview] Supports temporary tables.
- [Preview] JDBC Catalog supports Oracle and SQL Server.
- [Preview] Unified Catalog supports Kudu.
- Loading data into Primary Key tables with INSERT INTO supports partial updates in column mode.
- User-defined variables support the ARRAY type. #42631
- Stream Load supports converting JSON-type data and loading it into columns of STRUCT/MAP/ARRAY types. #45406
- Supports global dictionary cache.
- Supports deleting partitions in batch. #44744
- Supports queries on Iceberg views. #46273
- Supports managing column-level permissions in Apache Ranger. (Column-level permissions for materialized views and views must be set under the table object.) #47702
Improvements
- Optimized the IdChain hashcode implementation to reduce the FE restart time. #47599
- Improved error messages for the
csv.trim_space
parameter in the FILES() function, checking for illegal characters and providing reasonable prompts. #44740 - Stream Load supports using
\t
and\n
as row and column delimiters. Users do not need to convert them to their hexadecimal ASCII codes. #47302
Bug Fixes
Fixed the following issues:
- Schema Change failures due to file location changes caused by Tablet migration during the Schema Change process. #45517
- Cross-cluster Data Migration Tool fails to create tables in the target cluster due to control characters such as
\
,\r
in the default values of fields. #47861 - Persistent bRPC failures after BE restarts. #40229
- The
user_admin
role can change the root password using the ALTER USER command. #47801 - Primary key index write failures cause data write errors. #48045
Behavior Changes
- Intermediate result spilling is enabled by default when sinking data to Hive and Iceberg. #47118
- Changed the default value of the BE configuration item
max_cumulative_compaction_num_singleton_deltas
to500
. #47621 - When users create a partitioned table without specifying the bucket number, if the number of partitions exceeds 5, the rule for setting the bucket count is changed to
max(2*BE or CN count, bucket number calculated based on the largest historical partition data volume)
. The previous rule was to calculate the bucket number based on the largest historical partition data volume). #47949
Downgrade notes
To downgrade a cluster from v3.3.1 or later to v3.2, users must clean all temporary tables in the cluster by following these steps:
-
Disallow users to create new temporary tables:
ADMIN SET FRONTEND CONFIG("enable_experimental_temporary_table"="false");
-
Check if there are any temporary tables in the cluster:
SELECT * FROM information_schema.temp_tables;
-
If there are temporary tables in the system, clean them up using the following command (the SYSTEM-level OPERATE privilege is required):
CLEAN TEMPORARY TABLE ON SESSION 'session';
3.2.9
New Features
- Paimon tables now support DELETE Vectors. #45866
- Supports Column-level access control through Apache Ranger. #47702
- Stream Load can automatically convert JSON strings into STRUCT/MAP/ARRAY types during loading. #45406
- JDBC Catalog now supports Oracle and SQL Server. #35691
Improvements
- Improved privilege management by restricting user_admin role users from resetting the password of the root user. #47801
- Stream Load now supports using \t and \n as row and column delimiters. Users do not need to convert them to their hexadecimal ASCII codes. #47302
- Optimized memory usage during data loading. #47047
- Supports masking authentication information for the Files() function in audit logs. #46893
- Hive tables now support the skip.header.line.count property. #47001
- JDBC Catalog supports more data types. #47618
Bug Fixes
Fixed the following issues:
- BE crash caused by ALTER TABLE ADD COLUMN after upgrading a shared-data cluster from v3.2.x to v3.3.0 and then rolling it back. #47826
- Tasks initiated through SUBMIT TASK showed a Running status indefinitely in the QueryDetail interface. #47619
- Forwarding queries to the FE Leader node caused a null pointer exception. #47559
- SHOW MATERIALIZED VIEWS with WHERE conditions caused a null pointer exception. #47811
- Vertical Compaction fails for Primary Key tables in shared-data clusters. #47192
- Improper handling of I/O Error when sinking data to Hive or Iceberg tables. #46979
- Table properties do not take effect when whitespaces are added to their values. #47119
- BE crash caused by concurrent migration and Index Compaction operations on Primary Key tables. #46675
3.3.0
New Features and Improvements
Shared-data Cluster
- Optimized the performance of Schema Evolution in shared-data clusters, reducing the time consumption of DDL changes to a sub-second level. For more information, see Schema Evolution.
- To satisfy the requirement for data migration from shared-nothing clusters to shared-data clusters, the community officially released the StarRocks Data Migration Tool. It can also be used for data synchronization and disaster recovery between shared-nothing clusters.
- [Preview] AWS Express One Zone Storage can be used as storage volumes, significantly improving read and write performance. For more information, see CREATE STORAGE VOLUME.
- Optimized the garbage collection (GC) mechanism in shared-data clusters. Supports manual compaction for data in object storage. For more information, see Manual Compaction.
- Optimized the Publish execution of Compaction transactions for Primary Key tables in shared-data clusters, reducing I/O and memory overhead by avoiding reading primary key indexes.
Data Lake Analytics
- Data Cache enhancements
- Added the Data Cache Warmup command CACHE SELECT to fetch hotspot data from data lakes, which speeds up queries and minimizes resource usage. CACHE SELECT can work with SUBMIT TASK to achieve periodic cache warmup. This feature supports both tables in external catalogs and internal tables in shared-data clusters.
- Added metrics and monitoring methods to enhance the observability of Data Cache.
- Parquet reader performance enhancements
- Optimized Page Index, significantly reducing the data scan size.
- Reduced the occurrence of reading unnecessary pages when Page Index is used.
- Uses SIMD to accelerate the computation to determine whether data rows are empty.
- ORC reader performance enhancements
- Uses column ID for predicate pushdown to read ORC files after Schema Change.
- Optimized the processing logic for ORC tiny stripes.
- Iceberg table format enhancements
- Significantly improved the metadata access performance of the Iceberg Catalog by refactoring the parallel Scan logic. Resolved the single-threaded I/O bottleneck in the native Iceberg SDK when handling large volumes of metadata files. As a result, queries with metadata bottlenecks now experience more than a 10-fold performance increase.
- Queries on Parquet-formatted Iceberg v2 tables support equality deletes.
- [Experimental] Paimon Catalog enhancements
- Materialized views created based on the Paimon external tables now support automatic query rewriting.
- Optimized Scan Range scheduling for queries against the Paimon Catalog, improving I/O concurrency.
- Support for querying Paimon system tables.
- Paimon external tables now support DELETE Vectors, enhancing query efficiency in update and delete scenarios.
- Enhancements in collecting external table statistics
- ANALYZE TABLE can be used to collect histograms of external tables, which helps prevent data skews.
- Supports collecting statistics of STRUCT subfields.
- Table sink enhancements
- The performance of the Sink operator is doubled compared to Trino.
- Data can be sunk to Textfile- and ORC-formatted tables in Hive catalogs and storage systems such as HDFS and cloud storage like AWS S3.
- [Preview] Supports Alibaba Cloud MaxCompute catalogs, with which you can query data from MaxCompute without ingestion and directly transform and load the data from MaxCompute by using INSERT INTO.
- [Experimental] Supports ClickHouse Catalog.
- [Experimental] Supports Kudu Catalog.
Performance Improvement and Query Optimization
- Optimized performance on ARM.
Significantly optimized performance for ARM architecture instruction sets. Performance tests under AWS Graviton instances showed that the ARM architecture was 11% faster than the x86 architecture in the SSB 100G test, 39% faster in the Clickbench test, 13% faster in the TPC-H 100G test, and 35% faster in the TPC-DS 100G test. - Spill to Disk is in GA. Optimized the memory usage of complex queries and improved spill scheduling, allowing large queries to run stably without OOM.
- [Preview] Supports spilling intermediate results to object storage.
- Supports more indexes.
- [Preview] Supports full-text inverted index to accelerate full-text searches.
- [Preview] Supports N-Gram bloom filter index to speed up LIKE queries and the computation speed of ngram_search and ngram_search_case_insensitive functions.
- Improved the performance and memory usage of Bitmap functions. Added the capability to export Bitmap data to Hive by using Hive Bitmap UDFs.
- [Preview] Supports Flat JSON. This feature automatically detects JSON data during data loading, extracts common fields from the JSON data, and stores these fields in a columnar manner. This improves JSON query performance, comparable to querying STRUCT data.
- [Preview] Optimized global dictionary. provides a dictionary object to store the mapping of key-value pairs from a dictionary table in the BE memory. A new dictionary_get() function is now used to directly query the dictionary object in the BE memory, accelerating the speed of querying the dictionary table compared to using the dict_mapping() function. Furthermore, the dictionary object can also serve as a dimension table. Dimension values can be obtained by directly querying the dictionary object using dictionary_get(), resulting in faster query speeds than the original method of performing JOIN operations on the dimension table to obtain dimension values.
- [Preview] Supports Colocate Group Execution. significantly reduces memory usage for executing Join and Agg operators on the colocated tables, which ensures that large queries can be executed more stably.
- Optimized the performance of CodeGen. JIT is enabled by default, which achieves a 5X performance improvement for complex expression calculations.
- Supports using vectorization technology to implement regular expression matching, which reduces the CPU consumption of the regexp_replace function.
- Optimized Broadcast Join so that the Broadcast Join operation can be terminated in advance when the right table is empty.
- Optimized Shuffle Join in scenarios of data skew to prevent OOM.
- When an aggregate query contains Limit, multiple Pipeline threads can share the Limit condition to prevent compute resource consumption.
Storage Optimization and Cluster Management
- Enhanced flexibility of range partitioning. Three time functions can be used as partitioning columns. These functions convert timestamps or strings in the partitioning columns into date values and then the data can be partitioned based on the converted date values.
- FE memory observability. Provides detailed memory usage metrics for each module within the FE to better manage resources.
- Optimized metadata locks in FE. Provides Lock manager to achieve centralized management for metadata locks in FE. For example, it can refine the granularity of metadata lock from the database level to the table level, which improves load and query concurrency. In a scenario of 100 concurrent load jobs, the load time can be reduced by 35%.
- Supports adding labels on BEs. Supports adding labels on BEs based on information such as the racks and data centers where BEs are located. It ensures even data distribution among racks and data centers, and facilitates disaster recovery in case of power failures in certain racks or faults in data centers.
- Optimized the sort key. Duplicate Key tables, Aggregate tables, and Unique Key tables all support specifying sort keys through the ORDER BY clause.
- [Experimental] Optimized the storage efficiency of non-string scalar data. This type of data supports dictionary encoding, reducing storage space usage by 12%.
- Supports size-tiered compaction for Primary Key tables. Reduces write I/O and memory overhead during compaction. This improvement is supported in both shared-data and shared-nothing clusters.
- Optimized read I/O for persistent indexes in Primary Key tables. Supports reading persistent indexes by a smaller granularity (page) and improves the persistent index's bloom filter. This improvem...
Release notes 3.1.13
Release date: June 26, 2024
Improvements
- The Broker process supports access to Tencent Cloud COS Posix buckets. Users can load data from COS Posix buckets using Broker Load or unload data to COS Posix buckets using the SELECT INTO OUTFILE statement. #46597
- Supports viewing comments of Hive tables in Hive Catalogs using SHOW CREATE TABLE. #37686
- Optimized the evaluation time of Conjunct in WHERE clauses, such as multiple LIKE clauses on the same column or CASE WHEN expressions. #46914
Bug Fixes
Fixed the following issues:
- DELETE statements fail in shared-data clusters if there are excessive number of partitions to be deleted. #46229
Release notes 2.5.22
Release date: June 20, 2024
Improvements
- Optimized a partition check logic used for building query execution plan, significantly reducing the time consumption of complex queries that involve multiple tables. #46781
Bug Fixes
Fixed the following issues:
- Function Call does not handle child errors correctly. #42590
- The internal data statistics were not cleaned up regularly, causing inaccurate estimated information and thereby inefficient query plans. This will cause a drop in query performance and a surge in memory usage. #45839
- Using a stale column histogram may lead to the Division by Zero exception. #45614
Realease notes 3.2.8
Release date: June 7, 2024
New Features
- Supports adding labels on BEs: Supports adding labels on BEs based on information such as the racks and data centers where BEs are located. It ensures even data distribution among racks and data centers, and facilitates disaster recovery in case of power failures in certain racks or faults in data centers. #38833
Bug Fixes
Fixed the following issues:
- An error is returned when users DELETE data rows from tables that use the expression partitioning method with str2date. #45939
- BEs in the destination cluster crash when the StarRocks Cross-cluster Data Migration Tool fails to retrieve the Schema information from the source cluster. #46068
- The error Multiple entries with same key is returned to queries with non-deterministic functions. #46602
Release notes 3.1.12
Release date: May 30, 2024
New Features
- Flink connector supports reading complex data types ARRAY, MAP, and STRUCT from StarRocks. #42932 #347
Improvements
- When using the Broker process, Broker Load supports loading data from COS posix buckets, and SELECT ... FROM ... INTO OUTFILE supports unloading data to COS posix buckets. The format of the path parameter is cosn://some_bucket/xxx. #46090
- Previously, when BE failed to communicate with FE via RPC, FE would return a generic error message: call frontend service failed reason=xxx, making it unclear what the specific issue was. The error messages are now optimized to include specific reasons, such as timeout or server busy. #44153
- Improved error messages to indicate specific issues during data loading, such as the number of error data rows exceeding limits, mismatched column numbers, invalid column names, and no data in any partition.
Security
- Upgraded Kafka client dependency to v3.4.0 to fix the CVE-2023-25194 security issue. #45382
Bug Fixes
Fixed the following issues:
- If a materialized view definition includes multiple self-joins of the same table and incremental refreshes by partitions based on that table, incorrect results would occur due to wrong partition selection. #45936
- FEs crash when a Bitmap index is created in a materialized view in shared-data clusters causes . #45665
- BEs crash due to null pointer issues when FE follower is connected via ODBC and CREATE TABLE is executed. #45043
- Querying information_schema.task_runs fails frequently when many asynchronous tasks exist. #45520
- When a SQL statement contains multiple COUNT DISTINCT and includes LIMIT, LIMIT is wrongly processed, resulting in inconsistent data returned each time the statement is executed. #44749
- Queries with ORDER BY LIMIT clauses on Duplicate Key tables and Aggregate tables produce incorrect results. #45037
Release notes 3.2.7
Release date: May 25, 2024
New Features
- Stream Load supports data compression during transmission, reducing network bandwidth overhead. Users can specify different compression algorithms using parameters compression and Content-Encoding. Supported compression algorithms including GZIP, BZIP2, LZ4_FRAME, DEFLATE, and ZSTD. #43732
- Optimized the garbage collection (GC) mechanism in shared-data clusters. Supports manual compaction for tables or partitions stored in object storage. #39532
- Flink connector supports reading complex data types ARRAY, MAP, and STRUCT from StarRocks. #42932 #347
- Supports populating Data Cache asynchronously during queries, reducing the impact of populating cache on query performance. #40489
- ANALYZE TABLE supports collecting histograms for external tables, effectively addressing data skews. For more information, see CBO statistics. #42693
- Lateral Join with UNNEST supports LEFT JOIN. #43973
- Query Pool supports configuring memory usage threshold that triggers spilling via BE static parameter
query_pool_spill_mem_limit_threshold
. Once the threshold is reached, intermediate results of queries will be spilled to disks to reduce memory usage, thus avoiding OOM.#44063 - Supports creating asynchronous materialized views based on Hive views.#45085
Improvements
- Optimized the error message returned for Broker Load tasks when there is no data under the specified HDFS paths. #43839
- Optimized the error message returned when the Files function is used to read data from AWS S3 without Access Key and Secret Key specified. #42450
- Optimized the error message returned for Broker Load tasks that load no data to any partitions. #44292
- Optimized the error message returned for INSERT INTO SELECT tasks when the column count of the destination table does not match that in the SELECT statement. #44331
Bug Fixes
Fixed the following issues:
- Concurrent read or write of the BITMAP-type data may cause BE to crash. #44167
- Primary key indexes may cause BE to crash. #43793 #43569 #44034
- Under high query concurrency scenarios, the str_to_map function may cause BE to crash. #43901
- When the Masking policy of Apache Ranger is used, an error is returned when table aliases are specified in queries. #44445
- In shared-data clusters, query execution cannot be routed to a backup node when the current node encounters exceptions. The corresponding error message is optimized for this issue. #43489
- Memory information is incorrect in the container environment. #43225
- An exception is thrown when INSERT tasks are canceled. #44239
- Expression-based dynamic partitions cannot be automatically created. #44163
- Creating partitions may cause FE deadlock. #44974