CockroachDB v23.2 (LTS) is a required Regular Release.
Refer to Major release types before installing or upgrading for release timing and support details. To learn what's new in this release, refer to its Feature Highlights.
On this page, you can read about changes and find downloads for all production and testing releases of CockroachDB v23.2 (LTS)
- For key feature enhancements in v23.2 and other upgrade considerations, refer to the notes for v23.2.0. 
- For details about release types, naming, and licensing, refer to the Releases page. 
- Be sure to also review the Release Support Policy. 
- After downloading a supported CockroachDB binary, learn how to install CockroachDB or upgrade your cluster. 
Get future release notes emailed to you:
v23.2.28
Release Date: September 4, 2025
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.28.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.28.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.28.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.28.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.28.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.28.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.28.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.28.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.28.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.28.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.28
Source tag
To view or download the source code for CockroachDB v23.2.28 on Github, visit v23.2.28 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.27...v23.2.28
Performance improvements
- Lookup joins can now be used on tables with virtual columns even if the type of the search argument is not identical to the column type referenced in the virtual column. #152926
v23.2.27
Release Date: June 25, 2025
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.27.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.27.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.27.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.27.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.27.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.27.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.27.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.27.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.27.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.27.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.27
Source tag
To view or download the source code for CockroachDB v23.2.27 on Github, visit v23.2.27 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.26...v23.2.27
Operational changes
- The goschedstats.always_use_short_sample_period.enabledcluster setting should be set totruefor any serious production cluster; this will prevent unnecessary queuing in admission control CPU queues. #146742
Bug fixes
- Fixed a bug that could potentially cause a changefeed to complete erroneously when one of its watched tables encounters a schema change. #147040
- Fixed a bug that caused the SQL Activity > Statement Fingerprint page to fail to load details for statements run with application names containing a #character. #147219
- Fixed a bug that could cause the cockroachprocess tosegfaultwhen collecting runtime execution traces (typically collected via the Advanced Debug page in the Console). #147339
- Fixed a bug that could cause stable expressions to be folded in cached query plans. The bug could cause stable expressions like current_settingto return the wrong result if used in a prepared statement. The bug was introduced in v23.2.22, v24.1.14, v24.3.9, v25.1.2, and the v25.2 alpha. #147456
Performance improvements
- TTL jobs now respond to cluster topology changes by restarting and rebalancing across available nodes. #147224
v23.2.26
Release Date: May 28, 2025
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.26.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.26.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.26.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.26.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.26.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.26.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.26.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.26.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.26.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.26.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.26
Source tag
To view or download the source code for CockroachDB v23.2.26 on Github, visit v23.2.26 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.25...v23.2.26
Bug fixes
- Fixed a bug where using values for the cluster setting changefeed.aggregator.flush_jitterand the changefeed optionmin_checkpoint_frequencyresulting inchangefeed.aggregator.flush_jitter * min_checkpoint_frequency < 1would cause a panic. Jitter will now be disabled in this case. #144423
- Improved the performance of SHOW CREATE TABLEon multi-region databases with a large numbers of objects. #145081
- Fixed an internal assertion failure that could occur during operations like ALTER TYPEorALTER DATABASE ... ADD REGIONwhen temporary tables were present. #146200
- Fixed a bug that prevented TRUNCATEfrom succeeding if any indexes on the table had back-reference dependencies, such as from a view or function referencing the index. #146322
- Fixed a rare corruption bug that impacts import and materialized views. #144659
v23.2.25
Release Date: April 30, 2025
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.25.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.25.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.25.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.25.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.25.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.25.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.25.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.25.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.25.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.25.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.25
Source tag
To view or download the source code for CockroachDB v23.2.25 on Github, visit v23.2.25 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.24...v23.2.25
SQL language changes
- Added the WITH IGNORE_FOREIGN_KEYSoption toSHOW CREATE TABLEwhich omits foreign key constraints from the output schema. This option is also allowed inSHOW CREATE VIEW, but has no effect. It cannot be combined with theWITH REDACToption. #142165
Bug fixes
- Fixed a bug where CockroachDB would encounter an internal error when decoding the gists of plans with CALLstatements. The bug had been present since v23.2. #143312
- Fixed a bug that caused changefeeds to fail on startup when scanning a single key. #143147
- Fixed a bug that could cause a stack overflow during execution of a prepared statement that invoked a PL/pgSQL routine with a loop. The bug existed in versions v23.2.22, v24.1.15, v24.3.9, v25.1.2, v25.1.3, and pre-release versions of v25.2 prior to v25.2.0-alpha.3. #144029
- Fixed a bug that could leave behind a dangling reference to a dropped role if that role had default privileges granted to itself. The bug was caused by defining privileges such as: ALTER DEFAULT PRIVILEGES FOR ROLE self_referencing_role GRANT INSERT ON TABLES TO self_referencing_role. #143291
- MVCC garbage collection is now fully subject to IO admission control. Previously, it was possible for MVCC GC to cause store overload (such as LSM inversion) when a large amount of data would become eligible for garbage collection. Should any issues arise from subjecting MVCC GC to admission control, the kv.mvcc_gc.queue_kv_admission_control.enabledcluster setting can be set tofalseto restore the previous behavior. #143274
v23.2.24
Release Date: April 28, 2025
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.24.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.24.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.24.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.24.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.24.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.24.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.24.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.24.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.24.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.24.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.24
Source tag
To view or download the source code for CockroachDB v23.2.24 on Github, visit v23.2.24 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.23...v23.2.24
Bug fixes
- Fixed a rare corruption bug that impacts import and materialized views. #144659
v23.2.23
Release Date: April 9, 2025
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.23.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.23.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.23.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.23.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.23.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.23.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.23.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.23.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.23.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.23.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.23
Source tag
To view or download the source code for CockroachDB v23.2.23 on Github, visit v23.2.23 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.22...v23.2.23
Bug fixes
- Fixed a bug that could cause a stack overflow during execution of a prepared statement that invoked a PL/pgSQL routine with a loop. The bug existed in versions v23.2.22, v24.1.15, v24.3.9, v25.1.2, v25.1.3, and pre-release versions of v25.2 prior to v25.2.0-alpha.3. #144062
v23.2.22
Release Date: April 2, 2025
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.22.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.22.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.22.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.22.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.22.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.22.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.22.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.22.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.22.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.22.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.22
Source tag
To view or download the source code for CockroachDB v23.2.22 on Github, visit v23.2.22 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.21...v23.2.22
General changes
- The protected timestamp (PTS) records of running changefeeds are now updated when the set of targets changes, such as when system tables are added to the protected tables list. #141157
Bug fixes
- Fixed a bug that could cause gateway nodes to panic when performing an UPSERTon a table with aBOOLprimary key column and a partial index that used the primary key column as the predicate expression. #141825
- Fixed a rare bug in which a query could fail with the error could not find computed column expression for column in tablewhile dropping a virtual computed column from a table. This bug was introduced in v23.2.4. #139874
- Fixed a bug that could cause nil pointer dereferenceerrors when executing statements with user-defined functions (UDFs). The error could also occur when executing statements with some built-in functions, likeobj_description. #141666
Miscellaneous
- When configuring the sql.ttl.default_delete_rate_limitcluster setting, a notice is displayed informing the user that the TTL rate limit is per leaseholder per table with a link to the docs. #142831
v23.2.21
Release Date: March 6, 2025
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.21.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.21.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.21.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.21.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.21.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.21.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.21.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.21.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.21.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.21.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.21
Source tag
To view or download the source code for CockroachDB v23.2.21 on Github, visit v23.2.21 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.20...v23.2.21
SQL language changes
- Since v23.2, table statistics histograms have been collected for non-indexed JSONBcolumns. Histograms are no longer collected for these columns if thesql.stats.non_indexed_json_histograms.enabledcluster setting is set tofalse. This reduces memory usage during table statistics collection, for both automatic and manual collection viaANALYZEandCREATE STATISTICS. #140144
Bug fixes
- Fixed a bug where under rare circumstances draining a node could fail with some sessions did not respond to cancellation within 1s. #139479
- Fixed a bug that prevented the CREATEstatement for a routine from being shown in a statement bundle. This happened when the routine was created on a schema other thanpublic. The bug has existed since v23.1. #136131
- Fixed a bounded memory leak that could previously occur when evaluating some memory-intensive queries via the vectorized engine. The leak has been present since v20.2. #139098
- Previously, in changefeeds using CDC queries and the Parquet format, the output would include duplicate columns when it contained a user-defined primary key. Now, the columns are de-duplicated in Parquet changefeed messages. #140380
v23.2.20
Release Date: February 6, 2025
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.20.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.20.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.20.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.20.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.20.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.20.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.20.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.20.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.20.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.20.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.20
Source tag
To view or download the source code for CockroachDB v23.2.20 on Github, visit v23.2.20 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.19...v23.2.20
SQL language changes
- Since v23.2, table statistics histograms have been collected for non-indexed JSON columns. Histograms are no longer collected for these columns if the sql.stats.non_indexed_json_histograms.enabledcluster setting is set tofalse. This reduces memory usage during table statistics collection, for both automatic and manual collection viaANALYZEandCREATE STATISTICS. #140269
Operational changes
- The changefeed.max_behind_nanosmetric now supports scoping with metrics labels. #139241
Bug fixes
- Previously, SHOW CREATE TABLEwas showing incorrect data with regards to inverted indexes. It now shows the correct data that can be repeatedly entered back into CockroachDB to recreate the same table. #138167
- Fixed a bug where querying the pg_catalog.pg_constrainttable while the schema changer was dropping a constraint could result in a query error. #138286
- Fixed a bounded memory leak that could occur when collecting table statistics on a table that had both very wide (10KiB or more) and relatively small (under 400B) BYTES-like values within the same row. This leak had been present since before v19.2. #139177
- Fixed a bug where changefeeds using CDC queries could have duplicate columns in the Parquet output. #140155
- Fixed a bug that prevented the CREATEstatement for a routine from being included in a statement bundle when the routine was created on a schema other thanpublic. The bug had existed since v23.1. #140260
v23.2.19
Release Date: January 9, 2025
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.19.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.19.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.19.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.19.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.19.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.19.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.19.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.19.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.19.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.19.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.19
Source tag
To view or download the source code for CockroachDB v23.2.19 on Github, visit v23.2.19 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.18...v23.2.19
Security updates
- The cluster setting server.jwt_authentication.issuersnow takes the issuers configuration value from the URI. This can be set to one of the following values:- Simple string that can be parsed as a valid issuer URL. For example: 'https://accounts.google.com'.
- String that can be parsed as a valid JSON array of issuer URLs list. For example: ['example.com/adfs','https://accounts.google.com'].
- String that can be parsed as valid JSON and deserialized into a map of issuer URLs to corresponding JWKS URIs. In this case, the JWKS URI present in the issuer's well-known endpoint will be overridden. For example: '{"issuer_jwks_map": {"https://accounts.google.com": "https://www.googleapis.com/oauth2/v3/certs", "example.com/adfs": "https://example.com/adfs/discovery/keys"}}'. Whenissuer_jwks_mapis set, the JWKS URI is directly used to get the key set. In all other cases whenJWKSAutoFetchEnabledis set, the JWKS URI is obtained first from the issuer's well-known endpoint and then this endpoint is used. #138188
 
- Simple string that can be parsed as a valid issuer URL. For example: 
General changes
- In order to improve the granularity of changefeed pipeline metrics, the changefeed metrics changefeed.admit_latencyandchangefeed.commit_latencynow have histogram buckets from5msto60m(previously500msto5m). The changefeed metricschangefeed.parallel_io_queue_nanos,changefeed.parallel_io_result_queue_nanos,changefeed.sink_batch_hist_nanos,changefeed.flush_hist_nanos, andchangefeed.kafka_throttling_hist_nanoshave histogram buckets from5msto10m(previously500msto5m). #136618
- Added support for multiple seed brokers in the new Kafka sink. #136745
- Added a metric distsender.rangefeed.catchup_ranges_waiting_client_sidethat counts how many rangefeeds are waiting on the client-side limiter to start performing catchup scans. #136837
- Added changefeed support for the mvcc_timestampoption with theavroformat. If both options are specified, the Avro schema includes anmvcc_timestampmetadata field and emits the row's MVCC timestamp with the row data. #136018
SQL language changes
- Added the legacy_varchar_typingsession setting that reverts the changes of #133037 that caused the change in typing behavior described in #137837. Specifically, thelegacy_varchar_typingsession setting makes type-checking and overload resolution ignore the newly added "unpreferred" overloads. This setting defaults toon. #137922
Operational changes
- Telemetry delivery is now considered successful even in cases where we experience a network timeout. This will prevent throttling in cases outside an operator's control. #136477
- When a schema change job completes, rolls back, or encounters a failure, the time taken since the job began is now logged in a structured log in the SQL_SCHEMAlog channel. #136952
Bug fixes
- CREATE SCHEMAnow returns the correct error if the schema name is missing. #135925
- Fixed an issue where corrupted table statistics could cause the CockroachDB process to crash. #136043
- The idle_in_session_timeoutsetting now excludes the time spent waiting for schema changer jobs to complete, preventing unintended session termination during schema change operations. #136508
- Fixed a bug that caused the optimizer to use stale table statistics after altering an enum type used in the table. #136832
- CockroachDB now better respects statement_timeoutlimit on queries involving the top K sort and merge join operations. #136650
- Fixed an issue where license enforcement was not consistently disabled for single-node clusters started with start-single-node. Now, cluster restarts correctly disable licensing. #137009
- Fixed a bug that caused queries against tables with user-defined types to sometimes fail with errors after restoring those tables. #137356
- Fixed a bug that could cause an internal error if a table with an implicit (rowid) primary key was locked from within a subquery, for example,SELECT * FROM (SELECT * FROM foo WHERE x = 2) FOR UPDATE;. The error could occur either under read-committed isolation, or withoptimizer_use_lock_op_for_serializableenabled. #137130
- Fixed an issue where adding an existing column with the IF NOT EXISTSoption could exit too early, skipping necessary handling of the abstract syntax tree (AST). This could lead to failure of theALTERstatement. #137678
- CLOSE CURSORstatements are now allowed in read-only transactions, similar to PostgreSQL. The bug has been present since at least v23.1. #137788
- Fixed an issue where a schema change could incorrectly cause a changefeed to fail with an assertion error like received boundary timestamp ... of type ... before reaching existing boundary of type .... #137703
- Internal scans are now exempt from the sql.defaults.disallow_full_table_scans.enabledsetting, allowing index creation even when the cluster setting is enabled. #137720
- A new column of type JSONorJSONBthat has aUNIQUEconstraint will now be blocked from being added to a table if the cluster has not yet finalized the upgrade to v23.2. #137864
v23.2.18
Release Date: December 26, 2024
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.18.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.18.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.18.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.18.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.18.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.18.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.18.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.18.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.18.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.18.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.18
Source tag
To view or download the source code for CockroachDB v23.2.18 on Github, visit v23.2.18 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.17...v23.2.18
SQL language changes
- Added the legacy_varchar_typingsession setting. When set toon, type-checking comparisons involvingVARCHARcolumns behave as they did in all previous versions. When set tooff, type-checking of these comparisons is more strict and queries that previously succeeded may now error with the messageunsupported comparison operator. These errors can be fixed by adding explicit type casts. Thelegacy_varchar_typingsession setting is on by default. #137945
v23.2.17
Release Date: December 12, 2024
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.17.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.17.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.17.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.17.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.17.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.17.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.17.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.17.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.17.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.17.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.17
Source tag
To view or download the source code for CockroachDB v23.2.17 on Github, visit v23.2.17 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.16...v23.2.17
Security updates
- All cluster settings that accept strings are now fully redacted when transmitted as part of Cockroach Labs' diagnostics telemetry. The payload includes a record of modified cluster settings and their values when they are not strings. If you previously applied the mitigations in Technical Advisory 133479, you can safely set the value of cluster setting server.redact_sensitive_settings.enabledtofalseand turn on diagnostic reporting via thediagnostics.reporting.enabledcluster setting without leaking sensitive cluster setting values. #134015
General changes
- COCKROACH_SKIP_ENABLING_DIAGNOSTIC_REPORTINGis no longer mentioned in the- cockroach democommand. #134085
Enterprise edition changes
- Added system.usersto the list of system tables that changefeeds protect with protected timestamps (PTS). This table is required for CDC queries. #134233
Operational changes
- Added a new cluster setting ui.database_locality_metadata.enabled, which allows operators to disable loading extended database and table region information in the DB Console's Databases and Table Details pages. This information can cause significant CPU load on large clusters with many ranges. Versions of this page from v24.3 onwards do not have this problem. If you require this data, you can use theSHOW RANGES FROM {DATABASE| TABLE}query via SQL to compute on-demand. #134093
Bug fixes
- Previously, CockroachDB could encounter an internal error of the form interface conversion: coldata.Column isin an edge case. This is now fixed. The bug was present in versions v22.2.13 and later, v23.1.9 and later, and v23.2 and later. #133759
- Fixed a bug that caused incorrect NOT NULLconstraint violation errors onUPSERTandINSERT ... ON CONFLICT ... DO UPDATEstatements when those statements updated an existing row and a subset of columns that did not include aNOT NULLcolumn of the table. This bug had been present since at least v20.1.0. #133823
- Fixed an unhandled error that could occur when using REVOKE ... ON SEQUENCE ... FROM useron an object that was not a sequence. #133707
- Addressed a panic that could occur inside CREATE TABLE ASthat occurred if sequence builtin expressions had invalid function overloads. #133867
- String constants can now be compared against collated strings. #134114
- Previously, when executing queries with index or lookup joins when the ordering needed to be maintained, CockroachDB in some cases could get into a pathological state which would lead to increased query latency, possibly by several orders of magnitude. This bug was introduced in v22.2 and is now fixed. #134364
- Addressed a bug with DROP CASCADEthat would occasionally panic with anun-dropped backrefmessage on partitioned tables. #134523
- Reduced the duration of partitions in the gossip network when a node crashes. This eliminates false positives in the ranges.unavailablemetric. #134602
- An error message is no longer returned when a non-admin user runs DROP ROLE IF EXISTSon a user that does not exist. #134967
- Fixed a bug that could cause incorrect query results when the optimizer planned a lookup join on an index containing a column of type CHAR(N),VARCHAR(N),BIT(N),VARBIT(N), orDECIMAL(M, N), and the query held that column constant to a single value (e.g., with an equality filter). #135113
- Fixed an unhandled error that would occur if DROP SCHEMAwas executed on thepublicschema of thesystemdatabase, or on an internal schema likepg_catalogorinformation_schema. #135196
- Fixed a bug that caused incorrect evaluation of some binary expressions involving CHAR(N)values and untyped string literals with trailing whitespace characters. For example, the expression'f'::CHAR = 'f 'now correctly evaluates totrue. #135691
Performance improvements
- CockroachDB now avoids loading unnecessary file blocks shortly after a rebalance in a rare case. #134526 #135303 #135577
- Reduced the write-amplification impact of rebalances by splitting snapshot sstable files into smaller ones before ingesting them into Pebble. #134526 #135303 #135577
v23.2.16
Release Date: November 18, 2024
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.16.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.16.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.16.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.16.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.16.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.16.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.16.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.16.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.16.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.16.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.16
Source tag
To view or download the source code for CockroachDB v23.2.16 on Github, visit v23.2.16 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.15...v23.2.16
General changes
- Changed the license cockroachis distributed under to the new CockroachDB Software License (CSL). #131705 #131927 #131933 #131981 #131988 #131994 #131992 #132000 #132001 #131999 #132053 #132803 #132781
- The cluster setting diagnostics.reporting.enabledis now ignored if the cluster has a Enterprise Trial or Enterprise Free license, or if the reporting job is unable to load any license at all. #132461
- Added the sink error metric (changefeed.sink_errors) and expanded the reporting of the internal retries metric (changefeed.internal_retry_message_count) to all changefeed sinks that perform internal retries. #132569
- Allowed access to DB console APIs via JWT, which can be supplied as a Bearer token in the Authorization header. #133240
DB Console changes
- DB Console will reflect any throttling behavior from the cluster due to an expired license or missing telemetry data. Enterprise licenses are not affected. #131859
- Due to the inaccuracy of the Range Count column on the Databases page, and the cost incurred to fetch the correct range count for every database in a cluster, this data will no longer be visible. This data is still available via a SHOW RANGESquery. #133271
Bug fixes
- Fixed an error that could happen if an aggregate function was used as the value in a SETcommand. #131958
- Added automated clean-up/validation for dropped roles inside of default privileges. #132169
- Fixed a bug that could cause RESTOREto hang after encountering transient errors from the storage layer. #132260
- Fixed a bug that caused incorrect evaluation of CASE,COALESCE, andIFexpressions with branches producing fixed-width string-like types, such asCHAR. In addition, theBPCHARtype has been fixed so that it no longer incorrectly imposes a length limit of1. #130898
- Fixed a bug that could lead to incorrect results in rare cases. The bug requires a JOINbetween two tables, with an equality between columns with equivalent, but not identical types (e.g.,OIDandREGCLASS). In addition, theJOINmust lookup an index that includes a computed column that references one of the equivalent columns. This bug has existed since before v23.1. #132510
- Fixed a bug that could lead to incorrect results in rare cases. The bug requires a lookup join into a table with a computed index column, where the computed column expression is composite sensitive. A composite sensitive expression can compare differently if supplied non-identical, but equivalent input values (e.g. 2.0::DECIMALvs2.00::DECIMAL). This bug has existed since before v23.1. #132510
- Fixed a bug where a span stats request on a mixed-version cluster resulted in an NPE. #132683
- The franz-golibrary has been updated to fix a potential deadlock on changefeed restarts. #132784
- Fixed an issue where changefeeds would fail to update protected timestamp records in the face of retryable errors. #132774
- Fixed a bug that could result in changefeeds using CDC queries failing due to a system table being garbage collected. #131655
- Fixed a rare bug in which an update of a primary key column that is also the only column in a separate column family can sometimes fail to update the primary index. This bug has existed since v22.2. Requirements to hit the bug are:
 - A table with multiple column families.
- A column family containing a single primary key column.
- That column family is not the first column family.
- That column family existed before its column was in the primary key.
- That column must be of type FLOAT4/8,DECIMAL,JSON, collated string type, or array.
- An update that changes that column from a composite value to a non-composite value. #132123
 
- The proretsetcolumn of thepg_catalog.pg_proctable is now properly set totruefor set-returning builtin functions. #132874
- Fixed a bug in the query optimizer that could cause CockroachDB nodes to crash in rare cases. The bug could occur when a query contains a filter in the form col IN (elem0, elem1, ..., elemN)only whenNis very large, e.g., 1.6+ million, and whencolexists in a hash-sharded index or, exists in a table with an indexed, computed column dependent oncol. #133066
- Users with the adminrole can now runALTER DEFAULT PRIVILEGES FOR target_role ...on anytarget_role. Previously, this could result in a privilege error, which is incorrect as admins are allowed to perform any operation. #133069
- REASSIGN OWNED BYwill now transfer ownership of the- publicschema. Previously, it would always skip over the- publicschema even if it was owned by the target role. #133069
- Added a timer for inner changefeed sink client flushes. Fixed a bug where timers were not correctly registered with the metric system. #133255
- Fixed an error that could be caused by using an AS OF SYSTEM TIMEexpression that references a user-defined (or unknown) type name. These kinds of expressions are invalid, but previously the error was not handled properly. This will now return the correct error message. #132453
- Fixed a bug where backup schedules could advance a protected timestamp too early, which caused incremental backups to fail. #131389
Performance improvements
- Performance has been improved during periodic polling of table history when the schema_lockedtable storage parameter is not enabled. #132240
- Reduced the write-amplification impact of rebalances by splitting snapshot SSTable files into smaller ones before ingesting them into Pebble. #134526
v23.2.15
Release Date: November 15, 2024
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.15.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.15.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.15.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.15.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.15.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.15.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.15.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.15.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.15.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.15.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.15
Source tag
To view or download the source code for CockroachDB v23.2.15 on Github, visit v23.2.15 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.14...v23.2.15
Performance improvements
- Reduced the write-amplification impact of rebalances by splitting snapshot sstablefiles before ingesting them into Pebble. #135123
v23.2.14
Release Date: October 31, 2024
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.14.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.14.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.14.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.14.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.14.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.14.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.14.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.14.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.14.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.14.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.14
Source tag
To view or download the source code for CockroachDB v23.2.14 on Github, visit v23.2.14 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.13...v23.2.14
General changes
- Added internal client name options to distinguish backup data transfer bytes from those of other clients, such as changefeeds, for updated CockroachDB Cloud billing metrics. #133753
v23.2.13
Release Date: October 17, 2024
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.13.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.13.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.13.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.13.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.13.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.13.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.13.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.13.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.13.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.13.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.13
Source tag
To view or download the source code for CockroachDB v23.2.13 on Github, visit v23.2.13 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.12...v23.2.13
Enterprise edition changes
- The description for the cluster setting changefeed.sink_io_workersnow lists all changefeed sinks that support the setting. #130372
- Network metrics have been added for the following changefeed sinks:
- Added two network metrics, - changefeed.network.bytes_inand- changefeed.network.bytes_out. These metrics track the number of bytes sent by individual changefeeds to the following sinks:- Kafka sinks. If child metrics are enabled, the metric will have a kafkalabel.
- Webhook sinks. If child metrics are enabled, the metric will have a webhooklabel.
- Pub/Sub sinks. If child metrics are enabled, the metric will have a pubsublabel.
- SQL sink. If child metrics are enabled, the metric will have a sqllabel.
 
- Kafka sinks. If child metrics are enabled, the metric will have a 
- The new metric - changefeed.total_rangesallows observation of the number of ranges that are watched by a changefeed aggregator. It uses the same polling interval as- changefeed.lagging_ranges, which is controlled by the changefeed option- lagging_ranges_polling_interval. #130984
- The following groups of metrics and logs have been renamed to include the buffer they are associated with. The previous metrics are still maintained for backward compatibility. - changefeed.buffer_entries.*
- changefeed.buffer_entries_mem.*
- changefeed.buffer_pushback_nanos.*
 
