Version 4.0.0
Note
If you are upgrading a cluster, you must be running CrateDB 3.0.4 or higher before you upgrade to 4.0.0.
We recommend that you upgrade to the latest 3.3 release before moving to 4.0.0.
An upgrade to Version 4.0.0 requires a .
When restarting, CrateDB will migrate indexes to a newer format. Depending on the amount of data, this may delay node start-up time.
Please consult the Upgrade Notes before upgrading.
Warning
Tables that were created prior CrateDB 3.x will not function with 4.x and must be recreated before moving to 4.x.x.
You can recreate tables using and COPY FROM
or by .
Before upgrading, you should back up your data.
Table of Contents
This version of CrateDB uses a new cluster coordination (discovery) implementation which improves resiliency and master election times. A new voting mechanism is used when a node is removed or added which makes the system capable of automatically maintaining an optimal level of fault tolerance even in situations of network partitions.
This eliminates the need of the easily miss configured minimum_master_nodes
setting.
Additionally a rare resiliency failure, recorded as can no longer occur.
Due to this some discovery settings are added, renamed and removed.
Caution
The cluster.initial_master_nodes setting is required to be set at production (non loopback bound) clusters on upgrade, see the for details.
Only a single port value is allowed for each discovery.seed_hosts
setting entry. Defining a port range as it was allowed but ignored in previous versions under the old setting name discovery.zen.ping.unicast.hosts
, will be rejected.
Note
CrateDB will refuse to start when it encounters an unknown setting, like the above mentioned removed ones. Please make sure to adjust your crate.yml
or CMD arguments upfront.
Renamed CrateDB data types to the corresponding PostgreSQL data types.
See Data types for more detailed information. The old data type names, are registered as aliases for backward comparability.
Changed the ordering of columns to be based on their position in the statement. This was done to improve compatibility with PostgreSQL and will affect queries like
SELECT * FROM
orINSERT INTO <table> VALUES (...)
Changed the default Column policy on tables from
dynamic
tostrict
. Columns of type object still default todynamic
.Dropped support for Java versions < 11
Removed Settings
Removed the deprecated setting
cluster.graceful_stop.reallocate
.Removed the deprecated
http.enabled
setting. is now always enabled and can no longer be disabled.Removed the deprecated
license.ident
setting. Licenses must be set using the statement.Removed the deprecated
license.enterprise
setting. To use CrateDB without any enterprise features one should use the community edition instead.Removed the experimental
enable_semijoin
session setting. As this defaulted to false, this execution strategy cannot be used anymore.Removed the possibility of configuring the AWS S3 repository client via the
crate.yaml
configuration file and command line arguments. Please, use the CREATE REPOSITORY statement parameters for this purpose.Removed :
concurrent_streams
as it is no longer supported.The
zen1
related discovery settings mentioned in Discovery Changes.
Changed the layout of the
version
column in theinformation_schema.tables
andinformation_schema.table_partitions
tables. The version is now displayed directly undercreated
andupgraded
. Thecratedb
andelasticsearch
sub-category has been removed.Removed deprecated metrics from :
Renamed column
information_schema.table_partitions.schema_name
totable_schema
.Renamed
information_schema.columns.user_defined_type_*
columns toinformation_schema_columns.udt_*
for SQL standard compatibility.
The Elasticsearch REST API has been removed.
Removed the deprecated
ingest
framework, including theMQTT
endpoint.Removed the HTTP pipelining functionality. We are not aware of any client using this functionality.
Removed the deprecated average duration and query frequency JMX metrics. The total counts and sum of durations as documented in QueryStats MBean should be used instead.
Removed the deprecated
ON DUPLICATE KEY
syntax of statements. Users can migrate to theON CONFLICT
syntax.Removed the
index
thread-pool and thebulk
alias for the thread-pool. The JMXgetBulk
property of theThreadPools
bean has been renamed toogetWrite
.Removed deprecated
nGram
,edgeNGram
token filter andhtmlStrip
char filter, they are superseded byngram
,edge_ngram
andhtml_strip
.Removed the deprecated
USR2
signal handling. Use ALTER CLUSTER DECOMMISSION instead. Be aware that the behavior of sendingUSR2
signals to a CrateDB process is now undefined and up to the JVM. In some cases it may still terminate the instance but without clean shutdown.
Deprecate the usage of the column for Optimistic Concurrency Control in favour of the and _primary_term columns.
Deprecate the usage of the data type as a timestamp with time zone, use TIMESTAMP WITH TIME ZONE or instead. The
TIMESTAMP
data type will be an equivalent to data type without time zone in futureCrateDB
releases.Marked SynonymFilter tokenizer as deprecated.
Marked LowerCase tokenizer as deprecated.
Added support for using relation aliases with column aliases. Example:
SELECT x, y from unnest([1], ['a']) as u(x, y)
Added support for column Default clause for .
Extended the support for window functions. The
PARTITION BY
definition and theCURRENT ROW -> UNBOUNDED FOLLOWING
frame definitions are now supported.Added the aggregation function.
Added support for to the Date and time types.
Added the alias for the TIMESTAMP WITH TIME ZONE data type.
Added support for the cast operator, which is used to initialize a constant of an arbitrary type.
Added the scalar function to enhance PostgreSQL compatibility.
Enabled scalar function when used in the query FROM clause in place of a relation.
Show the session setting description in the output of the
SHOW ALL
statement.Added information for the internal PostgreSQL data type:
name
in for improved PostgreSQL compatibility.Added the pg_catalog.pg_settings table.
Added support for .
Added trim scalar function that trims the (leading, trailing or both) set of characters from an input string.
Added scalar function that splits an input string into an array of string elements using a separator and a null-string.
Added missing PostgreSQL type mapping for the
array(ip)
collection type.Added current_setting system information scalar function that yields the current value of the setting.
Allow to be registered against the
pg_catalog
schema. This also extends CURRENT_SCHEMA to be addressable withpg_catalog
included.Added scalar function that quotes a string if it is needed.
Mask sensitive user account information in sys.repositories for repository types:
azure
,s3
.Restrict access to log entries in and sys.jobs_log to the current user. This doesn’t apply to superusers.
Added a new
Administration Language (AL)
privilege type which allows users to manage other users and useSET GLOBAL
. See .
Added support for the Azure Storage repositories.
Changed the default value of the
fs
repository type settingcompress
, totrue
. See .Improved resiliency of the CREATE SNAPSHOT operation.
Performance and resiliency improvements
Exposed the and _primary_term system columns which can be used for . By introducing _seq_no and , the following resiliency issues were fixed:
Predicates like
abs(x) = 1
which require a scalar function and cannot operate on table indices directly are now candidates for the query cache. This can result in order of magnitude performance increases on subsequent queries.Routing awareness attributes are now also taken into consideration for primary key lookups. (Queries like
SELECT * FROM t WHERE pk = 1
)Changed the circuit breaker logic to measure the real heap usage instead of the memory reserved by child circuit breakers. This should reduce the chance of nodes running into an out of memory error.
Added a new optimization that allows to run predicates on top of views or sub-queries more efficiently in some cases.
Added support for dynamical reloading of SSL certificates. See Configuring the Keystore.
Added
minimum_index_compatibility_version
andminimum_wire_compatibility_version
to to expose the current state of the node’s index and wire protocol version as part of the sys.nodes table.Upgraded to Lucene 8.0.0, and as part of this the BM25 scoring has changed. The order of the scores remain the same, but the values of the scores differ. Fulltext queries including
_score
filters may behave slightly different.