- Added timers and corresponding [metrics](/docs/v24.2/metrics.html for key parts of the changefeed pipeline to help debug issues with feeds. The - changefeed.stage.{stage}.latencymetrics now emit latency histograms for each stage. The metrics respect the changefeed- scopelabel to debug a specific feed. #131428
Operational changes
- The new metric ranges.decommissioningshows the number of ranges with a replica on a decommissioning node. #130251
- The following new metrics show the number of RPC TCP connections established to remote nodes: - rpc.connection.connected: the number of gRPC TCP level connections established to remote nodes.
- rpc.client.bytes.egress: the number of TCP bytes sent over gRPC on connections initiated by the cluster.
- rpc.client.bytes.ingress: the number of TCP bytes received over gRPC on connections initiated by the cluster.
 
- Added a new configuration parameter, - server.cidr_mapping_url, which maps IPv4 CIDR blocks to arbitrary tag names. #130528
- The metrics - sql.bytesinand- sql.bytesoutare now aggregate metrics if child metrics are enabled. #130528
- The following new metrics track the number of bytes sent by an individual changefeed to each sink: - changefeed.network.bytes_in
- changefeed.network.bytes_out
 
- You can now set the log format for the - STDERRchangefeed sink using the- formatfield in the- stderrsink section of the logging configuration. #131533
DB Console changes
- The DB Console now shows a notification if the cluster has no Enterprise license set. Refer to upcoming license changes for more information. #130425
Bug fixes
- Fixed a bug where the command SHOW CLUSTER SETTING FOR VIRTUAL CLUSTERwould erroneously returnNULLfor some settings. #128782
- Fixed a bug where a node could fail to start with the error could not insert session ...: unexpected valueif an ambiguous result error occurred while inserting data into thesqllivenesstable. #130343
- Fixed a bug that could prevent upgrade finalization due to the upgrade pre-condition for repairing descriptor corruption. #130519
- Fixed a rare bug where a lease transfer could lead to a side-transport update saw closed timestamp regressionpanic. The bug could occur when a node was overloaded and failing to heartbeat its node liveness record. #130790
- Fixed a bug that could result in the erroneous log message expiration of liveness record ... is not greater than expiration of the previous lease ... after liveness heartbeat. #130790
- Fixed a bug where queries that are not initiated within a SQL session could fail to respect a statement timeout, including background jobs, queries issued by the DB Console that perform introspection, and the CockroachDB Cloud SQL Shell. #130790
- Fixed a bug where a connection could be incorrectly dropped if the client was attempting to change a schema at the same time that the same schema's objects were being dropped. [#130964][#130964]
- Fixed a bug that could cause the following error to be logged when executing a query under READ COMMITTED isolation if it involved a table with NOT NULLvirtual columns:internal error: Non-nullable column .... #131065
- Fixed a potential memory leak in changefeeds that use a cloud storage sink. The memory leak could occur if both of the cluster settings changefeed.fast_gzip.enabledandchangefeed.cloudstorage.async_flush.enabledweretrueand if the changefeed received an error while attempting to write to the sink. #130614
- Fixed a bug introduced in v23.2.6, where statistics forecasting could predict a result of zero rows for a downward-trending statistic when sql.stats.forecasts.max_decreaseisfalse. The setting is now enabled (set to1/3by default). #131128
- Fixed a bug introduced in v23.1 that can cause incorrect results in the following scenario: - The query contains a correlated subquery.
- The correlated subquery has a GroupByorDistinctOnoperator with an outer-column reference in its input.
- The correlated subquery is in the input of a SELECTorJOINclause that has a filter that sets the outer-column reference equal to an inner column that is in the input of the grouping operator.
- The set of grouping columns does not include the replacement column explicitly.
 
- Fixed a bug where AWS S3 and HTTP client configurations were not considered when implicit authentication was used. #131201 
- Fixed a bug that could prevent a changefeed from resuming from a prolonged paused state. #130919 
v23.2.12
Release Date: September 25, 2024
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.12.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.12.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.12.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.12.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.12.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.12.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.12.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.12.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.12.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.12.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.12
Source tag
To view or download the source code for CockroachDB v23.2.12 on Github, visit v23.2.12 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.11...v23.2.12
Enterprise edition changes
Added a changefeed.protect_timestamp.lag metric, which controls how much the changefeed protected timestamp (PTS) should lag behind the high-water mark. A changefeed now only updates its PTS if changefeed.protect_timestamp.lag has passed between the last PTS and the changefeed high-water mark. #129685
- SHOW CHANGEFEED JOB, SHOW CHANGEFEED JOBS, and SHOW JOBS no longer expose user sensitive information like client_key. #122681
SQL language changes
- The session setting plan_cache_mode=force_generic_plancan now be used to force prepared statements to use a query plan that is optimized once and reused in future executions without re-optimization, as long as the plan does not become stale due to schema changes or a collection of new table statistics. The setting takes effect duringEXECUTEcommands.EXPLAIN ANALYZEnow includes aplan typefield. If a generic query plan is optimized for the current execution, theplan typewill begeneric, re-optimized. If a generic query plan is reused for the current execution without performing optimization, theplan typewill begeneric, reused. Otherwise, theplan typewill becustom. #128100
- The session setting plan_cache_mode=autocan now be used to instruct the cost-based optimizer to automatically determine whether to use "custom" or "generic" query plans for the execution of a prepared statement. Custom query plans are optimized on every execution, while generic plans are optimized once and reused on future executions as-is. Generic query plans are beneficial in cases where query optimization contributes significant overhead to the total cost of executing a query. #128100
Operational changes
- There are now structured logging events that report connection breakage during node shutdown. Previously, these logs existed but were unstructured. These logs appear in the OPSlogging channel. There are two new events:- The node_shutdown_connection_timeoutevent is logged after the timeout defined by the cluster settingserver.shutdown.connections.timeouttranspires, if there are still open SQL connections.
- The node_shutdown_transaction_timeoutevent is logged after the timeout defined by the cluster settingserver.shutdown.transactions.timeouttranspires, if there are still open transactions on those SQL connections. #128710
 
- The 
- Added the ranges.decommissioningmetric, representing the number of ranges which have a replica on a decommissioning node. #130413
- Added three new network tracking metrics:
- rpc.connection.connectedis the number of rRPC TCP-level connections established to remote nodes.
- rpc.client.bytes.egressis the number of TCP bytes sent via gRPC on connections we initiated.
- rpc.client.bytes.ingressis the number of TCP bytes received via gRPC on connections we initiated. cockroachdb/cockroach#130712
 
- Added a new configuration parameter server.cidr_mapping_url, which maps IPv4 CIDR blocks to arbitrary tag names. #130712
- Modified metrics sql.bytesinandsql.bytesoutto be aggregation metrics If theserver.child_metrics.enabledcluster setting is enabled. #130712
- Added two network metrics, changefeed.network.bytes_inandchangefeed.network.bytes_out. These metrics track the number of bytes sent by individual changefeeds to the following sinks:- Kafka sinks. If the server.child_metrics.enabledcluster setting is enabled, the metric will have akafkalabel.
- Webhook sinks. If the server.child_metrics.enabledcluster setting is enabled, the metric will have awebhooklabel.
- Pub/Sub sinks. If the server.child_metrics.enabledcluster setting is enabled, the metric will have apubsublabel.
- SQL sink. If the server.child_metrics.enabledcluster setting is enabled, the metric will have asqllabel. #130712
 
- Kafka sinks. If the 
DB Console changes
- The DB Console time-series graphs now have hover behavior that focuses on individual lines and shows values under the mouse pointer. cockroachdb/cockroach#128864
- Users with the VIEWACTIVITYprivilege can download statement bundles from DB Console. #129502
- The DB Console now displays an alert message when the license is expired or if there are fewer than 15 days left before the license expires. #130509
- The DB Console will now show a notification alerting customers without an Enterprise license to upcoming license changes with a link to more information. #130509
Bug fixes
- Fixed a bug where declarative and legacy schema changes were incorrectly allowed to be executed concurrently, which could lead to failing or hung schema change jobs. #128838
- Fixed a bug that caused errors like ERROR: column 'crdb_internal_idx_expr' does not existwhen accessing a table with an expression index where the expression evaluates to anENUMtype, e.g.,CREATE INDEX ON t ((col::an_enum)). #129092
- Function input parameters can no longer have the VOIDtype. #129281
- Internally issued queries that are not initiated within a SQL session no longer respect a statement timeout. This includes: background jobs, queries issued by the DB Console that perform introspection, and the Cloud SQL shell. #129517
- Fixed a bug where the schema_lockedstorage parameter did not prevent a table from being referenced by a foreign key. #129753
- Users with the VIEWACTIVITYSQL privilege can now request, view, and cancel statement bundles in the DB Console. #129803
- Fixed a bug where a lease transfer could lead to a panic with the message side-transport update saw closed timestamp regression. The bug could occur when a node was overloaded and failing to heartbeat its node liveness record. #129808
- The log message expiration of liveness record ... is not greater than expiration of the previous lease ... after liveness heartbeatis no longer generated. #129808
- Fixed a bug where the require_explicit_primary_keyssession variable would prevent allCREATE TABLEstatements from working. #129906
- Fixed a slow-building memory leak when using Kerberos authentication. #130317
- Fixed a potential memory leak in changefeeds using a cloud storage sink. The memory leak could occur if both changefeed.fast_gzip.enabledandchangefeed.cloudstorage.async_flush.enabledweretrue, and the changefeed received an error while attempting to write to the cloud storage sink. #130624
v23.2.11
Release Date: September 16, 2024
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.11.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.11.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.11.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.11.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.11.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.11.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.11.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.11.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.11.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.11.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.11
Source tag
To view or download the source code for CockroachDB v23.2.11 on Github, visit v23.2.11 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.10...v23.2.11
Bug fixes
- Internally issued queries that are not initiated within a SQL session no longer respect a statement timeout. This includes: background jobs, queries issued by the DB Console that perform introspection, and the Cloud SQL shell. #130525
- Fixed a rare bug where a lease transfer could lead to a side-transport update saw closed timestamp regressionpanic. The bug could occur when a node was overloaded and failing to heartbeat its node liveness record. #130523
- Resolved a concerning log message: expiration of liveness record ... is not greater than expiration of the previous lease ... after liveness heartbeat. This message is no longer possible. #130523
v23.2.10
Release Date: August 29, 2024
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.10.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.10.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.10.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.10.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.10.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.10.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.10.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.10.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.10.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.10.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.10
Source tag
To view or download the source code for CockroachDB v23.2.10 on Github, visit v23.2.10 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.9...v23.2.10
Security updates
- URLs in the following SQL statements are now sanitized of any secrets, such as keys or passwords, before being written to unredacted logs:
Enterprise edition changes
- Added a new Kafka sink utilizing the franz-golibrary and our ownbatching_sinkbehind a cluster setting (changefeed.new_kafka_sink_enabled, disabled by default). #128048
- The v2 Kafka and Google Cloud Pub/Sub changefeed sinks now display notices indicating the topics they will emit to. #128459
SQL language changes
- Added the sql.auth.grant_option_for_owner.enabledcluster setting. The default value istrue, which results in behavior that matches the existing behavior of CockroachDB. When set tofalse, then theGRANT OPTIONis not implcitly given to the owner of an object. The object owner still implicitly has all privileges on the object, just not the ability to grant them to other users. #126958
- Fixed a bug where the DISCARDstatement was disallowed when thedefault_transaction_read_onlysession setting was set toon. #127548
DB Console changes
- The Databases and Tables pages in the DB Console now show a loading state while loading information for databases and tables, including size and range counts. #127709
- On the Databases page in the DB Console, table names will no longer appear with quotes around the schema and table name. #127765
Bug fixes
- Fixed a bug causing gateway nodes to crash while executing INSERTstatements inREGIONAL BY ROWtables. This bug had been present since v23.2. #127276
- Fixed a bug where dropping ENUMvalues that were referenced by index expressions could fail with an error. #127453
- Fixed a bug that caused a memory leak when executing SQL statements with comments, e.g., SELECT /* comment */ 1;. Memory owned by a SQL session would continue to grow as these types of statements were executed. The memory would only be released when closing the SQL session. This bug had been present since v23.1. #127758
- Fixed a memory leak that could occur when specifying a non-existent virtual cluster name in the connection string. #128104
- Fixed a bug where CREATE INDEX IF NOT EXISTSwould not correctly short-circuit if the given index already existed. #128312
- Fixed a bug in overly eager syntax validation, which did not allow the DESCENDINGclause for non-terminal columns of an inverted index. Only the last column of an inverted index should be prevented from beingDESCENDING, and this is now properly checked. #128312
- Fixed a bug where an index could store a column in the primary index if that column had a mixed-case name. #128312
- Fixed small memory leaks that would occur during changefeed creation. #128048
- Setting or dropping a default value on a computed column is now blocked -- even for null defaults. Previously, setting or dropping a default value on a computed column was a no-op; now there will be an error message. #128467
- Fixed a bug that could cause spurious user permission errors when multiple databases shared a common schema with a routine referencing a table. The bug had existed since user-defined functions were introduced in v22.2. #126413
- Fixed a bug where a hash-sharded constraint could not be created if it referred to columns that had a backslash in the name. #128676
- Fixed a bug where TYPEDESC SCHEMA CHANGEjobs could end up retrying forever if the descriptor targeted by them was already dropped. #128461
- Fixed a bug in which the output of EXPLAIN (OPT, REDACT)for variousCREATEstatements was not redacted. This bug had existed sinceEXPLAIN (REDACT)was introduced in v23.1 and affects the following statements:- EXPLAIN (OPT, REDACT) CREATE TABLE
- EXPLAIN (OPT, REDACT) CREATE VIEW
- EXPLAIN (OPT, REDACT) CREATE FUNCTION#128488
 
Contributors
This release includes 80 merged PRs by 28 authors.
v23.2.9
Release Date: August 1, 2024
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.9.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.9.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.9.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.9.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.9.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.9.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.9.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.9.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.9.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.9.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.9
Source tag
To view or download the source code for CockroachDB v23.2.9 on Github, visit v23.2.9 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.8...v23.2.9
SQL language changes
- EXPLAIN ANALYZEstatements are now supported when executed via Cloud Console SQL shell. #125562
- Added the sql.auth.grant_option_inheritance.enabledcluster setting. The default value istrue, which maintains consistency with CockroachDB's previous behavior: users granted a privilege withWITH GRANT OPTIONcan in turn grant that privilege to others. Whensql.auth.grant_option_inheritance.enabledis set tofalse, theGRANT OPTIONis not inherited through role membership, thereby preventing descendant roles from granting the privilege to others. However, the privilege itself continues to be inherited through role membership. #126298
Operational changes
- crdb_internal.cluster_execution_insights.txtand- crdb_internal.cluster_txn_execution_insights.txthave been removed from the debug zip. These files contained cluster-wide insights for statements and transactions. Users can still rely on the per-node execution insights in- crdb_internal.node_execution_insights.txtand- crdb_internal.node_txn_execution_insights.txt. #125804
- Some debugging-only information about physical plans is no longer collected in the system.job_infotable for changefeeds, because it has the potential to grow very large. #126097
- For the TELEMETRY channel, TCL sampled_queryevents will now be sampled at the rate specified by the settingsql.telemetry.query_sampling.max_event_frequency, which is already used to limit the rate of sampling DML statements. #126728
Bug fixes
- Fixed a bug introduced in v23.2.0 in which CockroachDB would hit an internal error when evaluating INSERTs intoREGIONAL BY ROWtables where the source was aVALUESclause with a single row and at least one boolean expression. #125504 #126839
- Fixed a bug where a DROP ROLEorDROP USERcommand could leave references behind inside types, which could prevent subsequentSHOW GRANTScommands from working. #125806
- Fixed a bug that could lead to descriptors having privileges to roles that no longer exist. Added an automated clean up for dropped roles inside descriptors. #125806
- Fixed a bug where a change to a user-defined type (UDT) could cause queries against tables using that type to fail with an error message like: histogram.go:694: span must be fully contained in the bucket. The change to the user-defined type could occur either directly from anALTER TYPEstatement or indirectly from anALTER DATABASE ... ADD REGIONorALTER DATABASE ... DROP REGIONstatement, which implicitly modifies thecrdb_internal_regionUDT. This bug had existed since UDTs were introduced in v20.2. #125806
- Fixed a bug in which constant LIKEpatterns containing certain sequences of backslashes did not become constrained scans. This bug has been present since v21.1.13 when support for building constrained scans fromLIKEpatterns containing backslashes was added. #125538
- Fixed a bug introduced in alpha versions of v23.1 where calling a routine could result in an unexpected function ... does not existerror. The bug is triggered when the routine is called twice using the exact same SQL query, and either: (a) the routine has polymorphic arguments, or: (b) between the two calls, the routine is replaced by a routine with the same name and different parameters. #123518
- Fixed the statistics estimation code in the optimizer so it does not use the empty histograms produced if histogram collection has been disabled during stats collection due to excessive memory utilization. Now the optimizer will rely on distinct counts instead of the empty histograms and should produce better plans as a result. This bug has existed since v22.1. #126156
- Fixed a bug in cockroach debug tsdumpwhere the command fails when a custom SQL port is used and the--format=rawflag is provided. #126184
- Fixed a bug where a user-defined function (UDF) that shared a name with a built-in function would not be resolved, even if the UDF had higher precedence according to the search_pathvariable. #126295
- Fixed a bug that caused background jobs to incorrectly respect a statement timeout. #126819
- Fixed a bug where ALTER DATABASE ... DROP REGIONcould fail if any tables under the given database have indexes on expressions. #126598
- Fixed a bug when restoring a database with a composite type. #126841
- Fixed a bug when inputting publicrole as user name for built-in compatibility functions, such ashas_database_privilegeandhas_schema_privilege. #126852
- Fixed a bug where the Database page could crash if range information is not available. #127091
- Fixed a bug where CockroachDB could incorrectly evaluate an IS NOT NULLfilter if it was applied to non-NULLtuples that hadNULLelements, such as(1, NULL)or(NULL, NULL). This bug has existed since v20.2. #126937
- In the DB Console event log, ALTER ROLEevents now display correctly even when no role options are included in theALTER ROLEstatement. #126565
- Fixed a bug where CREATE TABLEwith index expressions could hit undefined column errors on transaction retries. #126201
Performance improvements
- Schema changes that cause a data backfill, such as adding a non-nullable column or changing the primary key, will now split and scatter the temporary indexes used to perform the change. This reduces the chance of causing a write hotspot that can slow down foreground traffic. #126691
Contributors
This release includes 100 merged PRs by 33 authors.
v23.2.8
Release Date: July 15, 2024
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.8.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.8.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.8.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.8.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.8.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.8.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.8.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.8.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.8.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.8.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.8
Source tag
To view or download the source code for CockroachDB v23.2.8 on Github, visit v23.2.8 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.7...v23.2.8
Performance improvements
- Updated the replica allocator with a small performance win for very large clusters. #126918
- Updated the gossip layer to avoid unnecessary mutex contention. #126919, #126920
Bug fixes
- Fixed a bug where the disallow_full_table_scanssession variable was not working for tables with hash-sharded indexes. #126700
Contributors
This release includes 5 merged PRs by 4 authors.
v23.2.7
Release Date: July 2, 2024
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.7.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.7.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.7.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.7.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.7.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.7.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.7.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.7.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.7.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.7.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.7
Source tag
To view or download the source code for CockroachDB v23.2.7 on Github, visit v23.2.7 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.6...v23.2.7
Enterprise edition changes
- Changefeeds can use the bulk oracle for planning, which distributes work evenly across all replicas in the locality filter, including followers if enabled. Set the changefeed.random_replica_selection.enabledcluster setting totrueto enable this planning behavior. To use the previous bin-packing oracle, set the cluster settingchangefeed.random_replica_selection.enabledtofalse. #124925
- ALTER CHANGEFEEDno longer removes the CDC query when modifying changefeed properties. #125437
SQL language changes
- Precision is no longer limited when encoding geodata types to JSON. #124535
- When the new optimizer_push_offset_into_index_joinsession setting is enabled, the optimizer attempts to produce more efficient query plans by attempting to push offset expressions into index join expressions to produce more efficient query plans. #124492
General changes
- CockroachDB v23.2.7 and subsequent v23.2 releases are eligible for long term support (LTS).
Operational changes
- Improved metrics related to disk usage reporting for volumes that dynamically change their size over time. #125107
Security changes
- Improved the automated cleanup when dropping roles inside descriptors. #124665
Bug fixes
- Fixed a bug where a range with a replication factor of 1to be scaled up to a replication factor of2. #124487
- Fixed a bug that could cause leases to thrash between nodes when perturbed with a replication factor of 1. #124487
- Fixed a bug where, when the ttl_row_stats_poll_intervalstorage parameter is non-zero, the job to update row statistics for a table with row-level TTL enabled could be blocked from completing by the queries issued to update the row statistics. Now, if the job completes, these queries are cancelled, and thejobs.row_level_ttl.total_rowsandjobs.row_level_ttl.total_expired_rowsmetrics will report 0 if the job finishes before the queries to update the row statistics complete. #124626
- Fixed a bug where the results_buffer_sizesession setting could not be configured using theoptionsquery parameter in the connection string, but only as a top-level query parameter. This variable cannot be changed by using theSETcommand after the session begins. #124774
- Fixed a bug where dropping a role or user could leave references behind inside types. This in turn could prevent the - SHOW GRANTScommand from working correctly. #124644
- Fixed a bug where the - ALTER TABLE ... ALTER PRIMARY KEYcommand could hang for a table if its indexes are referred to by views or functions using the- force syntaxsyntax. #124569
- Fixed a bug where the - SHOW TYPEScommand omitted user-defined composite types. This bug was introduced in v23.1. #124816
- Fixed a bug where if a column name that contains UTF-8 characters is referenced in the - STORING()clause of the- CREATE INDEXcommand, the declarative schema changer cannot detect whether the column is already handled by an existing index. #125211
- Fixed a bug where the declarative schema changer erroneously includes virtual columns that are referenced in the - STORING()clause of the- CREATE INDEXcommand. #125211
- Fixed a bug introduced in v20.2, where a change to a user-defined type could cause queries against tables using that type to fail with the error like - histogram.go: span must be fully contained in the bucket. This bug could occur if the change was from an- ALTER TABLEcommand or from an- ALTER DATABASE ... ADD REGIONor- ALTER DATABASE ... DROP REGIONcommand, which implicitly change the non-public- crdb_internal_regiontype. #124853
- Fixed a bug where telemetry logs could emit the same statement fingerprint ID for different SQL statements. #125043 
- Fixed a bug where adding a column with a default value of an empty array could fail. #125326 
- Fixed a bug where the declarative schema changer could erroneously succeed despite a violation of an - ALTER TABLE ... ADD CONSTRAINT UNIQUEconstraint. Now such a violation results in an error message with the error code- 42601. #125418
- Fixed a changefeed panic in v24.1, v23.2, and v23.1 when the cluster setting - changefeed.aggregator.flush_jittercluster setting is configured and a changefeed's- min_checkpoint_frequencyoption is set to zero. #125469
- Fixed a bug where the public schema was erroneously created with its owner set to the - adminrole instead of the database owner. Ownership of the public schema can be altered after the schema is created. #125535
- Fixed a bug introduced in v23.2.0 where inserting rows into a - REGIONAL BY ROWtable could cause an internal error if the source was a- VALUESclause with a single row and at least one boolean expression. #126208
Performance improvements
- The optimizer now generates more efficient query plans for some queries with OFFSETclauses. #124492
Contributors
This release includes 77 merged PRs by 30 authors.
v23.2.6
Release Date: June 11, 2024
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.6.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.6.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.6.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.6.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.6.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.6.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.6.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.6.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.6.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.6.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.6
Source tag
To view or download the source code for CockroachDB v23.2.6 on Github, visit v23.2.6 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.5...v23.2.6
Enterprise edition changes
- Fixed a bug that was present since v22.2 where changefeeds with long-running initial scans might incorrectly restore checkpoint job progress and drop events during changefeed restarts due to transient errors or node restarts. The bug was most likely to occur in clusters with the following contributing factors:
- The changefeed.shutdown_checkpoint.enabledcluster setting was enabled.
- The cluster settings changefeed.frontier_checkpoint_frequencyandlow changefeed.frontier_highwater_lag_checkpoint_thresholdwere set low, which resulted in the initial scan taking many multiples of the configured frequency to complete.
- There were multiple target tables with significant differences in row counts in one changefeed.
- The changefeed target tables were large with many ranges.
- The initial scan took a long time to complete (an hour or longer). #123966
 
- The 
SQL language changes
- Updated the SHOW GRANTSresponses to display theobject_typeandobject_name, which has replaced therelation_namecolumn. #122822
- Added external connection granted privileges to the SHOW GRANTScommand. #122822
- Introduced three new cluster settings for controlling table statistics forecasting:
- sql.stats.forecasts.min_observationsis the minimum number of observed statistics required to produce a forecast.
- sql.stats.forecasts.min_goodness_of_fitis the minimum R² (goodness of fit) measurement required from all predictive models to use a forecast.
- sql.stats.forecasts.max_decreaseis the most a prediction can decrease, expressed as the minimum ratio of the prediction to the lowest prior observation. #122458
 
- Added a new session setting optimizer_use_improved_multi_column_selectivity_estimate, which if enabled, causes the optimizer to use an improved selectivity estimate for multi-column predicates. This setting will default totrueon v24.2 and later, andfalseon earlier versions. #123100
- The optimizer can now plan constrained scans over partial indexes in more cases, particularly on partial indexes with predicates referencing virtual computed columns. #123469
- The row-level TTL setting ttl_delete_rate_limitis now set to100by default, which sets the rate limit for deleting expired rows to100. #124353
Operational changes
- Two new metrics track the status of the SQL Activity Update job, which pre-aggregates top K information within the SQL statistics subsytem and writes the results to system.statement_activityandsystem.transaction_activity:- sql.stats.activity.updates.successful: Number of successful updates made by the SQL activity updater job.
- sql.stats.activity.update.latency: The latency of updates made by the SQL activity updater job. Includes failed update attempts. #123960
 
- Added a new counter metric, sql.stats.flush.done_signals.ignored, that tracks the number of times the SQL activity update job has ignored the signal that indicates that a flush has completed. This metric may indicate that the SQL activity update job is taking longer than expected to complete. #123960
- Added a new counter metric, sql.stats.activity.updates.failed, to measure the number of update attempts made by the SQL activity update job that failed with errors. The SQL activity update job is used to pre-aggregate top K information within the SQL stats subsystem and write the results tosystem.statement_activityandsystem.transaction_activity. #123960
- Added a new counter metric, sql.stats.flush.fingerprint.count, that tracks the number of unique statement and transaction fingerprints included in the SQL stats flush. #123960
- Added the sql.pgwire.pipeline.countmetric, which measures how many wire protocol commands have been received by the server, but have not yet started processing. This metric will only grow if clients are using the pipeline mode of the PostgreSQL wire protocol. #124260
- The client_authentication_okandclient_session_endevents are now logged to theSESSIONSlog channel unconditionally. Previously, these would only be logged if theserver.auth_log.sql_sessions.enabledcluster setting was set totrue. All otherSESSIONSlog messages are still only logged ifserver.auth_log.sql_sessions.enabledorserver.auth_log.sql_connections.enabledare set totrue. To not showclient_authentication_okandclient_session_endevents, disable theSESSIONSlog channel entirely. #124374
DB Console changes
- The Database details and Table details pages now display the correct stats in the Table Stats Last Updated. #122815
- Viewing the SQL Activity sorted by % of Runtimenow correctly sorts entries by the runtime amount. #123901
Bug fixes
- Fixed a bug where client certificate authentication combined with identity maps (server.identity_map.configuration) did not work. For the feature to work correctly, the client must specify a valid database user in the connection string. #122749
- Fixed a bug where the row-based execution engine could drop a LIMITclause when there was anORDER BYclause, and the ordering was partially provided by an input operator. For example, this bug could occur with an ordering such asORDER BY a, bwhen the scanned index was only ordered on columna. The impact of this bug was that more rows may have been returned than specified by theLIMITclause. This bug is only present when not using the vectorized execution engine; that is, when running withSET vectorize = off;. This bug has existed since CockroachDB v22.1. #122836
- Fixed a bug in the DB Console's Custom Chart tool where store-level metrics were displayed only for the first store ID associated with the node. Now data is displayed for all stores present on a node, and a single time series is shown for each store, rather than an aggregated value for all of the node's stores. This allows finer-grained monitoring of store-level metrics. #122703
- Fixed a bug where privileges granted for external connections were incorrectly showing up in SHOW SYSTEM GRANTS, but were not useful because there was no associated object name. The privileges no longer appear inSHOW SYSTEM GRANTS. Instead, theSHOW GRANTS ON EXTERNAL CONNECTIONstatement should be used. #122905
- Statistics forecasts of zero rows can cause suboptimal query plans. Forecasting will now avoid predicting zero rows for most downward-trending statistics. #122458
- Fixed a bug introduced in v23.2 that could cause a PL/pgSQL routine to return incorrect results when the routine included:
- At least one parameter.
- An IFstatement with one leak-proof branch and one branch with side effects. #120742
 
- Fixed a bug that could result in an internal error when attempting to create a PL/pgSQL routine using the (currently unsupported) %ROWTYPEsyntax for a variable declaration. #123010
- Fixed a bug where a RESTOREof a backup that itself contained a table created by theRESTOREof a table with an in-progressIMPORT INTOwould fail to restore all rows. #120543
- Fixed a bug introduced in v23.2 that could cause a PL/pgSQL variable assignment to not be executed if the variable was never referenced after the assignment. #123116
- Fixed a bug where CockroachDB could run into an attempting to append refresh spans after the tracked timestamp has moved forwardinternal error in some edge cases. The bug had been present since v22.2. #123150
- A job will now log rather than fail if it reports an out-of-bound progress fraction. #122964
- Fixed a bug that would occur when ALTER TYPE ... DROP VALUEis followed byDROP SCHEMA CASCADE ...in the same transaction. Previously, theALTER TYPEschema change would get queued up to run at commit time, but by that point, the type may have already been removed, so the commit could fail. #123576
- Fixed a bug that could lead to descriptors with self references that pointed to incorrect descriptor IDs. Now, tables that see the error invalid inbound foreign key ... origin table ID should beorinvalid outbound foreign key ... reference table ID should bewill automatically repair post deserialization. #123681
- Fixed a bug where a failed restore job could leave the system in a state where re-attempting the restore was not possible without manual intervention. #123463
- Index recommendations in the DB Console will now function properly for indexes on tables or columns whose names contain quotation marks or whitespace. For example: CREATE INDEX ON "my table" ("my col");. #122119
- Fixed a crash introduced in v23.2.5 that could occur when planning statistics collection on a table with a virtual computed column using a user-defined type when the newly introduced cluster setting sql.stats.virtual_computed_columns.enabledis set totrue. (The setting was introduced in v23.2.4 and set tofalseby default.) #124080
- Added automated clean up and validation for dropped roles inside descriptors. #124670
- Fixed a bug where DROP ROLEandDROP USERcould leave references behind inside types, which could preventSHOW GRANTSfrom working. #124668
- Fixed a bug where a change to a user-defined type could cause queries against tables using that type to fail with the error histogram.go:694: span must be fully contained in the bucket. The change to the user-defined type could come directly from anALTER TYPEstatement, or indirectly from anALTER DATABASE ADD REGIONorDROP REGIONstatement (which implicitly change thecrdb_internal_regiontype). This was present since user-defined types were introduced in v20.2. #124854
Performance improvements
- More efficient query plans are now generated for queries with text similarity filters, for example, text_col % 'foobar'. These plans are generated if theoptimizer_use_trigram_similarity_optimizationsession setting is enabled. It is disabled by default. #122753
- The optimizer now costs distinct-onoperators more accurately. It may produce more efficient query plans in some cases. #122844
- Added a new session setting optimizer_use_improved_zigzag_join_costing. When enabled and when the cluster settingenable_zigzag_joinis also enabled, the cost of zigzag joins is updated such that a zigzag join will be chosen over a scan only if it produces fewer rows than a scan. #123100
- Improved the selectivity estimation of multi-column filters when the multi-column distinct count is high. This prevents the optimizer from choosing a bad query plan due to over-estimating the selectivity of a multi-column predicate. #123100
- Improved the efficiency of error handling in the vectorized execution engine to reduce the CPU overhead of statement timeout handling and reduce the potential for more statement timeouts. #123502
Contributors
This release includes 115 merged PRs by 32 authors.
v23.2.5
Release Date: May 7, 2024
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.5.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.5.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.5.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.5.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.5.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.5.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.5.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.5.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.5.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.5.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.5
Source tag
To view or download the source code for CockroachDB v23.2.5 on Github, visit v23.2.5 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.4...v23.2.5
SQL language changes
- The new cluster setting sql.stats.virtual_computed_columns.enabledenables collection of table statistics on virtual computed columns. #120923
- The new session variable optimizer_use_virtual_computed_column_statsconfigures the optimizer to consider table statistics on virtual computed columns. #121179
- The new FORCE_INVERTED_INDEXhint configures the optimizer to prefer a query plan scan over any inverted index of the hinted table. If no such query plan can be generated, an error is logged. #122300
- The optimizer can now plan constrained scans over partial indexes in more cases, particularly on partial indexes with predicates referencing virtual computed columns. #123408
Operational changes
- A minimum Raft scheduler concurrency is now enforced per store so that a node with many stores does not spread workers too thinly. This avoids high scheduler latency across replicas on a store when load is imbalanced. #120798
- A changefeed optimization to reduce duplicates during aggregator restarts has been disabled due to poor performance. #123596
DB Console changes
- The Commit Latency chart in the Changefeed Dashboard now aggregates by max instead of by sum for multi-node changefeeds. This more accurately reflects the amount of time for events to be acknowledged by the downstream sink. #121235
Bug fixes
- Fixed a slow memory leak when opening many new connections. This bug was introduced in v22.2.9 and v23.1.0. #121055
- Fixed a bug that occurred when using ALTER TABLEto drop and re-add aCHECKconstraint with the same name. #121055
- Sequence options MINVALUEandMAXVALUEautomatically adjust to new types bounds. This mirrors the behavior of PostgreSQL. #121309
- Fixed a bug that could prevent timeseries graphs shown on the DB Console SQL Activity Statement Details page from rendering correctly when specifying a custom time range. #121383
- Fixed a bug present since at least v21.1 that could lead to incorrect evaluation of an - INexpression with:- INT2or- INT4type on the left side, and
- Values on the right side that are outside of the range of the left side.
 
- Fixed a leak in reported memory usage (not the actual memory usage) by the internal memory accounting system, the limit for which is configured via the - --max-sql-memoryflag when a long-running sessions issues hundreds of thousands or more transactions. This reporting bug could cause- root: memory budget exceedederrors for other queries. The bug was introduced in v23.1.17 and v23.2.3. #121950
- Fixed a bug introduced in v23.2.4 that could prevent collection of table statistics on tables that have on virtual computed columns of user-defined type when the newly-introduced cluster setting - sql.stats.virtual_computed_columns.enabledis set to- true(defaults to- false). The setting was introduced in v23.2.4 and is disabled by default. #122319
- Fixed a bug where a - GRANT ... ON ALL TABLESstatement could fail if a sequence existed that did not support the privilege being granted. #122034
- Fixed an existing bug where an unused value cannot be dropped from an - ENUMif the- ENUMitself is referenced by a user-defined function. A value can now be dropped from an- ENUMas long as the value itself is not being referenced by any other data element, including a user-defined function. #121237
Contributors
This release includes 79 merged PRs by 33 authors.
v23.2.4
Release Date: April 11, 2024
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.4.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.4.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.4.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.4.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.4.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.4.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.4.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.4.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.4.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.4.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.4
Source tag
To view or download the source code for CockroachDB v23.2.4 on Github, visit v23.2.4 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.3...v23.2.4
SQL language changes
- Mutation statements such as UPDATEandDELETEas well as locking statements such asSELECT FOR UPDATEare not allowed in read-only transactions orAS OF SYSTEM TIMEtransactions. Previously, a bug existed where mutation statements and locking statements in implicit single-statement transactions using AS OF SYSTEM TIME were allowed. #120158
- The new cluster setting sql.stats.virtual_computed_columns.enabled, when enabled, allows the collection of table statistics on virtual computed columns. #120933
- The new session variable optimizer_use_virtual_computed_column_stats, when enabled, configures the cost-based optimizer to use table statistics on virtual computed columns. #121329
DB Console changes
- Fixed an issue where clusters with multiple stores per node could list inaccurate region and node information on the Databases page. #120212
- Users will no longer see views displayed on the Databases page. Previously views would be listed with no information, only displaying errors. #120214
Bug fixes
- Previously, on long-running sessions that issue many (hundreds of thousands or more) transactions, CockroachDB's internal memory accounting system, the limit for which is configured via the --max-sql-memoryflag) could leak. This bug, in turn, could result in the error message"root: memory budget exceeded"for other queries. The bug was present in v23.2.3 and is now fixed. #121875
- Previously, altering a table's locality from REGIONAL BY ROWtoREGIONAL BY TABLEcould cause leaseholders to never move to the database's primary region. This is now fixed. #118794
- A user with the VIEWACTIVITYREDACTEDprivilege can no longer see constants inside of queries that originate from other users in theSHOW SESSIONSresult. Previously, this redaction did not occur. #119884
- Previously, the SHOW STATEMENTSand theSHOW QUERIEScommands incorrectly required the user to have theVIEWACTIVITYorVIEWACTIVITYREDACTEDprivilege. However, a user always should be able to view their own queries, even without these privileges. This is now fixed. #119884
- Fixed a bug where RESTOREon certainBACKUPs would open a very large number of connections to the backup storage provider. #119883
- Fixed a bug that occurred when using ALTER TABLEto drop and add back aCHECKconstraint with the same name. #120075
- Fixed a bug in which it was possible to set session variable transaction_read_onlytofalseduring anAS OF SYSTEM TIMEtransaction. #120158
- Fixed a bug where some files were not closed when inspecting backup metadata during BACKUPandRESTORE. #119635
- Fixed an intermittent page crash on the Schema Insights view. #120210
Contributors
This release includes 65 merged PRs by 37 authors
v23.2.3
Release Date: March 20, 2024
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.3.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.3.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.3.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.3.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.3.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.3.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.3.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.3.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.3.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.3.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.3
Source tag
To view or download the source code for CockroachDB v23.2.3 on Github, visit v23.2.3 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.2...v23.2.3
Security updates
- The DB Console sessioncookie is now markedHttpOnlyto prevent it from being read by any Javascript code. Cookies are also markedSecurefor the browser when the cluster is running in secure mode. #119259
- Clusters using Cluster Single Sign-on (SSO) with JSON web tokens (JWTs) can now optionally fetch signing keys from configured issuers instead of configuring static signing keys for each issuer. When the new cluster setting server.jwt_authentication.jwks_auto_fetch.enabledis set totrue, signing keys are automatically fetched from the issuer using metadata published in its OpenID configuration. In this case, static signing keys inserver.jwt_authentication.jwksare ignored. When automatic fetching is enabled, there may be a slight increase in network latency for each JWT authentication request, proportional to the latency between the cluster and the issuer's endpoint. #119768
Enterprise edition changes
- Fixed a bug where creating a changefeed with the format='avro'anddiffoptions that targeted tables with aDECIMAL(n)column (i.e., zero-scaleDECIMALcolumn) would cause a panic. #118847
SQL language changes
- Changed the sql.index_recommendation.drop_unused_durationcluster setting topublicso that it is documented on the Cluster Settings page. #118764
- Added the server.max_open_transactions_per_gatewaycluster setting. When set to a non-negative value, non-admin users cannot execute a query if the number of transactions open on the current gateway node is already at the configured limit. #118933
- Out-of-process SQL servers will now start exporting a new sql.aggregated_livebytesmetric. This metric gets updated once every 60 seconds by default, and its update interval can be configured via thetenant_global_metrics_exporter_intervalcluster setting. #119371
- Added support for index hints with INSERTandUPSERTstatements. This allowsINSERT ... ON CONFLICTandUPSERTqueries to use index hints in the same way they are already supported forUPDATEandDELETEstatements. #119601
Operational changes
- Expanded the --include-range-infoflag to include problem ranges. This flag still defaults totrue. #119234
- In unredacted debug zips, the crdb_internal.transaction_contention_eventstable file has two new columns:- waiting_stmt_query: the query of the waiting statement.
- blocking_txn_queries_unordered: the unordered list of the blocking transaction's queries. #118831
 
Command-line changes
- Updated the SQL shell help URL to point to the cockroach sqlpage. #118994
- cockroach debug tsdumpcreates a- tsdump.yamlfile. The- tsdumpraw format automatically creates the YAML file in the default location- /tmp/tsdump.yaml. Added a new flag- --yamlthat allows users to specify the path to create- tsdump.yamlinstead of using the default location. For example,- cockroach debug tsdump --host <host>:<port> \ --format raw --yaml=/some_path/tsdump.yaml > /some_path/tsdump.gob.#117741
DB Console changes
- Fixed a bug where a warning about the need to refresh data would remain displayed on the Active Executions view of the Statements and Transactions pages despite enabling Auto Refresh. #118703
- Updated the Statement Details page to always show the entire selected period, instead of just the period that had data. #118805
- The Overload dashboard now includes two additional graphs:
- Elastic CPU Utilization: displays the CPU utilization by elastic work, compared to the limit set for elastic work.
- Elastic CPU Exhausted Duration Per Second: displays the duration of CPU exhaustion by elastic work, in microseconds. #118896
 
- The Full Table/Index Scans chart in the SQL Metrics dashboard now shows the non-negative derivative of the number of full scans tracked. #118860
Bug fixes
- Fixed a bug where a changefeed could omit events in rare cases, logging the error cdc ux violation: detected timestamp ... that is less or equal to the local frontier. This could happen in the following scenario:- A rangefeed runs on a follower replica that lags significantly behind the leaseholder.
- A transaction commits and removes its transaction record before its intent resolution is applied on the follower.
- The follower's closed timestamp has advanced past the transaction commit timestamp.
- The rangefeed attempts to push the transaction to a new timestamp (at least 10 seconds after the transaction began).
- This may cause the rangefeed to prematurely emit a checkpoint before emitting writes at lower timestamps, which in turn may cause the changefeed to drop these events entirely, never emitting them. #118413
 
- Decommissioning replicas that are part of a mis-replicated range will no longer get stuck on a rebalance operation that was falsely determined to be unsafe. This bug was introduced in v23.1.0. #118343
- CockroachDB will no longer spam the logs with unable to get CPU capacityerrors every 10 seconds when running outside of a CPU cgroup. #118672
- AUTO CREATE STATSjobs could previously lead to growth in an internal system table resulting in slower job-system related queries. #118942
- Fixed a bug that caused an inscrutable error when a sequence name allocated by SERIALconflicted with an existing type name. #118947
- Fixed an internal error with a message like: LeafTxn ... incompatible with locking requestthat occurs when performing an update underREAD COMMITTEDisolation that cascades to a table with multiple other foreign keys. #118931
- Fixed a bug where ALTER PRIMARY KEYcould fail with an errornon-nullable column <x> with no value! Index scanned ..when validating recreated secondary indexes. #118974
- Fixed a bug where COMMENT ONstatements could fail with anunexpected valueerror if multipleCOMMENTstatements were running concurrently. #119020
- Previously, in certain cases, using virtual tables such as crdb_internal.system_jobscould result in the internal errorattempting to append refresh spans after the tracked timestamp has moved forward. This is now fixed. The bug was introduced in CockroachDB v23.1. #119184
- Fixed a bug where operations on the crdb_internal.leasestable could cause a node to become unavailable due to a deadlock in the leasing subsystem. #119341
- Fixed a bug where rangefeed resolved timestamps could get stuck, continually emitting the log message pushing old intents failed: range barrier failed, range split, typically following a range merge. #119541
- Fixed a bug where running a changefeed that targets a table with a user-defined type column and with the envelopeoption set to any value other thanwrappedwould cause a node panic due to a nil dereference. #119738
- Fixed a rare panic that could happen during a pg_dumpimport that contains a function that has a subquery in one of its arguments, likeSELECT addgeometrycolumn(...). Now, attempting to import apg_dumpwith such a function results in an expected error. #118612
- Users with the VIEWACTIVITY privilege can now request statement bundles using crdb_internal.request_statement_bundleor through the DB Console SQL Activity page. #118809
- Fixed a bug in changefeed webhook sinks where the HTTP request body may not be initialized on retries, resulting in the error http: ContentLength=... with Body length 0. #119496
- Fixed a bug that caused internal errors when executing an EXPORTstatement. #119711
- Fixed a bug that could lead to schema changes with a large number of descriptors doing full table scans on system.leases. #119464
- Fixed a bug where rangefeed resolved timestamps could get stuck, continually emitting the log message pushing old intents failed: range barrier failed, range split, typically following a range merge. This bug was introduced in v23.2.1. #119702
- Fixed a bug that occurred when using ALTER TABLEto drop and re-add aCHECKconstraint with the same name. #120076
- Fixed a bug that caused a slow memory leak that can accumulate when opening many new connections. The bug was present in v22.2.9+ and v23.1+ versions. #120245
Contributors
This release includes 118 merged PRs by 42 authors.
v23.2.2
Release Date: February 27, 2024
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.2.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.2.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.2.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.2.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.2.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.2.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.2.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.2.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.2.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.2.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.2
Source tag
To view or download the source code for CockroachDB v23.2.2 on Github, visit v23.2.2 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.1...v23.2.2
Bug fixes
- Fixed a bug where rangefeed resolved timestamps could get stuck, continually emitting the log message pushing old intents failed: range barrier failed, range split, typically following a range merge. This bug was introduced in v23.2.1. #119558
Contributors
This release includes 2 merged PRs by 2 authors.
v23.2.1
Release Date: February 20, 2024
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.1.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.1.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.1.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.1.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.1.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.1.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.1.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.1.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.1.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.1.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.1
Source tag
To view or download the source code for CockroachDB v23.2.1 on Github, visit v23.2.1 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.0...v23.2.1
Security updates
- Introduced the server.redact_sensitive_settings.enabledcluster setting, which is false by default. If set totrue, then the values of the following settings will be redacted when accessed throughSHOWcommands or other introspection interfaces. In the future, any other sensitive cluster settings that are added will be redacted as well. Users who have theMODIFYCLUSTERSETTINGprivilege can always view the unredacted settings. #117729- server.oidc_authentication.client_id
- server.oidc_authentication.client_secret
 
- If the server.redact_sensitive_settings.enabledcluster setting is set totrue, then theMANAGEVIRTUALCLUSTERprivilege is required to view the values of the per-virtual-cluster overrides for sensitive cluster settings. #117729
- The DB Console sessioncookie is now markedHttpOnlyto prevent it from being read by any JavaScript code. #119249
- DB Console cookies are marked Securefor the browser when the cluster is running in secure mode. #119249
General changes
- Updated Go version to 1.21.3. #115339
Enterprise edition changes
- Added a new SQL function fips_ready, which can be used to verify the FIPS readiness of the gateway node. #115202
- Physical Cluster Replication (PCR) now retries for approximately 3 minutes before failing. This is increased from 20 µs. #116402
- Fixed a bug where changefeeds that targeted schema-locked tables could fail due to a very old highwater timestamp being incorrectly persisted. #117961
- Fixed a bug where creating a changefeed that targeted tables with a DECIMAL(n)column (i.e., zero-scaleDECIMALcolumn),format='avro', anddiffwould cause a panic. #118895
SQL language changes
- Added the sql.ttl.default_select_rate_limitcluster setting and thettl_select_rate_limittable storage parameter to set the TTL select rate limit. This sets the number of records per table per second per node that can be selected by the TTL job. #115801
- Fixed a bug in PL/pgSQL where altering the name of a sequence or user-defined type (UDT) that was used in a PL/pgSQL function or procedure could break them. This bug was only present in v23.2 alpha and beta releases. #116419
- Added support for IMPORT INTOon a table that has columns typed as arrays of user-defined types (like enums). Tables that use multiple user-defined types with the same name but different schemas are still unsupported. #116359
- The new SELECT FOR UPDATEimplementation used under Read Committed isolation (and under Serializable isolation when theoptimizer_use_lock_op_for_serializablesession variable istrue) now locks all column families instead of only the first column family. #116826
- Fixed a bug where SELECT FOR UPDATEunder Read Committed isolation on multi-column-family tables was not locking column families containing only key columns. #116826
- It is now possible to run CALLstatements withEXPLAIN. TheEXPLAIN (OPT)variant will show the body of the procedure, while other variants will only show the procedure name and arguments. #116274
- EXPLAINoutput now contains detailed information about the plans for- CASCADEactions. #117719
Operational changes
- Per-node hot ranges logging now logs the top 5 hot ranges on the local node instead of the top 5 hot ranges cluster-wide. #118334
Command-line changes
- Added a new command cockroach debug enterprise-check-fips, which diagnoses errors in FIPS deployments. #115202
- The new flag --enterprise-require-fips-readycan be added to anycockroachcommand to prevent startup if certain prerequisites for FIPS compliance are not met. #115202
- cockroach workloadcommands now appropriately invoke- .Closein the case of an error. #116487
DB Console changes
- Updated the "CPU Time" label on the Runtime Dashboard to "SQL CPU Time" and added clarifications to its tooltip. #116449
- Statement bundles are now enabled for Serverless clusters. #117529
- The Networking Dashboard is enhanced with charts that visualize number of packets received, number of receiving packets with error, number of receiving packets that got dropped, number of packets sent, number of sending packets with error, and number of sending packets that got dropped. #116712
- The Explain Plans tab is now shown for the Statements and Insights pages, for Serverless clusters. #118169
Bug fixes
- Fixed a durability bug in Raft log storage, caused by incorrect syncing of filesystem metadata. Previously, it was possible to lose writes of a particular kind (AddSSTable) that were used by e.g.RESTORE. This loss was possible only under power-off or operating system crash conditions. Under such conditions, CockroachDB could enter a crash loop on node restart. In the worst case of a coordinated power-off/crash across multiple nodes this could lead to an unrecoverable loss of Raft quorum. #115709
- Fixed a bug where large jobs running with execution locality (such as some changefeeds) could result in the gateway node being assigned most of the work, causing performance degradation and cluster instability. #115388
- Fixed a bug that caused node crashes and panics when running INSERTqueries onREGIONAL BY ROWtables withUNIQUEconstraints or indexes. The bug was only present in v23.2.0-beta.1. #115668
- Fixed a bug that existed only in v23.2 alpha and beta versions that could have caused side effects to happen out of order for PL/pgSQL routines in rare cases. #115839
- Fixed a bug that existed since v23.1 that prevented naming user-defined type (UDT) parameters when dropping a user-defined function (or procedure). #115904
- Fixed a bug where scheduled jobs using external storage providers could fail shortly after node startup. #115693
- Locking tables (e.g., with SELECT FOR UPDATE) on the null-extended side of outer joins (e.g., the right side of aLEFT JOIN) is now disallowed and returns an error. This improves compatibility with PostgreSQL and prevents ambiguity in locking semantics. This bug has existed since locking withFOR UPDATEwas introduced. #115878
- Fixed a display bug in the DB Console where because not all types of schema changes are setting the value for the mutation ID, the value of the ID could previously show as "with ID undefined" on the Events panel. Now, the notification omits the undefined value (the rest of the event notification is still displayed). #116518
- Fixed the formatting for PL/pgSQL routines, which could prevent creating a routine with loop labels, and could prevent some expressions from being redacted correctly. The bug only existed in v23.2 alpha and beta releases. #116713
- Fixed a bug that would cause a syntax error during redaction of a PL/pgSQL routine. The bug existed only in v23.2 alpha and beta releases. #116713
- Fixed a bug that would cause syntax errors when attempting to RESTOREa database with PL/pgSQL user-defined functions (UDFs) or stored procedures. This bug only affected v23.2 alpha and beta releases. #116713
- UPDATE,- UPSERT, and- INSERT ON CONFLICTqueries are now disallowed under Read Committed isolation when the table contains a check constraint involving a column family that is updated, and the check constraint also involves a column family that is not updated, but is read. This is a temporary fix to prevent possible violation of the check constraint, and the restriction will be lifted in the future. #116428
- Previously, all AggHistogram-powered metrics were not reporting quantiles properly in the DB Console. This patch fixes the histograms so that the quantiles in DB Console are reported correctly. these histograms were only broken in the DB Console metrics dashboards, but were not broken in the Prometheus-compatible endpoint,/_status/vars. The list of affected metrics is shown below. #114506- changefeed.message_size_hist
- changefeed.parallel_io_queue_nanos
- changefeed.sink_batch_hist_nanos
- changefeed.flush_hist_nanos
- changefeed.commit_latency
- changefeed.admit_latency
- jobs.row_level_ttl.span_total_duration
- jobs.row_level_ttl.select_duration
- jobs.row_level_ttl.delete_duration
 
- Fixed a bug introduced in v23.2 that caused internal errors and panics when certain SQL queries were run with automatic index recommendation collection enabled. #117453
- Standard indexes and inverted indexes may no longer be created on PL/pgSQL REFCURSOR[]s columns.REFCURSORcolumns themselves are not indexable. #116071
- Fixed a bug that prevented database RESTOREwhen the database contained a view or routine that referenced a user-defined type (UDT) in the body string. For views, this bug was introduced in v20.2, when user-defined types (UDTs) were introduced. For routines, this bug was introduced in v22.2, when user-defined functions (UDFs) were introduced. #116841
- Fixed a bug that could cause a function resolution error when attempting to use a builtin function like now()as a formatting argument to a PL/pgSQLRAISEstatement. #116825
- Fixed a bug where CDC custom key columns did not function correctly with CDC queries. For example, CREATE CHANGEFEED WITH key_column=..., unordered AS SELECT * FROM tablenow works correctly instead of retrying forever. Note that some functionalities with CDC custom keys are not fully supported, see #115267 for more details. #116967
- Fixed a bug in Raft log truncation that could lead to crash loops, and unrecoverable loss of quorum in the unlikely worst case that all replicas enter this crash loop. The bug manifested when a few things coincided: The cluster was running a bulk write workload (e.g., schema change, import, RESTORE); a log truncation command was running; and the process crashed at an unfortunate moment (e.g., the process was killed, or killed itself for reasons like detecting a disk stall). #116574
- Fixed the value used for the total runtime on SQL statistics. This was using the wrong value previously, causing the SQL Activity page to display values with more than 100%. #117426
- Fixed a bug where trying to set an empty search_pathsession variable resulted in an error. #117557
- It is now possible to assign to the parameter of a PL/pgSQL routine. Previously, attempts to do this would result in a "variable not found" error at routine creation time. In addition, variable shadowing is now explicitly disabled, where previously it would cause an internal error. These bugs existed in the v23.2.0 release and the v23.2 pre-release versions. #117715
- Fixed a bug in the row-level TTL job that would cause it to skip expired rows if the primary key of the table included columns of the collated string type. This bug was present since the initial release of row-level TTL in v22.2.0. #117512
- Fixed a bug where concurrent GRANTstatements can cause deadlocks. #117713
- CockroachDB can now transparently retry more retryable errors when performing a non-atomic COPYcommand. #117895
- Fixed a bug that caused DML statements to fail while a hash-sharded index was being created. The symptom of this bug was an error like column "crdb_internal_val_shard_16" does not exist. This bug was present since v23.1.0. #118215
- Previously, CockroachDB could encounter the error unable to encode table key: *tree.DTSQuerywhen operating on columns with the internalTSQuerytype in some contexts (e.g., when collecting table statistics or when performing aDISTINCToperation). This is now fixed. The bug had been present since v23.1 when support for the internalTSQuerytype was added. #118321
- Previously, in some cases CockroachDB could incorrectly evaluate queries that scanned an inverted index and had a WHEREfilter in which two sides of theANDexpression had "similar" expressions (e.g.,ARRAY['str1'] <@ col AND (ARRAY['str1'] && col OR ...)); this is now fixed. The bug had been present since prior to v22.2. #118360
- Fixed a bug that could cause DELETEqueries sent by the row-level TTL job to use a secondary index rather than the primary index to find the rows to delete. This could lead to someDELETEoperations taking a much longer time than they should. This bug was present since v22.2.0. #118337
- Fixed an issue with missing data on SQL statistics, and consequently missing data on the SQL Activity page, by properly recalculating the value from the current and past hour on the top activity table. #118378
- Internal queries issued by the row-level TTL jobs should now use optimal plans. The bug has been present since at least v22.2. #118494
- Fixed a bug where a changefeed could omit events in rare cases, logging the error cdc ux violation: detected timestamp ... that is less or equal to the local frontier. This could happen in the following scenario:- A rangefeed runs on a follower replica that lags significantly behind the leaseholder.
- A transaction commits and removes its transaction record before its intent resolution is applied on the follower.
- The follower's closed timestamp has advanced past the transaction commit timestamp.
- The rangefeed attempts to push the transaction to a new timestamp (at least 10 seconds after the transaction began).
- This may cause the rangefeed to prematurely emit a checkpoint before emitting writes at lower timestamps, which in turn may cause the changefeed to drop these events entirely, never emitting them. #118981
 
Contributors
This release includes 252 merged PRs by 60 authors.
v23.2.0
Release Date: February 5, 2024
With the release of CockroachDB v23.2, we've added new capabilities to help you migrate, build, and operate more efficiently. See our summary of the most significant user-facing changes under Feature Highlights.
Downloads
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.0.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.0.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.0.linux-arm64.tgz (SHA256) | cockroach-sql-v23.2.0.linux-arm64.tgz (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.0.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.0.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.0.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.0.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.0.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.0.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image, both Intel and ARM images are generally available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach:v23.2.0
Source tag
To view or download the source code for CockroachDB v23.2.0 on Github, visit v23.2.0 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.0-rc.2...v23.2.0
Feature highlights
This section summarizes the most significant user-facing changes in v23.2.0 and other features recently made available to CockroachDB users across versions. For a complete list of features and changes in v23.2, including bug fixes and performance improvements, see the release notes for previous v23.2 testing releases. You can also search the docs for sections labeled New in v23.2.
- Feature categories
- Additional information
In CockroachDB Self-Hosted, all available features are free to use unless their description specifies that an Enterprise license is required. For more information, see the Licensing FAQ.
Observability
| Feature | Availability | |||
|---|---|---|---|---|
| Ver. | Self-Hosted | Dedicated | Serverless | |
| Identify network partitions using updated metrics in the Network page The Network page in the DB console has been updated with additional metrics that surface when the cluster is unstable due to network partitions. | 23.2 |  |  |  | 
| Troubleshoot 40001 errors from isolation conflicts in highly contended workloads Failed execution insights have been enhanced to include additional information (conflicting transaction and location) into 40001 errors that stem from isolation conflicts in highly contentious workloads. | 23.2 |  |  |  | 
| Identify and troubleshoot your most recent transactions and statements in the console Users can control the refresh of SQL activity Active Executions. They can turn off automatic polling and instead manually refresh the page. The page will persist recent executions and their statistics and plans to allow users to troubleshoot their recent workload. Previously, the Active executions page would refresh automatically and cause potentially problematic executions to disappear from the page making it difficult to troubleshoot recent workloads. | 23.2 |  |  |  | 
| Integrate SQL activity with Datadog for end-to-end observability SQL activity such as statements and transactions can be emitted with fine granularity to Datadog as logs to allow end to end observability using both metrics and logs. | 23.2 |  |  |  | 
| Customize your own metric dashboard for CockroachDB serverless The CockroachDB Cloud console supports additional metrics that can be customized in a single dashboard for CockroachDB Serverless. | All* |  |  |  | 
Migrations
| Feature | Availability | |||
|---|---|---|---|---|
| Ver. | Self-Hosted | Dedicated | Serverless | |
| Migrate to CockroachDB using Oracle Golden Gate You can now use Oracle Golden Gate to stream data directly into CockroachDB. Migrate data from compatible databases onto CockroachDB using this connector. | All** |  |  |  | 
| Migrate to CockroachDB using Debezium You can now use Debezium to stream data directly into CockroachDB. Migrate data from compatible databases onto CockroachDB using this connector. | All** |  |  |  | 
Disaster recovery
| Feature | Availability | |||
|---|---|---|---|---|
| Ver. | Self-Hosted | Dedicated | Serverless | |
| Physical Cluster Replication is now available in Preview Physical Cluster Replication is an asynchonous replication feature that allows your cluster to recover from full-cluster failure with a low RPO and RTO. In 23.2, it is a Preview feature, requiring an Enterprise license, and only available for self-hosted CockroachDB deployments. | 23.2 |  |  |  | 
Security and compliance
| Feature | Availability | |||
|---|---|---|---|---|
| Ver. | Self-Hosted | Dedicated | Serverless | |
| Use Azure IAM to authenticate storage for changefeeds and backup/restore Use implicit authorization to leverage existing azure credentials to authenticate with your Azure Blob Storage bucket. | 23.2 |  |  |  | 
| Folders UI in CockroachDB Cloud Orgs (Limited Access) CockroachDB Cloud organizations can now organize clusters using folders and can assign roles and permissions at the folder scope. | All* |  |  |  | 
Deployment and operations
| Feature | Availability | |||
|---|---|---|---|---|
| Ver. | Self-Hosted | Dedicated | Serverless | |
| General Availability for ARM binaries for Linux and Docker With this release, Linux and Docker binaries for the ARM 64-bit architecture are Generally Available (GA) for production workloads. ARM binaries for macOS are **experimental** and not yet qualified for production use. For more details, installation instructions, and limitations, refer to Install CockroachDB on Linux. | 23.2 |  |  |  | 
SQL
| Feature | Availability | |||
|---|---|---|---|---|
| Ver. | Self-Hosted | Dedicated | Serverless | |
| Support Read Committed Isolation Level in public preview Read Committed is a weaker transaction isolation level than Serializable and is the default isolation level in databases such as PostgreSQL, Oracle, and SQL Server. Read Committed isolation allows writes to interleave without aborting transactions and prevents writes from blocking reads, thus minimizing query latency and retries caused by read/write contention. | 23.2 |  |  |  | 
| Improved UDF capabilities UDFs now support mutations (INSERT, UPDATE, UPSERT, and DELETE). | 23.2 |  |  |  | 
| Support stored procedures and PL/pgSQL PL/pgSQL capabilities such as stored procedures, conditional logic, loops, and exception handling are now supported, increasing compatibility between CockroachDB and PostgreSQL. An Enterprise license is required. | 23.2 |  |  |  | Delete operation admission control This feature reduces the potential impact of deleting a large number of rows—directly, as well as implicitly via row-level TTL—on query performance and system stability. For more information, see Operations subject to admission control. | 23.2 |  |  |  | 
| Replication admission control This mechanism automatically paces work for which longer exection times are acceptable (such as index backfills) at the speed of the slowest replica in order to maintain cluster stability and throughput. For more information, see Operations subject to admission control. | 23.2 |  |  |  | 
| Column Level Encryption CockroachDB now supports column-level encryption through a set of built-in functions. This feature allows you to encrypt one or more columns in every row of a database table, and can be useful for compliance scenarios such as adhering to PCI or GDPR. An Enterprise license is required. | 23.2 |  |  |  | 
| Revoke CREATE privilege by default for public schema Newer versions of PostgreSQL (15 and above) do not grant the  | 23.2 |  |  |  | 
| Easily find Default Privileges for a Role This feature adds a simple syntax to see the default privileges for a particular grantee. SHOW DEFAULT PRIVILEGES FOR GRANTEE root; | 23.2 |  |  |  | 
Feature detail key
| * | Features marked “All*” were recently made available in the CockroachDB Cloud platform. They are available for all supported versions of CockroachDB, under the deployment methods specified in their row under Availability. | 
| ** | Features marked “All**” were recently made available via migration tools maintained outside of the CockroachDB binary. They are available to use with all supported versions of CockroachDB, under the deployment methods specified in their row under Availability. | 
|  | Feature is available for this deployment method of CockroachDB as specified in the icon’s column: CockroachDB Self-Hosted, CockroachDB Dedicated, or CockroachDB Serverless. | 
|  | Feature is not available for this deployment method of CockroachDB as specified in the icon’s column: CockroachDB Self-Hosted, CockroachDB Dedicated, or CockroachDB Serverless. | 
Backward-incompatible changes
Before upgrading to CockroachDB v23.2, be sure to review the following backward-incompatible changes, as well as key cluster setting changes, and adjust your deployment as necessary.
- The pre-v23.1 output produced by SHOW RANGES,crdb_internal.ranges, andcrdb_internal.ranges_no_leaseswas deprecated in v23.1 and is now replaced by default with output that's compatible with coalesced ranges (anges that pack multiple tables/indexes/partitions into individual ranges). See the v23.1 release notes forSHOW RANGESfor more details. #102961
- When a deployment is configured to use a time zone for log file output using formats crdb-v1orcrdb-v2, new output log entries cannot be processed by nodes that have not been upgraded to v23.2. #104265
- When customizing the SQL shell's interactive prompt, the special sequence %Mnow expands to the full host name instead of the combination of host name and port number. To include the port number explicitly, use%>. The special sequence%mnow expands to the host name up to the first period. #105137
- The cockroach debug zipcommand stores data retrieved from SQL tables in the remote cluster using the TSV format by default. #107474
- The changefeed.protect_timestamp.max_agecluster setting will only apply to newly created changefeeds in v23.2. For existing changefeeds, you can set theprotect_data_from_gc_on_pauseoption so that changefeeds do not experience infinite retries and accumulate protected change data. You can use theALTER CHANGEFEEDstatement to addprotect_data_from_gc_on_pauseto existing changefeeds. #103539
- The direct export of traces to Jaeger and the cluster setting trace.jaeger.agenthave been removed. The direct export functionality had been obsoleted since 2022; it stopped working altogether sometime in 2023 with the following error:data does not fit within one UDP packet; size 65006, max 65000, spans NN. Since 2022, Jaeger supports ingestion of traces using OTLP; and CockroachDB has supported emitting traces using OTLP since v22.1. Operators and developers who want to inspect traces are thus invited to use the OTLP protocol instead. The corresponding cluster setting istrace.opentelemetry.collector. For a successful deployment, an intermediate OTLP collector/forwarder should be configured. For an example of how to orchestrate the OpenTelemetry collector and Jaeger together using Docker Compose, or how to configure theotel-collector, see the more-detailed entry in v23.2-alpha.3 backward-incompatible changes. #111342
Key Cluster Setting Changes
The following changes should be reviewed prior to upgrading. Default cluster settings will be used unless you have manually set a value for a setting. This can be confirmed by checking the system.settings table (select * from system.settings) to view the non-default settings.
- The new cluster setting - sql.txn.read_committed_syntax.enabled, controls whether transactions run under- READ COMMITTEDor- SERIALIZABLEisolation. It defaults to- false. When set to- true, the following statements will configure transactions to run under- READ COMMITTEDisolation:- BEGIN TRANSACTION ISOLATION LEVEL READ COMMITTED
- SET TRANSACTION ISOLATION LEVEL READ COMMITTED
- SET default_transaction_isolation = 'read committed'
- SET SESSION CHARACTERISTICS AS TRANSACTION ISOLATION LEVEL READ COMMITTED
 
- The - sql.txn.read_committed_syntax.enabledcluster setting was renamed to- sql.txn.read_committed_isolation.enabled. #113833
- Users who have the - CREATEROLErole option can now grant and revoke role membership in any non-admin role. This change also removes the- sql.auth.createrole_allows_grant_role_membership.enabledcluster setting, which was added in v23.1. In v23.2, the cluster setting is effectively always true. #104376
- The cluster setting - sql.metrics.statement_details.gateway_node.enablednow defaults to false to reduce the number of rows generated in SQL Statistics pages. #107788
- The cluster setting - kv.rangefeed.enabledno longer controls access to- RANGEFEED SQLcommands. Instead, use- feature.changefeed.enabled. #110676
- The cluster settings related to physical cluster replication have been renamed for consistency. For example, - bulkio.stream_ingestion.minimum_flush_intervalis now named- physical_replication.consumer.minimum_flush_interval. #111197
- CockroachDB now periodically dumps the state of its internal memory accounting system into the - heap_profiler/directory when a heap profile is taken. To disable this behavior, set the- diagnostics.memory_monitoring_dumps.enabledcluster setting to- false. #114998
- Introduced the cluster setting - kv.gc.sticky_hint.enabledin v23.1.13. This setting helps expedite garbage collection after range deletions. For example, when a SQL table or index is dropped.- kv.gc.sticky_hint.enabledis enabled by default and deprecated in v23.2. #113040
- CockroachDB now enables the pacing mechanism in rangefeed closed timestamp notifications, by setting the default - kv.rangefeed.closed_timestamp_smear_intervalcluster setting to 1ms. This makes rangefeed closed timestamp delivery more uniform and less spikey, which reduces its impact on the Go scheduler and, ultimately, foreground SQL latencies. #103006
Deprecations
- The protect_data_from_gc_on_pauseoption has been deprecated. This option is no longer needed since changefeed jobs always protect data. #103539
- The cockroach connectfunctionality has been deprecated. #114241
Known limitations
For information about new and unresolved limitations in CockroachDB v23.2, with suggested workarounds where applicable, see Known Limitations.
Additional resources
| Resource | Topic | Description | 
|---|---|---|
| Cockroach University | Introduction to Distributed SQL and CockroachDB | This course introduces the core concepts behind distributed SQL databases and describes how CockroachDB fits into this landscape. You will learn what differentiates CockroachDB from both legacy SQL and NoSQL databases and how CockroachDB ensures consistent transactions without sacrificing scale and resiliency. You'll learn about CockroachDB's seamless horizontal scalability, distributed transactions with strict ACID guarantees, and high availability and resilience. | 
| Cockroach University | Practical First Steps with CockroachDB | This course will give you the tools you need to get started with CockroachDB. During the course, you will learn how to spin up a cluster, use the Admin UI to monitor cluster activity, and use SQL shell to solve a set of hands-on exercises. | 
| Cockroach University | Enterprise Application Development with CockroachDB | This course is the first in a series designed to equip you with best practices for mastering application-level (client-side) transaction management in CockroachDB. We'll dive deep on common differences between CockroachDB and legacy SQL databases and help you sidestep challenges you might encounter when migrating to CockroachDB from Oracle, PostgreSQL, and MySQL. | 
| Cockroach University | Building a Highly Resilient Multi-region Database using CockroachDB | This course is part of a series introducing solutions to running low-latency, highly resilient applications for data-intensive workloads on CockroachDB. In this course we focus on surviving large-scale infrastructure failures like losing an entire cloud region without losing data during recovery. We’ll show you how to use CockroachDB survival goals in a multi-region cluster to implement a highly resilient database that survives node or network failures across multiple regions with zero data loss. | 
| Docs | Migration Overview | This page summarizes the steps of migrating a database to CockroachDB, which include testing and updating your schema to work with CockroachDB, moving your data into CockroachDB, and testing and updating your application. | 
| Docs | Architecture Overview | This page provides a starting point for understanding the architecture and design choices that enable CockroachDB's scalability and consistency capabilities. | 
| Docs | SQL Feature Support | The page summarizes the standard SQL features CockroachDB supports as well as common extensions to the standard. | 
| Docs | Change Data Capture Overview | This page summarizes CockroachDB's data streaming capabilities. Change data capture (CDC) provides efficient, distributed, row-level changefeeds into a configurable sink for downstream processing such as reporting, caching, or full-text indexing. | 
| Docs | Backup Architecture | This page describes the backup job workflow with a high-level overview, diagrams, and more details on each phase of the job. | 
v23.2.0-rc.2
Release Date: January 9, 2024
Downloads
CockroachDB v23.2.0-rc.2 is a testing release. Testing releases are intended for testing and experimentation only, and are not qualified for production environments and not eligible for support or uptime SLA commitments.
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.0-rc.2.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.0-rc.2.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.0-rc.2.linux-arm64.tgz (Experimental) (SHA256) | cockroach-sql-v23.2.0-rc.2.linux-arm64.tgz (Experimental) (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.0-rc.2.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.0-rc.2.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.0-rc.2.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.0-rc.2.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.0-rc.2.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.0-rc.2.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image:
- The ARM image is in Limited Access.
- The Intel image is Generally Available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach-unstable:v23.2.0-rc.2
Source tag
To view or download the source code for CockroachDB v23.2.0-rc.2 on Github, visit v23.2.0-rc.2 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.0-rc.1...v23.2.0-rc.2
Bug fixes
- Fixed a bug introduced in v23.2 that caused internal errors and panics when certain queries ran with automatic index recommendation collection enabled. #117454
- Fixed a bug where mixed-version clusters with both v23.1 and v23.2 nodes could detect a false-positive replica inconsistency in GLOBALtables. #117341
Contributors
This release includes 12 merged PRs by 9 authors.
v23.2.0-rc.1
Release Date: December 21, 2023
Downloads
CockroachDB v23.2.0-rc.1 is a testing release. Testing releases are intended for testing and experimentation only, and are not qualified for production environments and not eligible for support or uptime SLA commitments.
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.0-rc.1.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.0-rc.1.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.0-rc.1.linux-arm64.tgz (Experimental) (SHA256) | cockroach-sql-v23.2.0-rc.1.linux-arm64.tgz (Experimental) (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.0-rc.1.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.0-rc.1.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.0-rc.1.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.0-rc.1.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.0-rc.1.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.0-rc.1.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image:
- The ARM image is in Limited Access.
- The Intel image is Generally Available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach-unstable:v23.2.0-rc.1
Source tag
To view or download the source code for CockroachDB v23.2.0-rc.1 on Github, visit v23.2.0-rc.1 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.0-beta.3...v23.2.0-rc.1
Enterprise edition changes
- Added a SQL function crdb_internal.fips_ready()that can be used to verify the FIPS readiness of the gateway node. #116281
- Physical cluster replication now retries for just over 3 minutes before failing. #116404
SQL language changes
- CALLstatements can now be run with- EXPLAIN. The- EXPLAIN (OPT)variant will show the body of the procedure, while other variants will show only the procedure name and arguments. #116273
- Added support for IMPORT INTOa table that has columns typed as arrays of user-defined types (likeENUM). Tables that use multiple user-defined types with the same name but different schemas are still unsupported. #116360
- The SELECT FOR UPDATEimplementation used under Read Committed isolation (and under Serializable isolation whenoptimizer_use_lock_op_for_serializableis set totrue) now locks all column families instead of only the first column family. #116828
Command-line changes
- Added the command cockroach debug enterprise-check-fipsthat diagnoses errors in FIPS deployments. #116281
- Added the flag --enterprise-require-fips-readythat can be run with any CockroachDB command to prevent startup if certain prerequisites for FIPS compliance are not met. #116281
DB Console changes
- Updated the CPU Time label to SQL CPU Time and added clarification to its tooltip on the SQL Activity and Insights pages. #116450
- Removed the ID when it is undefinedfrom the event description in the Metrics Events Panel. #116519
Bug fixes
- Fixed a bug that caused node crashes and panics when running INSERTqueries onREGIONAL BY ROWtables withUNIQUEconstraints or indexes. The bug is only present in version v23.2.0-beta.1. #116343
- UPDATE,- UPSERT, and- INSERT ON CONFLICTqueries are now disallowed under Read Committed isolation when the table contains a- CHECKconstraint involving a column family that is updated, and that- CHECKconstraint also involves a column family that is not updated, but is read. This restriction is a temporary fix to prevent possible violation of the- CHECKconstraint. However, it is important to note that this restriction will be lifted in the future. #116429
- Fixed a bug where scheduled jobs using external storage providers may fail shortly after node startup. #116205
- Fixed the formatting for plpgsqlroutines, which could prevent the creation of a routine with loop labels and could prevent some expressions from being redacted correctly. The bug only existed in alpha and beta versions of v23.2. #116711
- Fixed a bug that would cause a syntax error during redaction of a PL/pgSQL routine. The bug existed only in alpha and beta versions of the v23.2 release. #116711
- Fixed a bug that would cause syntax errors when attempting to restore a database with PL/pgSQL UDFs or stored procedures. This bug only affected alpha and beta versions of v23.2. #116711
- Fixed a bug in PL/pgSQL where altering the name of a sequence or UDT that was used in a PL/pgSQL function or procedure could break them. This is only present in v23.2 alpha and beta releases. #116420
- Fixed a bug where SELECT FOR UPDATEunder Read Committed isolation on multi-column-family tables was not locking column families containing only key columns. #116828
- Fixed a bug where all - AggHistogram-powered metrics were not reporting quantiles properly in the DB Console. The quantiles in the DB Console are now reported correctly. This bug was only present in histograms in the DB Console metrics features, and did not affect metrics reporting in the Prometheus-compatible endpoint,- /_status/vars. The affected metrics were:- changefeed.message_size_hist
- changefeed.parallel_io_queue_nanos
- changefeed.sink_batch_hist_nanos
- changefeed.flush_hist_nanos
- changefeed.commit_latency
- changefeed.admit_latency
- jobs.row_level_ttl.span_total_duration
- jobs.row_level_ttl.select_duration
- jobs.row_level_ttl.delete_duration
 
Contributors
This release includes 49 merged PRs by 26 authors.
v23.2.0-beta.3
Release Date: December 13, 2023
Downloads
CockroachDB v23.2.0-beta.3 is a testing release. Testing releases are intended for testing and experimentation only, and are not qualified for production environments and not eligible for support or uptime SLA commitments.
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.0-beta.3.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.0-beta.3.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.0-beta.3.linux-arm64.tgz (Experimental) (SHA256) | cockroach-sql-v23.2.0-beta.3.linux-arm64.tgz (Experimental) (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.0-beta.3.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.0-beta.3.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.0-beta.3.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.0-beta.3.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.0-beta.3.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.0-beta.3.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image:
- The ARM image is Experimental and not yet qualified for production use and not eligible for support or uptime SLA commitments.
- The Intel image is Generally Available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach-unstable:v23.2.0-beta.3
Source tag
To view or download the source code for CockroachDB v23.2.0-beta.3 on Github, visit v23.2.0-beta.3 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.0-beta.2...v23.2.0-beta.3
General changes
- Updated Go version to 1.21.3. #116098
SQL language changes
- Added the sql.ttl.default_select_rate_limitcluster setting and thettl_select_rate_limittable storage parameter to set the TTL select rate limit. This sets the number of records per table per second per node that can be selected by the TTL job. #115802
Bug fixes
- Fixed a bug that could result in an incorrect too few columnserror for queries that useANY <array>syntax with a subquery. #115592
- Fixed a bug that could cause too few columns/too many columnserrors for queries that usedINorNOT INwith a non-trivial right operand, such as a subquery (rather than a constant tuple). #115592
- Fixed a bug where CREATE INDEXwith expressions could fail on materialized views when the declarative schema changer was used. #115522
- Fixed a bug that could cause PL/pgSQL routines with SELECT INTOsyntax to return early. This bug existed only in pre-release versions v23.2.0-beta.1 and v23.2.0-beta.2. #115676
- Fixed a bug that could cause side effects to happen out of order for PL/pgSQL routines in rare cases. This bug existed only in v23.2 alpha versions and previous v23.2 beta versions. #115840
- Previously, in rare cases, CockroachDB could incorrectly evaluate queries with lookup joins where equality cols are keywhen performing lookups on multiple ranges. This could either manifest as a stuck query or result in incorrect output. The bug was introduced in v22.2 and is now fixed. #115580
- Fixed a durability bug in Raft log storage that was caused by incorrect syncing of filesystem metadata. It was possible to lose writes of a particular kind (AddSSTable) used by (e.g.)RESTORE. This loss was possible only under power-off or OS crash conditions. As a result, CockroachDB could enter a crash loop on restart. In the worst case of a coordinated power-off/crash across multiple nodes, this could lead to an unrecoverable loss of quorum. #115841
- Fixed a bug where large jobs running with execution localityoption could result in the gateway node being assigned most of the work causing performance degradation and cluster instability. #115876
- Fixed a bug that prevented naming UDT parameters when dropping a user-defined function (or procedure). This bug has existed since v23.1. #115905
- Locking tables (e.g., with SELECT ... FOR UPDATE) on the null-extended side of outer joins (e.g., the right side of a LEFT JOIN) is now disallowed and returns an error. This improves compatibility with PostgreSQL and prevents ambiguity in locking semantics. This bug has existed since locking withFOR UPDATEwas introduced. #115879
Contributors
This release includes 26 merged PRs by 20 authors.
v23.2.0-beta.2
Release Date: December 5, 2023
Downloads
CockroachDB v23.2.0-beta.2 is a testing release. Testing releases are intended for testing and experimentation only, and are not qualified for production environments and not eligible for support or uptime SLA commitments.
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.0-beta.2.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.0-beta.2.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.0-beta.2.linux-arm64.tgz (Experimental) (SHA256) | cockroach-sql-v23.2.0-beta.2.linux-arm64.tgz (Experimental) (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.0-beta.2.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.0-beta.2.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.0-beta.2.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.0-beta.2.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.0-beta.2.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.0-beta.2.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image:
- The ARM image is Experimental and not yet qualified for production use and not eligible for support or uptime SLA commitments.
- The Intel image is Generally Available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach-unstable:v23.2.0-beta.2
Source tag
To view or download the source code for CockroachDB v23.2.0-beta.2 on Github, visit v23.2.0-beta.2 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.0-beta.1...v23.2.0-beta.2
General changes
- CockroachDB now periodically dumps the state of its internal memory accounting system into the heap_profiler/directory when a heap profile is taken. To disable this behavior, set thediagnostics.memory_monitoring_dumps.enabledcluster setting tofalse. #114998
- Multi-level compactions have been disabled to investigate possible performance issues with foreground throughput and latency. #115481
Enterprise Edition changes
- When using Physical Cluster Replication, you can now initiate a cutover as of LATESTbefore the initial scan completes. #115101
- Sensitive information such as api_secret,sasl_password,client_cert, andca_cert, is now redacted in output from commandsSHOW CHANGEFEED JOB,SHOW CHANGEFEED JOBS, andSHOW JOBS. #115567
- The physical_replication.frontier_lag_nanosmetric and the related DB Console graph have been removed because they sometimes display incorrect information. For alerting, it is recommended to use the new metricphysical_replication.replicated_time_secondsmetric instead. #115234
- Fixed a bug in physical cluster replication where replicating from a primary cluster that is on a version prior to v23.2.x to a standby cluster running on v23.2.x could fail because of an undefined builtin function in the primary cluster. #114257
DB Console changes
- In the Changeeds dashboard, the Max Checkpoint Latency chart title now refers to "Lag" rather than "Latency", to better reflect the intention of the underlying metric, which measures how recently the changefeed was last checkpointed. #115003
- Times on the X-Axis of bar charts in Statement details pages are now correctly formatted in UTC. #115220
- In the SQL Activity Transaction Details page, you can now view a transaction fingerprint ID across multiple applications by specifying the application name in the appNamesURLGETparameter using a comma-separated encoded string of transaction fingerprint IDs. #115204
Bug fixes
- Fixed a bug that prevented the Now button on time range selectors in the DB Console from working as expected when a custom time period was previously selected. #115514
- Fixed a bug that prevented the SQL Activity page from showing internal statements when the sql.stats.response.show_internal.enabledcluster setting was set totrue. #114824
- Fixed a bug where an active replication report update could get stuck in a retry loop on clusters with over 10000 ranges. This could prevent a node from shutting down cleanly. #114178
- Fixed a bug introduced in v23.1 that could cause an internal error when using the text format (as opposed to binary) when preparing a statement with a user-defined composite type. #115064
- Fixed a bug that could cause a replica to be stuck processing in a queue's replica set when the replica had recently been removed from purgatory for processing but was destroyed, or the replica's ID changed before being processed. These replicas are now removed from the queue when they are encountered. #115037
- Fixed a bug that could cause a prepared statement to fail if it references both an enumand a table that has undergone a schema change. #115132
- Fixed a bug that could cause cluster version finalization to contend with descriptor lease renewals on large clusters. Descriptor lease renewals previously had a higher priority than cluster upgrade finalization. Finalization now always has a higher priority than descriptor lease renewal. #115034
- Fixed a bug that prevented backups from distributing work evenly across all replicas, including followers, regardless of leaseholder placement. #115019
- Fixed a bug introduced in v23.2.0-beta.1 that could cause a single composite-typed variable to be incorrectly handled as the target of a PostgreSQL INTOclause. #115404
- Fixed a bug that could cause a BEGINstatement log to record incorrect information in theAgefield, which could also cause them to appear erroneously in slow-query logs. #115259
Performance improvements
- Query planning time has been reduced significantly for some queries in which many tables are joined. #114445
Contributors
This release includes 91 merged PRs by 35 authors.
v23.2.0-beta.1
Release Date: November 27, 2023
Downloads
CockroachDB v23.2.0-beta.1 is a testing release. Testing releases are intended for testing and experimentation only, and are not qualified for production environments and not eligible for support or uptime SLA commitments.
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.0-beta.1.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.0-beta.1.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.0-beta.1.linux-arm64.tgz (Experimental) (SHA256) | cockroach-sql-v23.2.0-beta.1.linux-arm64.tgz (Experimental) (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.0-beta.1.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.0-beta.1.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.0-beta.1.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.0-beta.1.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.0-beta.1.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.0-beta.1.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image:
- The ARM image is Experimental and not yet qualified for production use and not eligible for support or uptime SLA commitments.
- The Intel image is Generally Available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach-unstable:v23.2.0-beta.1
Source tag
To view or download the source code for CockroachDB v23.2.0-beta.1 on Github, visit v23.2.0-beta.1 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.0-alpha.7...v23.2.0-beta.1
SQL language changes
- COPYcommands now use the- backgroundquality-of-service level by default, which makes- COPYcommands subject to admission control. The new session variable- copy_transaction_quality_of_servicecontrols the quality-of-service level for- COPYcommands. Previously,- COPYused the same level as other commands, determined by the- default_transaction_quality_of_servicesession variable, which is set to- regularby default.- regularis not subject to admission control. #114535
DB Console changes
- The Overview page now correctly renders the background color for the email signup, which fixes an issue where it was difficult to read the text. #114547
- Fixed a bug where selecting the internal application name prefix $ internalfrom the Application Name dropdown on the SQL Activity Statements page was not showing internal queries. The filtering logic will now show if there are statements with the$ internalapplication name prefix. #114517
Bug fixes
- Fixed a bug where an empty range corresponding to a DROP TABLEdid not respect system-level span configurations such as protected timestamps, which potentially caused reads above the protected timestamp to fail. #114833
- Fixed error handling for GetFilesso that it does not cause a nil pointer dereference. #114830
Contributors
This release includes 33 merged PRs by 21 authors.
v23.2.0-alpha.7
Release Date: November 20, 2023
Downloads
CockroachDB v23.2.0-alpha.7 is a testing release. Testing releases are intended for testing and experimentation only, and are not qualified for production environments and not eligible for support or uptime SLA commitments.
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.0-alpha.7.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.0-alpha.7.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.0-alpha.7.linux-arm64.tgz (Experimental) (SHA256) | cockroach-sql-v23.2.0-alpha.7.linux-arm64.tgz (Experimental) (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.0-alpha.7.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.0-alpha.7.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.0-alpha.7.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.0-alpha.7.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.0-alpha.7.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.0-alpha.7.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image:
- The ARM image is Experimental and not yet qualified for production use and not eligible for support or uptime SLA commitments.
- The Intel image is Generally Available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach-unstable:v23.2.0-alpha.7
Source tag
To view or download the source code for CockroachDB v23.2.0-alpha.7 on Github, visit v23.2.0-alpha.7 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.0-alpha.6...v23.2.0-alpha.7
SQL language changes
- Previously, if session variable use_declarative_schema_changerwas set tooff, thenALTER TABLE ... ALTER COLUMN ... SET NOT NULLwas run on a column which contained a NULL value, an error with code23514(check_violation) would be returned. Now in this scenario the error returned will have code 23502 (not_null_violation) to match PostgreSQL. #113970
- The sql.txn.read_committed_syntax.enabledcluster setting was renamed tosql.txn.read_committed_isolation.enabled. #113833
Command-line changes
- The cockroach connectfunctionality has been deprecated. #114241
DB Console changes
- Previously, the forward arrow button on the time selector would not move the time window forward if the current end time was less than "Now() - time window". For example, with a 10 minute time window, it was not possible to move forward if current end time is less that "Now() - 10 minutes". This caused the forward arrow button to become disabled even though there was more data to display. Now this scenario is handled by the forward arrow button selecting the latest available time window (similar to the Now button). #113907
Bug fixes
- Removed duplication of metrics names on DB Console Metrics charts' tooltips. #113728
- Fixed a bug that could cause ALTER DATABASE ... ADD/DROP REGION to hang if node localities were changed after regions were added. #114102
- A bug in the log configuration code prevented users from setting the datetime-formatanddatetime-timezonelog format options (set via theformat-optionsstructure) within their log configuration. Specifically, when users tried to use these options infile-defaultswith anyjsontype log format, the log configuration was previously unable to be parsed due to validation errors. This was because thefile-defaults.format-optionswere propagated to thesinks.stderr.format-options.sinks.stderronly supports a format ofcrdb-v2-tty. Therefore, the incorrectly propagatedformat-options, which are only supported by thejsonlog format, were identified as not being supported when validatingsinks.stderr. This bug is now fixed and thefile-defaults.format-optionsare only propagated tosinks.stderr.format-optionsif both of these conditions are true: 1.file-defaults.formatis one ofcrdb-v2orcrdb-v2-tty. 2.sinks.stderr.format-optionsare not explicitly set in the log configuration. #113684
- Previously, when executing queries with index joins or lookup joins or both when the ordering needs to be maintained, CockroachDB in some cases would get into a pathological behavior which would lead to increased query latency, possibly by one or two orders of magnitude. This bug was introduced in v22.2 and is now fixed. #114117
- Previously, the SHOW STATISTICS command incorrectly required the user to have the admin role. Now, it correctly only requires the user to have any privilege on the table being inspected. #114449
- Fixed a bug that could cause a query plan to skip scanning rows from the local region when performing a lookup join with a REGIONAL BY ROWtable as the input. #114458
Performance improvements
- This change prevents failed requests from being issued on follower nodes that are draining, decommissioning or unhealthy which prevents latency spikes if those nodes later go offline. #114259
Contributors
This release includes 95 merged PRs by 33 authors.
v23.2.0-alpha.6
Release Date: November 7, 2023
Downloads
CockroachDB v23.2.0-alpha.6 is a testing release. Testing releases are intended for testing and experimentation only, and are not qualified for production environments and not eligible for support or uptime SLA commitments.
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.0-alpha.6.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.0-alpha.6.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.0-alpha.6.linux-arm64.tgz (Experimental) (SHA256) | cockroach-sql-v23.2.0-alpha.6.linux-arm64.tgz (Experimental) (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.0-alpha.6.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.0-alpha.6.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.0-alpha.6.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.0-alpha.6.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.0-alpha.6.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.0-alpha.6.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image:
- The ARM image is Experimental and not yet qualified for production use and not eligible for support or uptime SLA commitments.
- The Intel image is Generally Available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach-unstable:v23.2.0-alpha.6
Source tag
To view or download the source code for CockroachDB v23.2.0-alpha.6 on Github, visit v23.2.0-alpha.6 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.0-alpha.5...v23.2.0-alpha.6
General changes
- The CockroachDB Docker image is now based on Red Hat's ubi9/ubi-minimal image instead of the ubi8/ubi-minimal image. #112967
SQL language changes
- Added the built-in function jsonb_array_to_string_arraythat convertsJSONBarray toSTRINGarray. #112865
- The built-in function jsonb_array_to_string_arraycan now returnNULLobjects. #112865
Operational changes
- Introduced the cluster setting kv.gc.sticky_hint.enabledthat helps expediting garbage collection after range deletions. For example, when a SQL table or index is dropped.kv.gc.sticky_hint.enabledis enabled by default in v23.2. The setting has been deprecated in v23.2. #113040
- Introduced a new environment variable that allows an operator to configure the compaction concurrency. #113313
- Debug zip will now collect the active traces of all running or reverting traceable jobs. This includes restores, imports, backups, and physical cluster replication. #113172
Cluster virtualization
- The privilege that controls access to CREATE VIRTUAL CLUSTERand other virtual cluster management syntax is now calledMANAGEVIRTUALCLUSTER. #113076
Bug fixes
- Fixed a bug that could prevent RESTOREfrom working if it was performed during a cluster upgrade. #112759
- Fixed a bug where the opclass for a trigram index is not shown if CockroachDB creates a trigram index and later displays it via SHOW CREATE TABLE. #113071
- Fixed a bug where CockroachDB could incorrectly evaluate lookup and index joins into tables with at least three column families. This would result in either the non-nullable column with no valueinternal error, or the query would return incorrect results. This bug was introduced in v22.2. #113105
- Fixed a bug where ALTER PRIMARY KEYwould incorrectly disable secondary indexes while new secondary indexes were being backfilled when using the declarative schema changer. #112627
- Fixed a bug where the unique_constraint_catalogandunique_constraint_schemacolumns ininformation_schema.referential_constraintscould be incorrect for cross schema or cross database references. #112739
- Fixed a bug in a method that was used by some of the jobs observability infrastructure. This method could be triggered if a file was overwritten with a different chunking strategy. #113290
- Fixed a bug where the result of SHOW CREATE TABLEfor a table that had a collated string column with a default expression was incorrect because the statement could not be parsed. #113119
- Fixed the SQL activity update job to: avoid conflicts on update, reduce the amount of data cached to only what the overview page requires, and fix the correctness of the top queries. #112865
- Fixed a bug that could prevent physical cluster replication from advancing in the face of some range deletion operations. #113041
- Fixed a bug where ALTER TYPEcould get stuck ifDROP TYPEwas executed concurrently. #113644
- Fixed a bug that could cause internal errors or panics while attempting to forecast statistics on a numeric column. #113797
- Rolled back deletes no longer cause a discrepancy between computed statistics and the actual stored values. #113766
Performance improvements
- Addressed a performance regression that can happen when the declarative schema changer is used to create an index with a concurrent workload. #113725
Contributors
This release includes 117 merged PRs by 49 authors.
v23.2.0-alpha.5
Release Date: October 30, 2023
Downloads
CockroachDB v23.2.0-alpha.5 is a testing release. Testing releases are intended for testing and experimentation only, and are not qualified for production environments and not eligible for support or uptime SLA commitments.
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.0-alpha.5.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.0-alpha.5.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.0-alpha.5.linux-arm64.tgz (Experimental) (SHA256) | cockroach-sql-v23.2.0-alpha.5.linux-arm64.tgz (Experimental) (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.0-alpha.5.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.0-alpha.5.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.0-alpha.5.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.0-alpha.5.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.0-alpha.5.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.0-alpha.5.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image:
- The ARM image is Experimental and not yet qualified for production use and not eligible for support or uptime SLA commitments.
- The Intel image is Generally Available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach-unstable:v23.2.0-alpha.5
Source tag
To view or download the source code for CockroachDB v23.2.0-alpha.5 on Github, visit v23.2.0-alpha.5 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.0-alpha.4...v23.2.0-alpha.5
SQL language changes
- Added support for the special OTHERScondition in PL/pgSQL exception blocks, which allows matching any error code apart fromquery_canceledandassert_failure. Note that Class 40 errors (40000,40001,40003,40002, and40P01) cannot be caught either. This is tracked in #111446. #112817
Bug fixes
- Previously, queries with the ST_Unionaggregate function could produce incorrect results in some cases due to the query optimizer performing invalid optimizations. This is now fixed. This bug had been present since theST_Unionfunction was introduced in v20.2.0. #112780
Contributors
This release includes 27 merged PRs by 17 authors.
v23.2.0-alpha.4
Release Date: October 23, 2023
Downloads
CockroachDB v23.2.0-alpha.4 is a testing release. Testing releases are intended for testing and experimentation only, and are not qualified for production environments and not eligible for support or uptime SLA commitments.
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.0-alpha.4.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.0-alpha.4.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.0-alpha.4.linux-arm64.tgz (Experimental) (SHA256) | cockroach-sql-v23.2.0-alpha.4.linux-arm64.tgz (Experimental) (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.0-alpha.4.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.0-alpha.4.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.0-alpha.4.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.0-alpha.4.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.0-alpha.4.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.0-alpha.4.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image:
- The ARM image is Experimental and not yet qualified for production use and not eligible for support or uptime SLA commitments.
- The Intel image is Generally Available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach-unstable:v23.2.0-alpha.4
Source tag
To view or download the source code for CockroachDB v23.2.0-alpha.4 on Github, visit v23.2.0-alpha.4 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.0-alpha.3...v23.2.0-alpha.4
General changes
- Updated the licenses/CCT.txtfile to reflect the latest Cockroachdb Community License. #112494
Enterprise edition changes
- Renamed cluster settings related to physical cluster replication for consistency. For example, bulkio.stream_ingestion.minimum_flush_intervalis nowphysical_replication.consumer.minimum_flush_interval. #111197
SQL language changes
- SHOW SCHEDULEShas two columns that surface the schedule options. These columns have been renamed to align with the documented option names:- on_previous_runningand- on_execution_failure. #111759
- Added support for the PLpgSQL CLOSEstatement, which allows a PLpgSQL routine to close a cursor with the name specified by a cursor variable. #111330
- When a RESTOREwithremove_regionsis performed, the restore job will now fail if the object contains aREGIONAL BY ROWtable. #111443
- It is now possible to open a cursor within a PLpgSQL function or procedure with an exception block. If an error occurs, creation of the cursor is rolled back before control reaches the exception handler. #111735
- If a scheduled backup resumes on a new cluster (e.g., after physical cluster replication cutover or a cluster restore), the backup schedule will pause. The user may resume the schedule without changing it, but should take special care to ensure no other schedule is backing up to the same collection. The user may also want to cancel the paused schedule and start a new one. #111578
- Added support for PLpgSQL FETCHandMOVEstatements. Similar to SQLFETCH/MOVEstatements, commands that would seek the cursor backward will fail. In addition, expressions other than constant integers are not yet supported for thecountoption. #111318
- Added support for the REFCURSORdata type.REFCURSORis a special string type that is used to handle cursors. PLpgSQL cursor declarations are required to use a variable of typeREFCURSOR, and the name of a cursor can be passed to and from a PLpgSQL function or procedure. #111392
- Added two changes to - FOR UPDATE:- Multiple - FOR UPDATEclauses on fully parenthesized queries are now disallowed. For example, the following statements are now disallowed:- (SELECT 1 FOR UPDATE) FOR UPDATE; SELECT * FROM ((SELECT 1 FOR UPDATE) FOR UPDATE) AS x;- Whereas statements like the following are still allowed: - SELECT * FROM (SELECT 1 FOR UPDATE) AS x FOR UPDATE; SELECT (SELECT 1 FOR UPDATE) FOR UPDATE;- This does not match PostgreSQL, which allows all of these, but does match CockroachDB behavior for - ORDER BYand- LIMIT.
- FOR UPDATEis now allowed on statements with- VALUESin the- FROMlist, or as a subquery. For example, the following statements are now allowed:- SELECT (VALUES (1)) FOR UPDATE; SELECT * FROM (VALUES (1)) AS x FOR UPDATE;- Using - FOR UPDATEdirectly on- VALUESis still disallowed:- VALUES (1) FOR UPDATE; (VALUES (1)) FOR UPDATE; INSERT INTO t VALUES (1) FOR UPDATE;- This matches PostgreSQL. #111258 
 
- FOR UPDATEis now permitted on some queries that were previously disallowed. Queries that use the following operations are now allowed to have- FOR UPDATE OFas long as the prohibited operation is in a subquery not locked by the- FOR UPDATE OF:- UNION
- INTERSECT
- EXCEPT
- DISTINCT
- GROUP BY
- HAVING
- Aggregations
- Window functions
 - For example, the following query is now allowed because the subquery using the prohibited operations is not affected by the - FOR UPDATE OF:- SELECT * FROM t, (SELECT DISTINCT 0, 0 UNION SELECT a, count(*) FROM t GROUP BY a HAVING a > 0) AS u FOR UPDATE OF t;- This matches PostgreSQL. #111258 
- Identifiers after numeric constants that are not separated by whitespace are now disallowed to match PostgreSQL 15 behavior. #112021 
- Added the new column - contention_typeto the- crdb_internal.transaction_contention_eventstable. This column indicates the type of transaction contention encountered. Current values are- LOCK_WAITand- SERIALIZATION_CONFLICT. #111685
- Changed the error message: - statement error cannot execute FOR UPDATE in a read-only transactionto- statement error cannot execute SELECT FOR UPDATE in a read-only transactionto match PostgreSQL. #112138
- Added a new session variable - optimizer_use_lock_op_for_serializable, which when set enables a new implementation of- SELECT FOR UPDATE. This new implementation of- SELECT FOR UPDATEacquires row locks after any joins and filtering, and always acquires row locks on the primary index of the table being locked. This more closely matches- SELECT FOR UPDATEbehavior in PostgreSQL, but at the cost of more round trips from gateway node to replica leaseholder. Under read-committed isolation (and other isolation levels weaker than serializable), CockroachDB will always use this new implementation of- SELECT FOR UPDATEregardless of the value of- optimizer_use_lock_op_for_serializableto ensure correctness. #112138
Operational changes
- Added a new cluster setting server.http.base_paththat controls the redirection of the browser after successful login with OIDC SSO. It is unlikely that this setting would need adjustment. However, it is helpful in cases where CockroachDB is running behind a load balancer or proxy that serves CockroachDB under a subpath, such ashttps:// <hostname>/crdb/. In those cases, it is necessary for the browser to redirect to/ crdbafter login instead of/, which has always been the hard-coded default. #111283
Cluster virtualization
- The following settings can now only be set from the system virtual cluster: - All the physical_replication.*settings
- server.rangelog.ttl
- timeseries.storage.*
 
- All the 
- The cluster settings - cluster.organizationand- enterprise.licensecan now only be set via the system virtual cluster. Attempting to set them from any other virtual cluster results in an error. #111788
- A new flag - --internal-rpc-port-rangeallows operators to specify the port range used by virtual clusters for node-to-node communication. Users implementing physical cluster replication or cluster virtualization public preview features should use this flag if they require the- cockroachprocesses to only communicate using ports in a known port range. #111798
- Two guardrails are available to system operators to help with users upgrading from a deployment without cluster virtualization enabled to a deployment using cluster virtualization. This is intended to help in cases where the user is not connected to the correct SQL interface to perform certain configuration operations. There are two guardrails included: - The - sql.restrict_system_interface.enabledcluster setting encourages users to use a virtual cluster for their application workload. When set, certain common operations that end users may execute to set up an application workload are disallowed, such as running DDL statements or modifying an application level cluster setting. Users will receive an error similar to:- ERROR: blocked DDL from the system interface SQLSTATE: 42501 HINT: Object creation blocked via sql.restrict_system_interface.enabled to prevent likely user errors. Try running the DDL from a virtual cluster instead.
- The - sql.error_tip_system_interface.enabledcluster setting enhances errors reported when a user mistakenly uses a storage-level SQL feature within any virtual cluster besides the system virtual cluster. For example, when attempting to modify a cluster setting that was previously at the application level, an error like the following occurs:- NOTICE: ignoring attempt to modify "kv.rangefeed.enabled" HINT: The setting is only modifiable by the operator. Normally, an error would be reported, but the operation is silently accepted here as configured by "sql.error_tip_system_interface.enabled".
- For a cluster setting that was always system-level, an error like the following occurs: - ERROR: cannot modify storage-level setting from virtual cluster SQLSTATE: 42501 HINT: Connect to the system interface and modify the cluster setting from there.
 
- The predefined config profiles related to cluster virtualization now automatically set the new cluster settings - sql.restrict_system_interface.enabledand- sql.error_tip_system_interface.enabled. #111568
- The hidden - --secondary-tenant-port-offsetoption has been removed. Users who were previously using this option should use- --internal-rpc-port-rangeinstead. #112050
- Added support for automatic finalization of a virtual cluster's version upgrade. A new setting - cluster.auto_upgrade.enabledwas added to enable and disable automatic cluster version upgrade (finalization). It will be used in automatic upgrade of both the storage cluster and its virtual clusters. #102427
Command-line changes
- cockroach debug ziphas an additional flag that is default off- include-running-job-tracesthat will enable collecting the in-flight traces of traceable jobs, such as backup, restore, import, physical cluster replication and dump them in a- jobs/subdirectory in the zip. #112644
DB Console changes
- The Jobs table will now correctly display timestamps for creation, last modified, and the completed time fields. #110366
- The transaction insight details will show the following details when CockroachDB has information on a transaction execution with a 40001error code and it has captured the conflicting transaction meta details (only available if the transaction had not yet committed at the time of execution). A section calledFailed Executionwill appear when this information is available and it will contain:- Blocking transaction execution ID
- Blocking transaction fingerprint ID
- Conflict location
- Database, table, and index names #111873
 
- Added progressive loading functionality to the Databases page. #110901
Bug fixes
- Fixed a bug in physical cluster replication where the primary cluster would not be able to take backups when a primary cluster node was unavailable. #111337
- Fixed a bug in transaction insight details where it was possible to see the contention details of other transactions. Now, CockroachDB will only surface contention details for the current transaction. #111867
- Voter constraints will now be satisfied by promoting existing non-voters. Previously, there was a bug where voter constraints were never satisfied due to all existing replicas being considered necessary to satisfy a replica constraint. #111609
- Fixed a bug where indoptioninsidepg_indexwas not properly encoded causing clients to be unable to decode it asint2vector. #111911
- This patch fixes an issue where the optimizer fails to honor the statement_timeoutsession setting when generating constrained index scans for queries with largeINlists or= ANYpredicates on multiple index key columns, which may lead to an out of memory condition on the node. #111979
- This patch fixes a performance issue in join queries with a LIMITclause, where the optimizer may fail to push aWHEREclause filter into a join due to how theLIMIToperation is internally rewritten. This causes a full scan of the table referenced in the filter. #110593
- Fixed a bug that caused internal errors during query optimization in rare cases. The bug has been present since version v2.1.11, but it is more likely to occur in version v21.2.0 and later, though it is still rare. The bug only presents when a query contains minandmaxaggregate functions. #112255
Performance improvements
- This patch adds support for insert fast-path uniqueness checks on REGIONAL BY ROWtables where the source is aVALUESclause with a single row. This results in a reduction in latency for single-row inserts toREGIONAL BY ROWtables and hash-shardedREGIONAL BY ROWtables with unique indexes. #111822
Contributors
This release includes 213 merged PRs by 51 authors. We would like to thank the following contributors from the CockroachDB community:
- Finn Mattis (first-time contributor)
- craig
v23.2.0-alpha.3
Release Date: October 10, 2023
Downloads
CockroachDB v23.2.0-alpha.3 is a testing release. Testing releases are intended for testing and experimentation only, and are not qualified for production environments and not eligible for support or uptime SLA commitments.
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.0-alpha.3.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.0-alpha.3.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.0-alpha.3.linux-arm64.tgz (Experimental) (SHA256) | cockroach-sql-v23.2.0-alpha.3.linux-arm64.tgz (Experimental) (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.0-alpha.3.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.0-alpha.3.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.0-alpha.3.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.0-alpha.3.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.0-alpha.3.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.0-alpha.3.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image:
- The ARM image is Experimental and not yet qualified for production use and not eligible for support or uptime SLA commitments.
- The Intel image is Generally Available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach-unstable:v23.2.0-alpha.3
Source tag
To view or download the source code for CockroachDB v23.2.0-alpha.3 on Github, visit v23.2.0-alpha.3 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.0-alpha.2...v23.2.0-alpha.3
Backward-incompatible changes
- The direct export of traces to Jaeger and the cluster setting - trace.jaeger.agenthave been removed. The direct export functionality had been obsoleted since 2022; it stopped working altogether sometime in 2023 with the following error:- data does not fit within one UDP packet; size 65006, max 65000, spans NN. Since 2022, Jaeger supports ingestion of traces using OTLP; and CockroachDB has supported emitting traces using OTLP since v22.1. Operators and developers who want to inspect traces are thus invited to use the OTLP protocol instead. The corresponding cluster setting is- trace.opentelemetry.collector. For a successful deployment, an intermediate OTLP collector/forwarder should be configured.- You can orchestrate the OpenTeletry collector and Jaeger together using Docker Compose by adapting the following example:
 - otel-collector: image: otel/opentelemetry-collector-contrib container_name: otel-collector volumes: - ./otel-collector-config.yaml:/etc/otelcol-contrib/config.yaml ports: - 1888:1888 # pprof extension - 8888:8888 # Prometheus metrics exposed by the collector - 8889:8889 # Prometheus exporter metrics - 13133:13133 # health_check extension - 4317:4317 # OTLP gRPC receiver - 4318:4318 # OTLP http receiver - 55679:55679 # zpages extension jaeger: image: jaegertracing/all-in-one container_name: jaeger ports: - "16685:16685" - "16686:16686" - "14250:14250" - "14268:14268" - "14269:14269" - "6831:6831/udp" environment: - COLLECTOR_ZIPKIN_HTTP_PORT=9411 - COLLECTOR_OTLP_ENABLED=true- To configure the otel-collector, you can adapt this example:
 - receivers: otlp: # the OTLP receiver the app is sending traces to protocols: grpc: http: processors: batch: exporters: otlp/jaeger: # Jaeger supports OTLP directly endpoint: http://jaeger:4317 tls: insecure: true service: pipelines: traces/dev: receivers: [otlp] processors: [batch] exporters: [otlp/jaeger]
To use this configuration, unset Jaeger via SET CLUSTER SETTING trace.jaeger.agent='', and then set the OTLP collector using SET CLUSTER SETTING trace.opentelemetry.collector='localhost:4317'.
Enterprise edition changes
- Changefeeds now support the confluent-cloud://sink scheme. This scheme can be used to connect to Kafka hosted on Confluent Cloud. The scheme functions identically to Kafka, but it has it's own authentication parameters. Namely, it requiresapi_keyandapi_secretto be passed as parameters in the sink URI. They must be URL encoded. An example URI is:'confluent-cloud://pkc-lzvrd.us-west4.gcp.confluent.cloud:9092?api_key=<KEY>&api_secret=<SECRET>'. By default, the optionstls_enabled=true,sasl_handshake=true,sasl_enabled=true, andsasl_mechanism=PLAINare applied. For more information about authenticating with Confluent Cloud, see https://docs.confluent.io/platform/current/security/security_tutorial.html#overview. The sink scheme still supports non-authentication parameters such astopic_nameandtopic_prefix. It also supports the standard Kafka changefeed options (ex.kafka_sink_config). #111368
SQL language changes
- The RESTOREoptionstrip_localities, which was added in #110606, has been renamed toremove_regions. This option will lead to a "region-less restore"; it is used to strip the locality and region information from a backup when there are mismatched cluster regions between the backup's cluster and the target cluster. Note that a restore using this option will fail if the backup's cluster hadREGIONAL BY ROWtable localities. This is because theRESTOREstatement has a contract that all tables must be available to serve writes once it finishes. #111356
- Added initial support for executing the PLpgSQL OPENstatement, which allows a PLpgSQL routine to create a cursor. Currently, opening bound or unnamed cursors is not supported. In addition,OPENstatements cannot be used in a routine with an exception block. #110709
- Added support for declaring bound cursors, which associate a query with a cursor in a PLpgSQL routine before it is opened. #111092
- The SELECT FOR SHAREandSELECT FOR KEY SHAREstatements previously did not acquire any locks. Users issuing these statements would expect them to acquire shared locks (multiple readers allowed, but no writers). This patch switches over the behavior to acquire such read locks when the user has selected theREAD COMMITTEDisolation level. For serializable transactions, we default to the previous behavior, unless theenable_shared_locking_for_serializablesession setting is set totrue. #109638
- When a PLpgSQL exception handler catches an error, it now rolls back any changes to database state that occurred within the block. Exception blocks are not currently permitted to catch 40001and40003errors. #110998
- Added support for unnamed PLpgSQL cursors, which generate a unique name when no cursor name was specified. #111329
- Fixed a bug that caused CockroachDB to stop collecting new statistics about Statement fingerprints and Transaction fingerprints. #111613
- Make the max_event_frequencymetric visible for public documentation and usage. This is the maximum event frequency at which we sample executions for telemetry. #111594
Operational changes
- Added the following metrics for Raft proposals and reproposals: raft.commands.proposed,raft.commands.reproposed.unchanged, andraft.commands.reproposed.new-lai. #111272
- Removed the cluster setting spanconfig.store.enabledand the ability to use theCOCKROACH_DISABLE_SPAN_CONFIGSenvironment variable. #110253
- Renamed the metric fluent.sink.conn.errorstolog.fluent.sink.conn.errors. The addition of thelog.prefix was to better group together logging-related metrics. The behavior and purpose of the metric remains unchanged. #111126
- Set the Metric Type metadata on the metric log.fluent.sink.conn.errors. Previously, the Metric Type was incorrectly left unset. Note that this is an update to the metric's metadata; the behavior and purpose of the metric remains unchanged. #111126
- Added a new metric log.buffered.messages.dropped. Buffered network logging sinks have amax-buffer-sizeattribute, which determines, in bytes, how many log messages can be buffered. Anyfluent-serverorhttp-serverlog sink that makes use of abufferingattribute in its configuration (enabled by default) qualifies as a buffered network logging sink. If this buffer becomes full, and an additional log message is sent to the buffered log sink, the buffer would exceed thismax-buffer-size. Therefore, the buffered log sink drops older messages in the buffer to handle, in order to make room for the new.log.buffered.messages.droppedcounts the number of messages dropped from the buffer. Note that the count is shared across all buffered logging sinks. #111126
- Added the metric log.messages.count. This metric measures the count of messages logged on the node since startup. Note that this does not measure the fan-out of single log messages to the various configured logging sinks. This metric can be helpful in understanding log rates and volumes. #111126
- Added the file-based-headersfield found in thehttp-defaultssection of the log config, which accepts 'key-filepath' pairs. This allows values found at filepaths to be updated without restarting the cluster by sendingSIGHUPto notify that values need to be refreshed. #111235
- Added the cluster setting kv.snapshot.ingest_as_write_threshold, which controls the size threshold below which snapshots are converted to regular writes. It defaults to100KiB. #110943
Cluster virtualization
- The name of the virtual cluster that the SQL client is connected to can now be inspected via the SQL session variable virtual_cluster_name. #111565
Command-line changes
- The following cluster settings have been renamed; the previous names remain available for backward-compatibility. #109415 - Previous name - New Name - server.shutdown.drain_wait- server.shutdown.initial_wait- server.shutdown.lease_transfer_wait- server.shutdown.lease_transfer_iteration.timeout- server.shutdown.query_wait- server.shutdown.transactions.timeout- server.shutdown.connection_wait- server.shutdown.connections.timeout- server.shutdown.jobs_wait- server.shutdown.jobs.timeout
DB Console changes
- Fixed an error on the SQL Activity page when there was a workload, and then the workload stopped so that no queries ran against the database in the last hour. #111420
- On the Metrics page, now the information about which metric is used to create each chart is available on the chart's tooltip. #111469
Bug fixes
- Fixed the error message that is returned when the user attempts to drop an ENUMvalue that is used at least twice in anARRAYcolumn. #111354
- Added a check for values before using meanon the Plan Details page, fixing a crash. #111472
- Fixed the metric name for Schema Registry Registrationson the Metrics page. #111469
- Fixed a panic that could occur if a query used a string larger than 2^31-1 bytes. This was triggered by attempting to import a 2.7 GiB CSV file. #111627
- Fixed a bug where atttypmodinpg_attributewas not populated forTIMESTAMP/INTERVALtypes, which meant that ORMs could not know the precision of these types properly. #111400
Contributors
This release includes 130 merged PRs by 43 authors.
v23.2.0-alpha.2
Release Date: October 2, 2023
Downloads
CockroachDB v23.2.0-alpha.2 is a testing release. Testing releases are intended for testing and experimentation only, and are not qualified for production environments and not eligible for support or uptime SLA commitments.
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.0-alpha.2.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.0-alpha.2.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.0-alpha.2.linux-arm64.tgz (Experimental) (SHA256) | cockroach-sql-v23.2.0-alpha.2.linux-arm64.tgz (Experimental) (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.0-alpha.2.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.0-alpha.2.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.0-alpha.2.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.0-alpha.2.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.0-alpha.2.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.0-alpha.2.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image:
- The ARM image is Experimental and not yet qualified for production use and not eligible for support or uptime SLA commitments.
- The Intel image is Generally Available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach-unstable:v23.2.0-alpha.2
Source tag
To view or download the source code for CockroachDB v23.2.0-alpha.2 on Github, visit v23.2.0-alpha.2 source tag.
Changelog
View a detailed changelog on GitHub: v23.2.0-alpha.1...v23.2.0-alpha.2
Security updates
- The SIGHUPsignal now clears the cached expiration times for client certificates that are reported by thesecurity.certificate.expiration.clientmetric. #110726
General changes
- Increased the maximum permitted value of the COCKROACH_RPC_INITIAL_WINDOW_SIZEenvironment variable to 64MB. In conjunction with tuning your operating system's maximum TCP window size, this can increase the throughput that Raft replication can sustain over high latency network links. #111255
SQL language changes
- The discardlog message is now limited to once per minute by default. The message now includes both the number of transactions and the number of statements that were discarded. #110805
- The cluster setting kv.rangefeed.enabledno longer controls access toRANGEFEED SQLcommands. Instead, usefeature.changefeed.enabled. #110676
- SQL commands that were previously limited to the adminsystem privilege can now be used by users with theVIEWCLUSTERMETADATAorREPAIRCLUSTERMETADATAsystem privilege, depending on whether the operation is read-only or modifies state. #110084
- Added a last_errorcolumn to thecluster_execution_insights,node_execution_insights,cluster_txn_execution_insights, andnode_txn_execution_insightstables. These columns contain error messages for failed executions. #110565
- The new backup option updates_cluster_monitoring_metricstracks the timestamp of the last backup failure due to a KMS error. This option is disabled by default. #104634
- The new restore option strip_localitiesoptionally strips the locality information from a backup when restoring to a cluster with different regions than the source cluster.
Restoring a cluster or database that contains regional-by-row tables, or restoring a regional-by-row table, requires you to modify the database:
- To restore a cluster with regional-by-row tables, you must drop the zone config of the database, then drop the type d.public.crdb_internal_region.
- To restore a database that contains regional-by-row tables, or to restore a regional-by-row table, you must drop the type d.public.crdb_internal_region.
- You must alter the crdb_regioncolumn to set the default region for newly-written rows.
- You must discard the previous zone config, which contains outdated information, such as that related to the partitions and constraints after the restore. This column specifies each row's home region and is a prefix to the table's primary key. Stripping localities does not modify this column, because it would require the entire table to be written.
This change is part of a larger effort, and this feature is subject to change.
- Added a check to disallow queries that use predicate locking, since explicit uniqueness checks are not yet supported under Read Committed isolation. INSERT,UPDATE, andUPSERTstatements against someREGIONAL BY ROWtables will fail under Read Committed isolation with the following error:
  unimplemented: explicit unique checks are not yet supported under read committed isolation SQLSTATE: 0A000
For more details about which REGIONAL BY ROW tables are affected, refer to Issue #110873.
#110879
- The created field produced by SHOW STATISTICS has been updated from TIMESTAMP to TIMESTAMPTZ. Statistic creation times are now displayed in the session time zone if it is set. #110753
Operational changes
- Removed the node-level engine.stallstimeseries metric. This metric has not been updated for several releases. #110936
DB Console changes
- The legend is now always displayed on charts in DB Console Metrics pages. In addition, when you select an item from the legend that represents a single line in the chart, that line is selected in the chart. #110809
- When collecting a statement bundle, you can now filter by a specific plan gist or collect diagnostics for all plan gists. #110931
- Statement and Transaction detail pages now include an Error Message row. Users with the VIEWACTIVITYsystem privilege can view the full error message, and users with theVIEWACTIVTYREDACTEDsystem privilege can view the redacted error message. If a user has both privileges,VIEWACTIVITYTREDACTED` takes precedence. #110849
- A new dashboard in the SQL Dashboard page tracks how often distributed queries with errors were rerun using the "rerun as local" mechanism, as well as how often those reruns failed. the number of times distributed queries that resulted in errors were rerun as local as well as when those reruns failed. The "rerun as local" mechanism is new in v23.2 and is enabled by default. For more information, contact your Cockroach Labs account representative. #110619
- The DB Console Insights page now shows the error message when a transaction fails at the COMMITstage. #110898
- The Overload Dashboard page now includes the following graphs to monitor admission control:
- IO Overload - Charts normalized metric based on admission control target thresholds. Replaces LSM L0 Health graph which used raw metrics.
- KV Admission Slots Exhausted - Replaces KV Admission Slots graph.
- Flow Tokens Wait Time: 75th percentile - Use to monitor the new replication admission control feature.
- Requests Waiting For Flow Tokens - Use to monitor the new replication admission control feature.
- Blocked Replication Streams - Use to monitor the new replication admission control feature. #110135
 
Bug fixes
- Fixed a race condition in the Replica lifecycle that could result in a failed SQL request when the request could have been successfully retried. #110806
- Fixed a bug where a CREATE TABLEcommand with anIDENTITYcolumn did not properly propagate the type of the column into the sequence. #110621
- Fixed a panic when decoding a gist in a foreign database that does not contain a table referred to by the gist. #110966
- A synthetic droppedcolumn have been added to thepg_attributetable. This column tracks the attribution numbers for dropped attributions, to work around issues with ORMs that are not designed to handle gaps in attribution numbering in thepg_attributetable. #111019
- Fixed a rare internal error in the unnestandinformation_schema._pg_expandarraybuilt-in functions where passed string arguments could be cast to an array. #110956
- External connection URLs now accept the scheme azure-blobfor connections to Azure Blob Storage and the schemeazure-kmsfor connections to Azure KMS. For backward compatibility, schemesazureandazure-storageschemes continue to work for connections to Azure Blob Storage. #111217
- Fixed a bug where vectorized COPY FROMcould produce a plan with more than one RenderNodes, when only zero or one should be allowed. This could result in multiple render nodes in a table with a hash sharded primary key. #111284
- Fixed a bug in DB Console's Statement Diagnostic page that could cause the page to crash if the response was larger than 50 KB. The page now keeps pulling results until no maximum size errors are encountered. #111128
- Fixed a bug where DB Console instances proxied at different subpaths that use OIDC pointed to an incorrect relative OIDC login path. #111240
- Fixed a bug where changing the setting server.telemetry.hot_ranges_stats.intervalhad no effect. #111305
Performance improvements
- Fixed a performance bug that could result in rewriting a 128-MB file each time a store file is created, renamed, or removed when Encryption At Rest is enabled on a large store with many small files. #111069
- Improved compaction heuristics to mitigate read amplification growth and admission control throttling when processing large deletes, such as during node decommissioning, replica rebalancing, or when dropping tables. #111277
Contributors
This release includes 157 merged PRs by 54 authors.
v23.2.0-alpha.1
Release Date: September 26, 2023
Downloads
CockroachDB v23.2.0-alpha.1 is a testing release. Testing releases are intended for testing and experimentation only, and are not qualified for production environments and not eligible for support or uptime SLA commitments.
Experimental downloads are not qualified for production use and not eligible for support or uptime SLA commitments, whether they are for testing releases or production releases.
| Operating System | Architecture | Full executable | SQL-only executable | 
|---|---|---|---|
| Linux | Intel | cockroach-v23.2.0-alpha.1.linux-amd64.tgz (SHA256) | cockroach-sql-v23.2.0-alpha.1.linux-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.0-alpha.1.linux-arm64.tgz (Experimental) (SHA256) | cockroach-sql-v23.2.0-alpha.1.linux-arm64.tgz (Experimental) (SHA256) | |
| Mac (Experimental) | Intel | cockroach-v23.2.0-alpha.1.darwin-10.9-amd64.tgz (SHA256) | cockroach-sql-v23.2.0-alpha.1.darwin-10.9-amd64.tgz (SHA256) | 
| ARM | cockroach-v23.2.0-alpha.1.darwin-11.0-arm64.tgz (SHA256) | cockroach-sql-v23.2.0-alpha.1.darwin-11.0-arm64.tgz (SHA256) | |
| Windows (Experimental) | Intel | cockroach-v23.2.0-alpha.1.windows-6.2-amd64.zip (SHA256) | cockroach-sql-v23.2.0-alpha.1.windows-6.2-amd64.zip (SHA256) | 
Docker image
Multi-platform images include support for both Intel and ARM. Multi-platform images do not take up additional space on your Docker host.
Within the multi-platform image:
- The ARM image is Experimental and not yet qualified for production use and not eligible for support or uptime SLA commitments.
- The Intel image is Generally Available for production use.
To download the Docker image:
docker pull cockroachdb/cockroach-unstable:v23.2.0-alpha.1
Source tag
To view or download the source code for CockroachDB v23.2.0-alpha.1 on Github, visit v23.2.0-alpha.1 source tag.
Backward-incompatible changes
- The pre-v23.1 output produced by SHOW RANGES,crdb_internal.ranges, andcrdb_internal.ranges_no_leaseswas deprecated in 23.1 and is now replaced by default with output that's compatible with coalesced ranges (i.e., ranges that pack multiple tables/indexes/partitions into individual ranges). See the v23.1 release notes forSHOW RANGESfor more details. #102961
- When a deployment is configured to use a time zone (new feature) for log file output using formats crdb-v1orcrdb-v2, it becomes impossible to process the new output log files using thecockroach debug merge-logscommand from a previous version. The newestcockroach debug merge-logscode must be used instead. #104265
- When customizing the SQL shell's interactive prompt, the special sequence %Mnow expands to the full host name instead of the combination of host name and port number. To include the port number explicitly, use%>. The special sequence%mnow expands to the host name up to the first period. #105137
- The cockroach debug zipcommand stores data retrieved from SQL tables in the remote cluster using the TSV format by default. #107474
- The changefeed.protect_timestamp.max_agecluster setting will only apply to newly created changefeeds in v23.2. For existing changefeeds, you can set theprotect_data_from_gc_on_pauseoption so that changefeeds do not experience infinite retries and accumulate protected change data. You can use theALTER CHANGEFEEDstatement to addprotect_data_from_gc_on_pauseto existing changefeeds. #103539
- The changefeed.new_pubsub_sink_enabledcluster setting is now enabled by default, which improves changefeed throughput. With this setting enabled, the top-level fields in JSON-encoded messages are capitalized:{Key: ..., Value: ..., Topic: ...}. After upgrading to CockroachDB v23.2, you may need to reconfigure downstream systems to parse the new message format. If you disable this setting, changefeeds emitting to Pub/Sub sinks with JSON-encoded events have the top-level message fields all lowercase:{key: ..., value: ..., topic: ...}.
Security updates
- Users who have the CREATEROLErole option can now grant and revoke role membership in any non-admin role. This change also removes thesql.auth.createrole_allows_grant_role_membership.enabledcluster setting, which was added in v23.1. In v23.2, the cluster setting is effectively always true. #104376
General changes
- You can now set Docker command arguments using the COCKROACH_ARGSenvironment variable. #98899
- Extended the /api/v2/nodesAPI endpoint with astoreMetricsfield. #98208
- CockroachDB would previously use separate ranges for each table, index, or partition. This is no longer true. It is possible now to have multiple tables, indexes, and partitions get packed into the same range. For users with many of these schema objects, this will reduce the total range count in their clusters. This is especially true if individual tables, indexes, or partitions are smaller than the default configured maximum range size (controlled using zone configs, specifically the range_max_bytesparameter). We made this change to improve scalability with respect to the number of schema objects, since the underlying range count is now no longer a bottleneck. Users upgrading from v22.2, when finalizing their upgrade, may observe a round of range merges and snapshot transfers (to power said range merges) as a result of this change. If users want to opt-out of this optimization, they can configure the following cluster setting:SET CLUSTER SETTING spanconfig.storage_coalesce_adjacent.enabled = false;#98820
- EXPORT INTO PARQUETwill now use a new internal implementation for writing Parquet files using the Parquet spec version 2.6. There should be no significant impact to the structure of files being written. There is one minor change: all columns written to Parquet files will be nullable (i.e., the Parquet repetition type is- OPTIONAL). #104234
- Spatial libraries for CockroachDB now rely on GEOS 3.11 instead of GEOS 3.8. #106642
- CockroachDB no longer distributes libgeosfor the experimental Windows build. Users can instead install GEOS directly from the source: https://libgeos.org/usage/download/. #106642
- The Formatting of byte figures in Pebble logs has been improved. Tools that parse these logs might need updating. #107392
- CockroachDB now has a new CLI option, --experimental-shared-storageto rebalance data faster from node to node. #105839
- Fixed a bug where, internally, if we print a 0 decimal with a very low exponent we use excessive memory. This is not possible when using the DECIMAL type, but may be possible when using crdb_internalfunctions. #110527
Enterprise edition changes
- The kafka_sink_configCompressionandRequiredAcksoptions are now case-insensitive. #100929
- Changefeeds emit significantly fewer duplicate messages during node and cluster restarts. #102717
- CockroachDB has a new changefeed.protect_timestamp.max_agesetting (by default 4 days), which will cancel running changefeed jobs if they fail to make forward progress for a period of time. This setting is used if the explicitgc_protect_expires_afteroption is not set. In addition, theprotect_data_from_gc_on_pauseoption has been deprecated. This option is no longer needed since changefeed jobs always protect data. #103539
- Changefeeds now officially support the Parquet format using specification version 2.6. It is only usable with the cloud storage sink. The syntax to use Parquet is: CREATE CHANGEFEED FOR foo INTO ... WITH format=parquet. It supports all standard changefeed options and features including CDC transformations, except it does not support thetopic_in_valueoption. #104528
- Changefeeds that create files over an HTTP connection may now be specified using INTO 'file-https://'to disambiguate withwebhook-https. #107572
- The pgcryptofunctionsencrypt,encrypt_iv,decrypt, anddecrypt_ivare now implemented. These functions require an enterprise license on a CCL distribution. #105654
- CockroachDB now paces the rangefeed goroutine creation rate to improve scheduler latency. This improves observability by adding an additional column in the crdb_internal.active_rangefeedtable to indicate if the range is currently in catchup scan mode. #109346
SQL language changes
- Fixed the helper message on UPDATE SQL statements to include the optional FROM cause. #98709
- CockroachDB now supports enabling forward indexes and ordering on JSON values. #99275
- Added a new column - visibilityto- crdb_internal.table_indexesand- information_schema.statistics. Also added a new column- visibilityto the output of following SQL statements:- SHOW INDEX FROM (table_name);- SHOW INDEXES FROM (table_name);- SHOW KEYS FROM (table_name);- SHOW INDEX FROM DATABASE (database_name);- SHOW INDEXES FROM DATABASE (database_name);- SHOW KEYS FROM DATABASE (database_name);- This new column contains a floating point number specifying the level of visibility of the index, from 0 (not visible) to 1 (fully visible). If the value is between 0 and 1, the index will be visible to the corresponding fraction of queries. #101334 
- ALTER INDEX ... VISIBILITY ...is now supported. It can change an index visibility to any visibility between 0.0 and 1.0. Visibility 0.0 means the index is not visible to the optimizer, while visibility 1.0 means the index is fully visible. A value in the range between 0.0 and 1.0 means the index will be visible to the corresponding fraction of queries. #87301
- CockroachDB now has support for non-aggregate expressions involving columns outside of the grouping columns when the grouping columns include all key columns of a unique index and those key columns are not nullable. #101675 
- CockroachDB now supports - CREATE INDEX ... VISIBILITY ...and- CREATE TABLE ... (... INDEX (...) VISIBILITY ...). This allows users to set the index visibility to any visibility between 0.0 and 1.0. Visibility 0.0 means the index is not visible to the optimizer, while visibility 1.0 means the index is fully visible. A value in the range between 0.0 and 1.0 means the index will be visible to the corresponding fraction of queries. #101812
- Row level TTL now supports - DESCorder primary key columns. #101869
- Added the - ST_BdPolyFromTextbuilt-in which copies the behavior of the PostGIS function. Takes in only a multilinestring geometry and returns a polygon. It will return an error if anything other than a multilinestring is input, and will return an error if internally a multipolygon is created for some reason.- NULLinputs also return- NULL. #102708
- SHOW SCHEDULESnow shows the schedule options with which the schedules were created.- SHOW SCHEDULES FOR BACKUPadditionally shows if the schedule is a full or incremental backup schedule. #102890
- You can no longer use - PREPAREwith- EXPLAIN ANALYZEstatements. Previously, this was allowed, but attempts to- EXECUTEthe prepared- EXPLAIN ANALYZEstatements would result in an error. #103259
- ttl_expiration_expressionnow allows stable operators and functions. This allows intervals to be directly added to- TIMESTAMPTZexpressions. See https://www.postgresql.org/docs/15/xfunc-volatility.html. #102974
- CockroachDB now allows - INSERTcommands in UDF statement bodies. #102773
- CockroachDB now allows - UPDATEand- UPSERTcommands in UDF statement bodies. #102773
- The - READ COMMITTEDisolation level is now supported. It can be used in the following ways:- When starting a transaction, use BEGIN ISOLATION LEVEL READ COMMITTED.
- After starting a transaction, but before performing reads or writes, use SET TRANSACTION ISOLATION READ COMMITTED.
- Configure it as the default isolation level using the default_transaction_isolationsession variable. To see the isolation level of the currently running transaction, use eitherSHOW TRANSACTION ISOLATION LEVELorSHOW transaction_isolation.
 
- When starting a transaction, use 
- Added version gates which require all nodes in a given cluster to have a minimum binary version number, which in turn is required for creating forward indexes on JSON columns and for ordering JSON columns. #101932 
- CockroachDB now allows - DELETEcommands in UDF statement bodies. #103531
- Added a new cluster setting - sql.auth.public_schema_create_privilege.enabledwhich controls whether users receive- CREATEprivileges on the public schema or not. The setting applies at the time that the public schema is created, which happens whenever a database is created. The setting is- trueby default. #103598
- EXPLAIN (DDL)statements now have descriptor, index, column, constraint, and other ID values decorated with names when available. There is now also a new- EXPLAIN (DDL, SHAPE)statement that provides information on costly operations planned by the declarative schema changer, like which index backfills and validations will get performed. #103930
- A new statistic - KV pairs readis now exposed on- EXPLAIN ANALYZEoutput in some cases (when this number is different from the- KV rows readstatistic or when the- VERBOSEoption is requested). This new statistic is also added to the telemetry sampled query events. #104079
- The - KV rows readstatistic in- EXPLAIN ANALYZEoutput has been renamed to- KV rows decodedto better reflect its meaning. #104079
- Table names are now allowed in - SELECTlists inside view and UDF definitions. #104929
- SHOW JOB WITH EXECUTION DETAILSfor a backup job will regenerate the DistSQL plan diagram with per-node and per-processor progress information. This will help users better understand the state of a running backup job. #103145
- The - crdb_internal.node_transactionsand- crdb_internal.cluster_transactionstables now have columns for- isolation_level,- priority, and- quality_of_service. #105009
- The - SHOW RANGEScommand will now emit span statistics when the- DETAILSoption is specified. The statistics are included in a new column named- span_stats, as a- JSONobject. The statistics are calculated for the identifier of each row.- SHOW RANGES WITH DETAILSwill compute span statistics for each range.- SHOW RANGES WITH TABLES, DETAILSwill compute span statistics for each table, and so on. The- span_stats- JSONobject has the following keys:- approximate_disk_bytes
- [key|val|sys|live|intent]_count
- [key|val|sys|live|intent]_bytes
 - approximate_disk_bytesis an approximation of the total on-disk size of the given object.- key_countis the number of meta keys tracked under- key_bytes.- key_bytesis the number of bytes stored in all non-system point keys, including live, meta, old, and deleted keys. Only meta keys really account for the "full" key; value keys only for the timestamp suffix.- val_countis the number of meta values tracked under- val_bytes.- val_bytesis the number of bytes in all non-system version values, including meta values.- sys_countis the number of meta keys tracked under- sys_bytes.- sys_bytesis the number of bytes stored in system-local key-value pairs. This tracks the same quantity as (- key_bytes+- val_bytes), but for system-local metadata keys (which aren't counted in either- key_bytesor- val_bytes).- live_countis the number of meta keys tracked under- live_bytes.- live_bytesis the number of bytes stored in keys and values which can in principle be read by means of a Scan or Get in the far future, including intents but not deletion tombstones (or their intents). Note that the size of the meta key-value pair (which could be explicit or implicit) is included in this. Only the meta key-value pair counts for the actual length of the encoded key (regular pairs only count the timestamp suffix).- intent_countis the number of keys tracked under- intent_bytes. It is equal to the number of meta keys in the system with a non-empty Transaction proto.- intent_bytesis the number of bytes in intent key-value pairs (without their meta keys).
- Introduced the - pg_lsndata type, which is used to store the- lsnassociated with replication. #105031
- Users now can issue one - ALTER TABLEstatement with a combination of any number of- ADD COLUMN, any number of- DROP COLUMN, one- ALTER PRIMARY KEY, and any number of- ADD CONSTRAINTclauses. For example, with this PR, we now support statements like:- CREATE TABLE t (i INT PRIMARY KEY, j INT NOT NULL, k INT NOT NULL); ALTER TABLE t ADD COLUMN p INT DEFAULT 30, ALTER PRIMARY KEY USING COLUMNS (j), DROP COLUMN k, ADD CHECK (i > 0);
- Added the ability to add numeric values to LSNs, or sub a decimal value from a LSN. #105326 
- Implemented the - pg_lsn - pg_lsn = decimalbuilt-in function, which subtracts 2 LSNs to return a decimal. #105326
- Added limited support for scalar PL/pgSQL functions. Supported statements are variable declarations, variable assignments, - IFstatements, simple- LOOPstatements (with no conditions),- EXITand- CONTINUEstatements, and- RETURNstatements. #104755
- Implemented the spatial built-in - ST_AsMVTGeom. #105530
- Pg_class's- relreplidentfield was previously unpopulated. It is now populated with- dfor all tables (as each table has a primary key) and- notherwise. #106242
- Added the - pg_sequence_last_valuebuilt-in function, which returns the last value generated by the sequence. #106445
- RESTOREcan now be passed a- WITH EXECUTION LOCALITYoption similar to- BACKUP, to restrict execution of the job to nodes with matching localities. #104439
- Added the - REPLICATIONuser role option, which allows a user to use the streaming replication protocol. There is a corresponding- REPLICATIONsystem privilege. #106082
- A new view-only session variable, - max_connectionswas added. This can be used with- SHOWto view the maximum amount of non-superuser SQL connections allowed at a given time. #106952
- Added the - nameconcatoidbuilt-in function, which concatenates a name with an OID. #105944
- The - pg_catalog.pg_languagetable is now populated with data about the languages used to define functions. #105944
- The - information_schema.routinesview is now populated with information about functions. #105944
- The - information_schema.parameterstable is now populated with information about function parameters. #105944
- Added support for the PLpgSQL - RAISEstatement, which allows sending notices to the client and raising errors. Currently the notice is only sent to the client. Support for logging notices will be added in a future release. #106351
- The - publicpseudo-role now receives the- EXECUTEprivilege by default for all user-defined functions that are created. This can be adjusted by using- ALTER DEFAULT PRIVILEGES. #107317
- The - crdb_interanal.node_statement_statisticstable redacts the error message if the user has the- VIEWACTIVITYREDACTEDprivilege, and does not redact the error message if the user has- VIEWACTIVITY. If the user has both,- VIEWACTIVITYREDACTEDtakes precedence and the last error is redacted. #107076
- The - crdb_internal.cluster_lockstable now has a- isolation_levelcolumn indicating the isolation level. #107309
- In - CommonSQLExecDetails, which is emitted as part of the SQL audit logs, SQL exec logs, and telemetry events, there is a new field:- StmtPosInTxn. It represents the statement's index in the transaction, starting at 1. #107081
- cluster_logical_timestampnow returns an error when called at isolation levels lower than- SERIALIZABLE. #107090
- EXPLAIN ANALYZEoutput now includes:- The isolation level of the statement's transaction.
- The priority of the statement's transaction.
- The quality of service level of the statement's transaction.
 
- Added a new session variable, - enable_implicit_fk_locking_for_serializable, which controls locking during foreign key checks under- SERIALIZABLEisolation. With this set to- true, foreign key checks of the referenced (parent) table, such as those performed during an- INSERTor- UPDATEof the referencing (child) table, will lock the referenced row using- SELECT FOR SHARElocking. This is somewhat analogous to the existing- enable_implicit_select_for_updatevariable but applies to the foreign key checks of a mutation statement instead of the initial row fetch. Under weaker isolation levels such as read committed,- SELECT FOR SHARElocking will always be used to ensure the database maintains the foreign key constraint, regardless of the current setting of- enable_implicit_fk_locking_for_serializable. #105857
- Add a new session variable, - enable_durable_locking_for_serializable, which controls locking durability under- SERIALIZABLEisolation. With this set to true,- SELECT FOR UPDATElocks,- SELECT FOR SHAREDlocks, and constraint check locks (e.g., locks acquired during foreign key checks if- enable_implicit_fk_locking_for_serializableis set to- true) will be guaranteed-durable under serializable isolation, meaning they will always be held to transaction commit. These locks are always guaranteed-durable under weaker isolation levels. By default, under serializable isolation these locks are best-effort rather than guaranteed-durable, meaning in some cases (e.g., leaseholder transfer, node loss, etc.) they could be released before the transaction commits. Serializable isolation does not rely on locking for correctness, only using it to improve performance under contention, so this default is a deliberate choice to avoid the performance overhead of lock replication. #107749
- The cluster setting - server.cpu_profile.enabledhas been removed.- server.cpu_profile.cpu_usage_combined_thresholdcan enable and disable CPU profiling. #107717
- Added support for - CONSTANTvariable declarations in PLpgSQL routines. Any assignment to a variable declared with the- CONSTANTkeyword will raise a compile-time error. #107682
- Added a new syntax to - SHOW DEFAULT PRIVILEGES,- SHOW DEFAULT PRIVILEGES FOR GRANTEE <grantee>, that shows the default privileges that a grantee received. #107953
- The Statement diagnostics feature has been extended to support collecting a bundle for a particular plan. Namely, the existing fingerprint-based matching has been extended to also include plan-gist-based matching. Such bundles will miss a couple of things: - plan.txtfile as well as the tracing of the optimizer. At the moment, the feature is only exposed via an overload to the- crdb_internal.request_statement_bundlebuilt-in function. We now also support "anti-match": collecting a bundle for any plan other than the provided plan gist. #105477
- SHOW BACKUP's timestamp columns are now- TIMESTAMPTZ, meaning they render in the session offset. #108290
- Attempting to drop a column when safe updates are enabled ( - sql_safe_updates = on) now additionally warns users that indexes referencing that column will be automatically dropped. #108047
- NOTICEs are now emitted for each index dropped by an- ALTER TABLE ... DROP COLUMN ...statement. #108047
- SHOW JOBSnow returns times (- created,- last_run, and so on) using the- TIMESTAMPTZcolumn type instead of the- TIMESTAMPtype, meaning they are now rendered using the session offset. #108353
- Added a cluster setting - sql.schema.force_declarative_statementsto enable/disable DDL in the declarative schema changer. #107815
- Added the new built-in functions - workload_index_recs()and- workload_index_recs(TIMESTAMPTZ), which return workload level index recommendations (columns of string, each string represent an index recommendation) from statement level index recommendations (as candidates) in- system.statement_statistics. If the- TIMESTAMPTZis given, it will only consider those candidates generated after that- TIMESTAMPTZvalue. #106525
- Added support for specifying PLpgSQL - IFstatements with- ELSIFbranches. #108211
- The admin API database details endpoint now returns authoritative range statistics. #108037 
- Added the - max_retries_for_read_committedsession variable. It defaults to 10, and determines the number of times an individual statement in an explicit- READ COMMITTEDtransaction will be retried if it encounters a retryable transaction error. #107044
- Added support for the execution of PLpgSQL functions with exception blocks. This allows a PLpgSQL function to catch and handle arbitrary errors it encounters during its execution. #107601 
- Added the built-in functions - bitmask_or,- bitmask_andand- bitmask_xorfor variable-length input bitwise- OR,- AND, and- XORoperations, respectively. #107863
- The - oidvectortypesbuilt-in has been implemented, which can format- oidvector. #108467
- Added support for executing SQL statements directly within PLpgSQL routines. Note that this currently only applies to the subset of statements that can be executed within SQL UDFs, so - CREATE TABLEis not supported, for example.- INTOsyntax is also supported. For example,- SELECT * INTO a, b FROM xy;. #107920
- A SQL client can now request strict atomicity for mixed DDL/DML transactions with the new session variable - strict_ddl_atomicity, which defaults to- false. When this variable is set to- true, CockroachDB will refuse to accept processing those specific DDL statements inside- BEGIN...COMMITfor which it cannot guarantee atomic processing (other DDL statements are still allowed). Note that schema changes implicit in certain operations (e.g.,- IMPORT) are not protected via the new mechanism and can still fail with- XXA00errors. #42063
- Fixed an issue where the UI was missing query text and details on the SQL Activity Transactions page if there were more than 500 transactions or statements. The - statement_activitytable now includes all statements for a transaction that are in the- transaction_activitytable. #109424
- Added the - VIEWSYSTEMTABLEsystem privilege. Users with this privilege have- SELECTprivileges for all tables in the system database. #109474
- The - statement_activityand- transaction_activitytables column- execution_total_cluster_secondsis now accurate. The- combinedstmtsendpoint returns the correct value for the- StmtsTotalRuntimeSecsand- TxnsTotalRuntimeSecsproperties. #109592
- The - persistedsqlstatstable maximum size check is now done once an hour instead of every 10 minutes. This reduces the risk of serialization errors on the statistics tables. #109696
- The deprecated session variable - idle_in_session_timeoutis now hidden from introspection. It was previously changed to- idle_session_timeout. #109872
- The session variable - sslis now visible through introspection for better compatibility with PostgreSQL. #109872
- The session variable - session_useris now invisible through introspection, in a way consistent with- session_authorizationand PostgreSQL. #109872
- There is now a - CREATEROLEsystem privilege, which is analogous to the existing- CREATEROLErole option, but can also be inherited by role membership. #109258
- Added the - gen_random_bytesbuilt-in function, which generates cryptographically secure random bytes. #110107
- The hash function used by hash-sharded indexes was changed to - mod(fnv32(md5(crdb_internal.datums_to_bytes(columns))), bucket_count). Previously, it did not use- md5. This change was made to enhance the uniformity of bucket distribution in cases when the bucket count is a power of 2, and the columns being sharded have numerical properties that make the- fnv32function return values with a non-uniformly distributed modulus. #109374
- New datetime built-ins ( - make_date,- make_timestamp, and- make_timestamptz) have been added, allowing for the creation of timestamps, timestamps with time zones, and dates. In addition,- date_truncnow allows for a timestamp to be truncated in a specified timezone (to a specified precision). #108824
- There is now a - CREATELOGINsystem privilege, which is analogous to the existing- CREATELOGINrole option, but can also be inherited by role membership. #110220
- There is now a - CREATEDBsystem privilege, which is analogous to the existing- CREATEDBrole option, but can also be inherited by role membership. #110220
- There is now a - CONTROLJOBsystem privilege, which is analogous to the existing- CONTROLJOBrole option, but can also be inherited by role membership. #110220
- The - persistedsqlstatstable maximum size check is now done once an hour instead of every 10 minutes. This reduces the risk of serialization errors on the statistics tables. #110173
- The new cluster setting - sql.txn.read_committed_syntax.enabled, controls whether transactions run under- READ COMMITTEDor- SERIALIZABLEisolation. It defaults to- false. When set to- true, the following statements will configure transactions to run under- READ COMMITTEDisolation:- BEGIN TRANSACTION ISOLATION LEVEL READ COMMITTED
- SET TRANSACTION ISOLATION LEVEL READ COMMITTED
- SET default_transaction_isolation = 'read committed'
- SET SESSION CHARACTERISTICS AS TRANSACTION ISOLATION LEVEL READ COMMITTED
 
- The cluster setting - sql.metrics.statement_details.gateway_node.enablednow defaults to false, to reduce the number of rows generated in SQL Statistics pages. #107788
- The default value for the - ttl_job_crontable storage parameter is now- @dailyrather than- @hourly. This parameter controls the default recurrence of the row-level TTL job. As part of this change, the output of the- SHOW CREATE TABLEstatements now include the- ttl_cron_jobparameter only if it is explicitly set. #110623
Operational changes
- Removed a timeseries metric that has not been reported for several versions. #100524
- Added two new metrics, range.snapshots.(send|recv)-queue-bytes, to track the total size of all snapshots waiting in the snapshot queue. #100942
- Exposed a new metric storage.compactions.duration, computed by the storage engine, that provides the cumulative time the storage engine has spent in compactions. This duration may exceed time elapsed, because of concurrent compactions, and may be useful in monitoring compaction concurrency. #103670
- Two new store metrics, range.snapshots.cross-region.sent-bytesandrange.snapshots.cross-region.rcvd-bytes, were added to track the aggregate of snapshot bytes sent from and received at a store across different regions. Note that these metrics require the nodes' localities to include a “region” tier key. If a node lacks this key but is involved in cross-region batch activities, an error message will be logged. #104111
- Added new store metrics to track the aggregate of snapshot bytes sent from and received at a store across different zones. - range.snapshots.cross-zone.sent-bytes
- range.snapshots.cross-zone.rcvd-bytes
 - For accurate metrics, follow these recommendations: - Configure region and zone tier keys consistently across nodes. - Within a node locality, ensure unique region and zone tier keys. - Maintain consistent configuration of region and zone tiers across nodes. 
- Added new store metrics: - raft.rcvd.bytes
- raft.sent.bytes
- raft.rcvd.cross_region.bytes
- raft.sent.cross_region.bytes
- raft.rcvd.cross_zone.bytes
- raft.sent.cross_zone.bytes
 
- Added new DistSender metrics: - distsender.batch_requests.replica_addressed.bytes
- distsender.batch_responses.replica_addressed.bytes
- distsender.batch_requests.cross_region.bytes
- distsender.batch_responses.cross_region.bytes
- distsender.batch_requests.cross_zone.bytes
- distsender.batch_responses.cross_zone.bytes.
 
- Added new Node metrics: - batch_requests.bytes
- batch_responses.bytes
- batch_requests.cross_region.bytes
- batch_responses.cross_region.bytes
- batch_requests.cross_zone.bytes
- batch_responses.cross_zone.bytes
 
- Added new RPC metrics to help you to diagnose RPC connection issues: - grpc.connection.avg_round_trip_latency
- rpc.connection.failures
- rpc.connection.healthy
- rpc.connection.healthy_nanos
- rpc.connection.heartbeats
- rpc.connection.unhealthy
- rpc.connection.unhealthy_nanos
 
- Added a new metric - changefeed.lagging_rangesthat shows the number of ranges which are behind in changefeeds. This metric can be used with the- metrics_labelchangefeed option. Added a new changefeed option- lagging_ranges_threshold, which is the amount of time a range needs to be behind to be considered lagging. By default this is 3 minutes. Added a new option- lagging_ranges_polling_interval, which controls how often the lagging ranges calculation is done. This setting defaults to polling every 1 minute. Note that polling adds latency to the metric being updated. For example, if a range falls behind by 3 minutes, the metric may not update for an additional minute afterwards. Also note that ranges undergoing an initial scan for longer than the threshold are considered to be lagging. Starting a changefeed with an initial scan on a large table will likely increment the metric for each range in the table. However, as ranges complete the initial scan, the number of ranges will decrease. #109835
- A histogram metric - raft.replication.latencywas added. It tracks the time between evaluation and application of the command. This includes time spent in the quota pool, in replication (including re-proposals) as well as log application, but notably not sequencing latency (i.e., contention and latch acquisition). #106094
- The default Raft scheduler concurrency cap has been increased from 96 to 128 workers, scaling with 8 workers per CPU up to the cap. The scheduler concurrency can be controlled using the - COCKROACH_SCHEDULER_CONCURRENCYenvironment variable. #105521
- The new cluster setting - server.hot_ranges_request.node.timeoutcontrols the maximum amount of time that a hot ranges request will spend waiting for a node to provide a response. It defaults to 5 minutes. To disable timeouts, set it to- 0. #107796
- Two new cluster settings control whether intent resolution is subject to admission control: - kv.intent_resolver.send_immediately.bypass_admission_control.enabledand- kv.intent_resolver.batch.bypass_admission_control.enabled. #109932
- The new cluster setting - admission.l0_min_size_per_sub_levelreduces the probability of admission control throttling when there is a sequence of small- memtableflushes or small files ingested into L0. #109332
- The new cluster setting - kv.intent_resolver.batcher.in_flight_backpressure_limit.enabledcontrols whether an in-flight RPC limit is enforced on intent resolution RPCs. It defaults to- false. #109899
- BACKUPnow skips contacting the ranges for tables on which- exclude_data_from_backupis set, and can thus succeed even if an excluded table is unavailable. #108627
- Span stats requests will return a partial result if the request encounters any errors. Errors that would have previously terminated the request are now included in the response. #108456 
- The rangefeed closed timestamp interval controlled by - kv.rangefeed.closed_timestamp_refresh_intervalnow defaults to 3 seconds. This affects how often rangefeeds emit resolved timestamps, and thus how often changefeeds can emit checkpoints. Previously, its default value of 0 would fall back to- kv.closed_timestamp.side_transport_interval, which defaults to 200 milliseconds. Users who rely on the setting- kv.closed_timestamp.side_transport_intervalto control the rangefeed closed timestamp interval should make sure they either set- kv.rangefeed.closed_timestamp_refresh_intervalto 0 to retain the old behavior (preferably before upgrading), or to an appropriate value. #108667
- The default value of - timeoutfor- http-serverslogging sinks has been changed from- 0(i.e., "no timeout") to- 2s. This is reflected in the- http-defaultssection of the log configuration. Users still maintain the ability to override the timeout, or disable it by explicitly setting it to- 0(e.g.- timeout: 0). #109264
- Changefeed metrics now include a - changefeed.checkpoint_progressmetric which is similar to- changefeed.max_behind_nanosbut supports metrics labels, as well as a- changefeed.aggregator_progressmetric which can track the progress of individual aggregators (the lowest timestamp for which all aggregators with the label have emitted all values they're responsible for). #108757
- Added support for Prometheus native histograms behind an environment variable flag. #104302 
- Requests for database details or table details from the UI, or usages of [ - SHOW RANGES WITH DETAILS]/docs/v23.2/show-ranges.html are no longer subject to errors if the number of requested spans is too large. #109464
- The - cockroach debug zipcommand now has an option to omit goroutine stack dumps. This impacts the creation of- nodes/*/stacks.txtand- nodes/*/stacks_with_labels.txtwithin debug ZIP bundles. Users can opt to exclude these goroutine stacks by using the- --include-goroutine-stacks=falseflag. Note that fetching stack traces for all goroutines is a "stop-the-world" operation, which can momentarily have negative impacts on SQL service latency. Note also that any periodic goroutine dumps previously taken on the node will still be included in- nodes/*/goroutines/*.txt.gz, as these would have already been generated and don't require any stop-the-world operations. #110177
- New rangefeed metrics help to troubleshoot rangefeed restarts. The metric names have the format - distsender.rangefeed.retry.{reason}. #109346
- Rangefeeds regularly attempt to push long-running transactions to a future timestamp in order to emit checkpoints. The interval at which this is attempted has been increased from 250 milliseconds to 1 seconds. This is now configurable via the environment variable - COCKROACH_RANGEFEED_PUSH_TXNS_INTERVAL. #110332
Cluster virtualization
When cluster virtualization is enabled:
- A selection box displays in DB Console Metrics pages when you are connected to the system virtual cluster, and allows you to view metrics for a specific virtual cluster. #103308
- A "no data" empty graph state has been added when switching to a virtual cluster with no data. #103971
- A selection box displays on custom charts in the DB Console and allows you to select a specific virtual cluster. #103780
- The name of the virtual cluster, when known, is now reported in logging events. #108807
- When cockroach debug zipis run for a cluster with virtualization enabled, data about virtual clusters is now stored in avirtualsubdirectory rather than atenantssubdirectory. #106117
- When cluster virtualization is enabled, the following closed timestamp side-transport settings can be set only from the system virtual cluster: kv.closed_timestamp.target_duration,kv.closed_timestamp.side_transport_interval, andkv.closed_timestamp.lead_for_global_reads_override. #108678
Command-line changes
- The CLI commands that output SQL data now support the JSON output format (--format=json), in addition to newline-delimited JSON (ND-JSON,--format=ndjson) that had been supported since v22.2. #102595
- cockroach debug zipnow supports the command-line flag- --formatto select the format used to store SQL table data, in the same way as- cockroach sql. In contrast to- cockroach sqlhowever, its default value is- json(resulting in files named- .json) and the default is not dependent on whether the terminal is interactive. #102607
- The SQL shell now supports argument quoting for client-side commands in a similar way to - psql: inside single quotes,- \can escape characters and recognize octal/hexadecimal sequences; and inside double quotes characters are passed through. The quote characters themselves, when doubled, result in themselves as part of the string.- For example, the following commands both result in a SQL prompt that says - go "world":- \set prompt1 'go "world"' \set prompt1 go' '"world"- To add color to the prompt: - \set prompt1 '\033[34mmydb>\033[m'- These quoting rules are similar to PostgreSQL, but are different from the rules used by POSIX shells and of other programming languages like Python or Go. For example, octal and hex escape sequences support a variable number of digits, and double quoted strings preserve the surrounding quotes. When in doubt, refer to the PostgreSQL documentation. 
- The configuration for log output sinks now accepts a new - format-optionsfield. This can be used to customize the output of a given format. Each format accepts different options. One available option for the- jsonoutput format is- datetime-format.- For example: - sinks: fluent-groups: custom-json: format: json format-options: {datetime-format: rfc3339}- This introduces a (new) field - datetimein each output JSON event, with the format specified by the option. As of this writing, the following values are documented:- none: disable the creation of the- datetimefield. This is the default value.
- iso8601/- rfc3339: format the time stamp like "2006-01-02T15:04:05.999999999Z".
- rfc1123: format the time stamp like "Mon, 02 Jan 2006 15:04:05 +0000".
 - Enabling the - datetimefield introduces CPU overhead and is not recommended. When using output to a log collector such as Fluent or Datadog, the log collector can be configured to transform the timestamp provided by CockroachDB without requiring participation from CockroachDB itself. When inspecting a log file containing JSON output produced by CockroachDB, the command- cockroach debug merge-logcan consume the JSON data and reformat it using the- crdb-v2format which also includes the date and time using the RFC3339 format. #104265
- The - jsonlog output format now recognizes the extra format option- datetime-timezonewhich selects which timezone to use when formatting the- datetimefield.- datetime-timezonemust be combined with- datetime-formatbecause the default value for the latter option is- none(i.e.,- datetimeis not produced by default). For example:- sinks: fluent-groups: custom-json: format: json format-options: {datetime-format: rfc3339, datetime-timezone: America/New_York}
- The - jsonlog format now recognizes the format options- tag-styleand- fluent-tag. The existing formats- json-compact,- json-fluent,- json-fluent-compacthave been redefined to become aliases for- jsonwith different defaults for the two new options. #104265
- The - crdb-v1log format now recognizes the format options- show-counterand- colors. The existing formats- crdb-v1-tty,- crdb-v1-count,- crdb-v1-tty-counthave been redefined to become aliases for- crdb-v1with different defaults for the two new options. #104265
- The - crdb-v2log format now recognizes the format option- colors. The existing formats- crdb-v2-ttyhas been redefined to become aliases for- crdb-v2with a different default for the new option. #104265
- The log output formats - crdb-v1and- crdb-v2now support the format option- timezone. When specified, the corresponding time zone is used to produce the timestamp column. For example:- file-defaults: format: crdb-v2 format-options: {timezone: america/new_york}- Example logging output: - I230606 12:43:01.553407-040000 1 1@cli/start.go:575 ⋮ [n?] 4 soft memory limit of Go runtime is set to 35 GiB ^^^^^^^ indicates GMT-4 was used- The timezone offset is also always included in the format if it is not zero (e.g., for non-UTC time zones). This is necessary to ensure that the times can be read back precisely. #104265 
- The command - cockroach debug merge-logwas adapted to understand time zones in input files read with format- crdb-v1or- crdb-v2. #104265
- When customizing the SQL interactive prompt, - %Mand- %mnow behave more like- psqlwhen connecting over a Unix datagram socket. #105137
- The default value of the - --formatparameter to- cockroach debug zipis- tsv, like other CLI commands that can extract SQL data. #107474
- The - debug.zipnow includes the- crdb_internal.probe_rangetable with a limit of 100 rows to prevent the query from taking too long. #107720
- The default value for the - --max-sql-memoryparameter of the- cockroach democommand has been increased from 128 MiB to 256 MiB. #103642
- The command - \demo recommissionhas been removed from- cockroach demo. It had been obsolete and non-functional ever since v20.2. #108566
- Added limited - statement_statisticsto the debug ZIP file. #108210
- The following user-visible cluster settings have been renamed. The previous name is still available for backward compatibility. - Previous name - New name - server.web_session_timeout- server.web_session.timeout- kv.closed_timestamp.follower_reads_enabled- kv.closed_timestamp.follower_reads.enabled- kv.range_split.by_load_enabled- kv.range_split.by_load.enabled- changefeed.balance_range_distribution.enable- changefeed.balance_range_distribution.enabled- changefeed.batch_reduction_retry_enabled- changefeed.batch_reduction_retry.enabled- server.clock.forward_jump_check_enabled- server.clock.forward_jump_check.enabled- server.oidc_authentication.autologin- server.oidc_authentication.autologin.enabled- sql.metrics.statement_details.dump_to_logs- sql.metrics.statement_details.dump_to_logs.enabled- sql.trace.log_statement_execute- sql.log.all_statements.enabled- trace.debug.enable- trace.http_debug_endpoint.enabled
- The following cluster settings have been renamed. The previous names are available for backward-compatibility. - Previous name - New name - spanconfig.tenant_coalesce_adjacent.enabled- spanconfig.range_coalescing.application.enabled- spanconfig.storage_coalesce_adjacent.enabled- spanconfig.range_coalescing.system.enabled
- The new - cockroach gen metric-listcommand generates metadata that describes the various metrics collected by an idle server. The list does not include dynamic metric names whose names are generated based on the workload. #109042
DB Console changes
- The time window selection for metrics charts is now encoded in the URL via query params. #101258
- The Job Details page now has a tabbed UI that will allow users to toggle between the Overview and other future views for advanced debugging and observability. #102737
- Renamed "recent executions" to "active executions" in the UI. #103784
- The Changefeed Dashboard has been updated with new graphs to track backfill progress, protected timestamps age, and the number of schema registry registrations. The updates include renaming the Sink Byte Traffic graph to Emitted Bytes and the Max Changefeed Latency graph to Max Checkpoint Latency. #101790
- A new Networking tab has been added to the DB Console metrics dashboard. Metrics for network bytes sent and received are now displayed in the Networking tab rather than the Hardware tab. In addition, the following metrics have been added: - cr.node.round-trip-latency-p50
- cr.node.round-trip-latency-p99
- cr.node.rpc.connection.unhealthy
 
- The Job Details page now has a profiler tab for more advanced observability into a job's execution. Currently, we support collecting a cluster-wide CPU profile of the job. #103945
- The active executions views in the SQL Activity pages now support toggling between automatic and manual refresh. A manual refresh button was also added along with a timestamp indicating when the last refresh was performed. #103786
- The visibility of the cluster setting ui.display_timezonehas been set to public. Documentation of the cluster setting has been added. No functionality has been changed. #106530
- Added a table in the Profiler job details page that lists all the available files describing a job's execution details #106879
- Add columns for p50, p90, p99 percentiles and latency min and max on Explain Plan tab on the Statement Execution Details page. #107719
- Fixed a broken query for the database details page that was causing an infinite loading state. #107893
- Added summary cards with total/average values for statistics on the Statement Execution Details page. #109056
- The DB Console now Shows a warning when the time period selected on SQL Activity pages is older than the oldest data available. #109164
- Users without the VIEWCLUSTERSETTINGSpermission but withVIEWACTIVITYorVIEWACTIVITYREDACTEDcan now see index recommendations. #109047
- The DB Console now allows non-admin users to view the Databases page. #109245
- Non-admin users are able to use the Database Details page. #109432
- Non-admin users are able to use the Database Table page. #109521
- The "SQL Connection Rate" metric on the SQL Dashboard is downsampled using the MAX function instead of SUM. This improves situations where zooming out would cause the connection rate to increase for downsampled data. #110391
Bug fixes
- Fixed an internal error that can occur when CREATE OR REPLACE VIEWreplaces a view with fewer columns and another entity depended on the view. #99057
- If views are created with circular dependencies, CockroachDB now returns an error (cyclic view dependency for relation) instead of crashing the node. This bug was present since at least 21.1. #99174
- Fixed a potential bug whereby a failed or cancelled IMPORT could in some cases leave some of the imported rows behind after it was cancelled, in the rare event that the writing processes were slow enough to continue writing after the cleanup process started. #97071
- Fixed a very rare bug that could cause keys to get unexpectedly deleted when rebalances occurred in a write-heavy workload. #102164
- It is now possible to properly redirect the output of SQL queries using the ndjsonoutput table format incockroach sql. This bug had been introduced in v22.2. #102595
- The unaccentbuilt-in function no longer removes spaces. #103819
- The details of errors pertaining to invalid descriptors are not included any more in redacted debug ZIP files. #104050
- Fixed a bug where join expressions were processed incorrectly. #103782
- Fixed a bug that could cause a UDF to return a value that does not conform to the return type of the UDF. This bug was only present for UDFs that return user-defined types. The bug was present since v23.1. #104151
- Fixed a bug where if a user was logged in while a different session dropped that user, the dropped user would still inherit privileges from the publicrole. Now, CockroachDB checks that the user exists before allowing it to inherit privileges from thepublicrole. In addition, any active web sessions are now revoked when a user is dropped. #104215
- Fixed a bug in upstream etcd-io/raftwhich could result in pulling unlimited amount of logs into memory, and lead to out-of-memory errors. Now the log scan has a limited memory footprint. #104483
- Fixed a bug where, in rare circumstances, a replication could get stuck when proposed near lease or leadership changes, especially under overload, and the [replica circuit breakers](../v23.2 could trip. A previous attempt to fix this issue has been reverted in favor of this fix. #106515
- CockroachDB now automatically deletes statistics for dropped tables from the system.table_statisticstable. #105364
- Fixed a rare internal error which occurs when a query uses a "project set" operation involving simple column expressions. #104756
- The Raft PreVoteandCheckQuorummechanisms are now fully enabled. These prevent spurious elections when followers already have an active leader, and cause leaders to step down if they don't hear back from a quorum of followers. This improves reliability under partial and asymmetric network partitions, by avoiding spurious elections and preventing unavailability where a partially partitioned node could steal leadership away from an established leaseholder who would then no longer be able to reach the leader and submit writes. #104042
- Fixed a bug that could produce incorrect values for virtual computed columns in rare cases. The bug only occurred when the virtual column expression's type did not match the type of the virtual column. #105736
- Fixed a rounding error that could cause distributed execution for some decimal aggregate functions to return slightly inaccurate results in rare cases. #105694
- Fixed the StatementStatistics.Nodesto contain all of the nodes involved in the query. Fixed the region info inEXPLAIN ANALYZE (DISTSQL)for virtual clusters. #106587
- Fixed a bug that caused backups to fail if there are tables and functions of the same name. #106626
- Fixed edge cases in decimal and float evaluation for division operators. 'NaN'::DECIMAL / 0will now returnNaNinstead of a division-by-zero error, and0 / 'inf'::DECIMALwill return0instead of0E-2019. #106472
- Fixed a bug present since before v22.2 that could cause a query with LIMITandORDER BYto return results in the wrong order. This bug could cause incorrect results as well if theLIMITwas nested within an outer query (e.g., under anotherLIMIT). #106717
- Added missing SQLInstanceIDsused to execute the statement to the telemetrySampledQueryevent. #106753
- Fixed a bug where inserting geometries into a table with an inverted index involving a NaN coordinate could result in a panic. This now produces errors instead. #106671
- Avoid displaying undefinedregions on the Databases page. #106778
- The cockroach userfile uploadcommand uses less memory when uploading a file. #106056
- CASE,- IF,- COALESCE, and- IFNULLexpressions now return an error when passed a generator function as an argument. This mirrors the behavior of PostgreSQL. #105582
- Fixed a bug that allowed views created with CREATE OR REPLACE VIEWto reference user-defined types in other databases, even withsql.cross_db_views.enabledset tofalse. This bug was present since user-defined types were introduced in v20.1. #106869
- Removed a source of unnecessary Raft snapshots during replica movement. #106793
- Fixed a bug where in rare situations nodes would get stuck during start-up. It would manifest itself through a stack frame sitting on a select in waitForAdditionalStoreInitfor extended periods of time (i.e., minutes). #107124
- Fixed a bug that caused internal errors when using an aggregate function in an ORDER BYclause of aDELETEorUPDATEstatement. Aggregate functions are no longer allowed in these contexts. The bug has been present since at least v20.2. #107641
- The filter on the Statements page works when application name is an empty string. #107750
- The Transaction Details page now loads with the fingerprint details even if no application is specified in the URL. #107742
- The Schema Insights page no longer times out. #107292
- The last SQL statement in a user-defined function with a VOIDreturn type can now produce any number of columns of any type. This bug was present since UDFs were introduced in v22.2. #108299
- Fixed a bug that caused nodes to crash when attempting to EXECUTEa prepared statement with an argument that referenced a user-defined function. This bug was present since user-defined functions were introduced in v22.2. #108213
- Fixed a bug where a release save point could incorrectly emit a "cannot publish new versions for descriptors" error instead of a retryable error. #108133
- Users with the VIEWACTIVITYprivilege now are able to see other users sessions from both the CLI and the DB Console. #106590
- Fixed a bug in cockroach demowhereby\demo addcould sometimes crash with an error "index out of range [...] with length ...". This bug had been introduced in v19.x. #108566
- Fixed a bug introduced in v20.2 where the command \demo decommissionincockroach democould leave the demo cluster in a broken state. #108566
- Fixed a bug where cockroach startwould sometimes incorrectly hang upon shutting down a server after encountering an internal error. This bug had been introduced some time in v22.x. #108612
- Fixed a bug in the index recommendations provided in the EXPLAINoutput whereALTER INDEX ... VISIBLEindex recommendations may suggest making the wrong index visible when there are multiple invisible indexes in a table. #108576
- Users with the VIEWACTIVITYprivilege can now view correct values for timezones. #108486
- Fixed a bug present since v23.1.0 that would cause queries on the pg_catalog.pg_statistic_exttable to fail if a table was dropped recently. This bug also caused the\dCLI shortcut to encounter errors. #108818
- Fixed a bug where pg_attributeandpg_attrdefdid not properly return results for generated columns. #108964
- Fixed a bug where a SpanStatsRequestwould return post-replicated MVCC stats. Now, aSpanStatsRequestreturns the logical MVCC stats for the requested span. #108852
- Fixed the column name on the selects on the tables crdb_internal.node_txn_execution_insightsandcrdb_internal.cluster_txn_execution_insightsupon the creation ofdebug.zip. #109444
- Fixed the type resolution logic for CASEstatements to more closely match Postgres' logic. In particular, we now adhere to rule 5 listed in the PostgreSQL documentation, which requires that we select the first non-unknown input type as the candidate type, then consider each other non-unknown input type, left to right (CASEtreats itsELSEclause (if any) as the "first" input, with theTHENclauses(s) considered after that). If the candidate type can be implicitly converted to the other type, but not vice-versa, select the other type as the new candidate type. Then continue considering the remaining inputs. If, at any stage of this process, a preferred type is selected, stop considering additional inputs (note that CockroachDB does not yet support the concept of a "preferred type"). #108387
- Fixed an issue on the Metrics page where no metrics would load when viewing metrics for a virtual cluster with a hyphenated name in a global context. #109174
- Fixed a potential livelock between a high-priority transactional read and a normal-priority write. The read pushes the timestamp of the write, but if the read gets pushed as well, it may repeatedly fail to refresh because it keeps encountering the intent of the write. #108190
- Fixed a nil dereference panic during node startup that could be caused by an incorrect initialization order. #109659
- The differencebuilt-in had its return type incorrectly set to a string instead of an integer. #109731
- Fixed a bug that could cause a transaction performing multiple parallel foreign key checks to return a concurrent txn use detectederror. #109510
- Fixed a bug causing performance regression when disabling sql.metrics.statement_details.enabledwhich caused execution stats to be collected for all queries instead of the default one percent. #109785
- Fixed a bug where certain SQL session variables meant to be hidden from introspection were showing up in information_schema.session_variables, which was incoherent with the handling inpg_catalog.pg_settings. #109872
- CockroachDB now properly handles RPC failures on writes using the parallel commit protocol that execute in parallel to the commit operation, avoiding incorrect retryable failures and transaction unexpectedly committedassertions by detecting when writes cannot be retried idempotently, instead returning anAmbiguousResultError. #107658
- Fixed a bug where dependencies on sequences from tables would be reported with the wrong value for the classidcolumn in thepg_catalog.pg_dependtable. #110144
- Two ALTER RANGE default CONFIGURE ZONEstatements on the same line no longer displays an error. #109774
- Fixed a DB Console issue where the DROP_UNUSEDindex recommendations produced by the table details page produced an invalidDROP INDEXstatement. #110429
- Removed buggy TTL descriptor repair. Previously, upgrading from v22.2.X to v23.1.9 incorrectly removed TTL storage parameters from tables (visible by running a SHOW CREATE TABLE <ttl-table>;statement) while attempting to repair table descriptors. This resulted in the node that attempted to run the TTL job crashing due to a panic caused by the missing TTL storage parameters. #110364
- cockroach debug pebblecommands now work correctly with encrypted stores which don't use the default- cockroach-datapath without having to also pass- --store. #110150
- Fixed a bug where CREATE INDEXfor partial indexes could fail withERROR: duplicate key value violates unique constraintif concurrent inserts happened simultaneously. #110216
- Observability pages no longer crash when they encounter zeros (e.g., a session with no memory allocated). #108752
- Removed the cluster setting kv.snapshot_recovery.max_rate:- In v23.2, this setting is disabled; it is a no-op. If you previously set kv.snapshot_recovery.max_rateon a cluster running v23.1 and upgraded to v23.2, the setting is ignored, and thekv.snapshot_rebalance.max_ratesetting is used instead.
- In v24.1 and later, this setting is removed entirely. If you had previously set kv.snapshot_recovery.max_rateprior to upgrade, it will be cleared, and any attempts to set it will fail with the error message:ERROR: unknown cluster setting 'kv.snapshot_recovery.max_rate'. #102596
 
- In v23.2, this setting is disabled; it is a no-op. If you previously set 
- Fixed a bug in which a - CREATE FUNCTIONmay produce a syntax error if the UDF body wrapped in tagged dollar quotes (e.g.,- $func$), contains two consecutive dollar signs- $$. If the UDF body is known to contain dollar signs, then the caller should use tagged dollar quotes or single quotes when defining the UDF. For example:- CREATE FUNCTION f(a STRING) RETURNS STRING LANGUAGE SQL AS $func$ SELECT concat('$$', a); $func$
- CockroachDB now prevents setting - max_range_sizebelow the- COCKROACH_MIN_RANGE_MAX_BYTESenvironment variable, which defaults to 64 MiB (half of the default minimum range size). #96725
- Fixed a bug that could occasionally cause schema change jobs, such as table or index drops, to appear stuck in state "waiting for MVCC GC" for much longer than expected. The fix only applies to future schema changes. To process existing stuck jobs, manually force-enqueue the relevant ranges in the MVCC GC queue from the DB Console's Advanced Debug page. #110078 
- Fixed a bug introduced when the - ChartCatalogAPI endpoint was introduced, where the endpoint did not correctly report the unit of metrics. #109042
- Fixed a bug that could occur when the "multiple active portals" execution mode (Preview) was enabled to evaluate queries such as lookup joins. The bug could result in an internal error like - unexpected 40960 leftover bytesif the portal was not fully consumed. #110625
- Fixed a bug where an - ALTER TABLE ... ADD CONSTRAINT CHECK ...statement that utilized a user-defined function in the- CHECKcould cause a validation error. #110130
- Fixed a bug where - RESET (ttl_expire_after)could incorrectly remove- ttl_expiration_expression. #110252
- Fixed a bug where the - format_typebuilt-in did not honor- typemodinformation for array types, leading to incorrect output. #110900
- Fixed a bug introduced in v22.2 that incorrectly allowed users without the - EXECUTEprivilege to execute a user-defined function. #107587
Performance improvements
- The optimizer now plans inverted index scans for queries using INor the=operators without the fetch val (->) operator. For example:json_col = '{"b":"c"}' OR json_col IN ('"a"', '1')#101178
- Queries that have subqueries in equality expressions are now more efficiently planned by the optimizer. #100881
- Query planning time has been reduced for some queries with multiple joins. #102011
- CockroachDB now enables the pacing mechanism in rangefeed closed timestamp notifications, by setting the default kv.rangefeed.closed_timestamp_smear_intervalcluster setting to 1ms. This makes rangefeed closed timestamp delivery more uniform and less spikey, which reduces its impact on the Go scheduler and, ultimately, foreground SQL latencies. #103006
- Some large, long-running INSERTstatements now perform less work during their commit phase and can run faster. #103241
- Ranges now only quiesce after 3 seconds without proposals, to avoid frequent unquiescence which incurs an additional Raft proposal. This is configurable via the COCKROACH_QUIESCE_AFTER_TICKSenvironment variable, which defaults to 6. #103266
- SQL statements that must clean up intents from many different previously abandoned transactions now do so moderately more efficiently. #103265
- The optimizer can now avoid a grouping stage in more cases when de-duplicating the input to an UPSERTorINSERT ... ON CONFLICTstatement. #105206
- The optimizer can now eliminate joins in more cases. #105214
- CockroachDB now improves the time to disk space reclamation when deleting rows. Previously, in scenarios where rows had large variations in row size, it was possible for disk space to not be reclaimed after MVCC garbage collection deleted the rows. #104539
- CockroachDB now has improved disk space reclamation heuristics, making disk space reclamation more timely. #106177
- bool_andand- bool_oraggregates will now scale linearly instead of quadratically when used as a window function with a non-shrinking window, #106477
- CockroachDB now has reduced lock contention on ssmemstorage.RecordStatement. This is useful for workloads that execute the same statement concurrently on the same SQL instance. #106860
- The optimizer now produces more efficient query plans in some cases for queries with subqueries and user-defined functions. #107133
- The default Raft entry cache size has been increased from 16 MB to 1/256 of system memory with a minimum of 32 MB, divided evenly between all stores. This can be configured using the COCKROACH_RAFT_ENTRY_CACHE_SIZEenvironment variable. #107424
- CockroachDB now automatically collects table statistics on the system.jobstable, which will enable the optimizer to produce better query plans for internal queries that access thesystem.jobstable. This may result in better performance of the system. #108139
- The impact of high concurrency blind writes to the same key on goroutine scheduling latency was reduced. #109349
- Changefeeds to Webhook or Pub/Sub endpoints now support much higher throughput #109351
- This release improved the cost of resolving a user-defined enum type that has many values. #109394
- Queries that compare collated strings now use less memory and may execute faster. #110066
- Added a scheduler based rangefeed processor which improves rangefeed and changefeed performance for very large tables. The new processor is disabled by default, but can be enabled by setting kv.rangefeed.scheduler.enabledcluster setting totrue. #107553
- This release disables sql.defaults.zigzag_join.enabledby default. #110214
Build changes
- Go has been upgraded to 1.20.8. #109773
- The top-level Makefilewas replaced by a stubGNUmakefilewhich defers its behavior todev. The common targetsmake [all],make test, andmake installremain for compatibility with most UNIX installation guides. The previousmakerules remain available viamake -C build/GNUmakefile.obsolete. #84565
Contributors
This release includes 3208 merged PRs by 124 authors.
Please select a star rating above.
Tell us about your experience
Please attach a screenshot of the area where you encountered the problem.
Thank you for your feedback!
Your input helps us improve our documentation.