mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-11-21 23:21:59 +00:00
Merge branch 'master' into pr/allmazz/63279
This commit is contained in:
commit
90d2d36209
62
CHANGELOG.md
62
CHANGELOG.md
@ -18,6 +18,7 @@
|
|||||||
* Metric `KeeperOutstandingRequets` was renamed to `KeeperOutstandingRequests`. [#66206](https://github.com/ClickHouse/ClickHouse/pull/66206) ([Robert Schulze](https://github.com/rschu1ze)).
|
* Metric `KeeperOutstandingRequets` was renamed to `KeeperOutstandingRequests`. [#66206](https://github.com/ClickHouse/ClickHouse/pull/66206) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
* Remove `is_deterministic` field from the `system.functions` table. [#66630](https://github.com/ClickHouse/ClickHouse/pull/66630) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
* Remove `is_deterministic` field from the `system.functions` table. [#66630](https://github.com/ClickHouse/ClickHouse/pull/66630) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
* Function `tuple` will now try to construct named tuples in query (controlled by `enable_named_columns_in_function_tuple`). Introduce function `tupleNames` to extract names from tuples. [#54881](https://github.com/ClickHouse/ClickHouse/pull/54881) ([Amos Bird](https://github.com/amosbird)).
|
* Function `tuple` will now try to construct named tuples in query (controlled by `enable_named_columns_in_function_tuple`). Introduce function `tupleNames` to extract names from tuples. [#54881](https://github.com/ClickHouse/ClickHouse/pull/54881) ([Amos Bird](https://github.com/amosbird)).
|
||||||
|
* Change how deduplication for Materialized Views works. Fixed a lot of cases like: - on destination table: data is split for 2 or more blocks and that blocks is considered as duplicate when that block is inserted in parallel. - on MV destination table: the equal blocks are deduplicated, that happens when MV often produces equal data as a result for different input data due to performing aggregation. - on MV destination table: the equal blocks which comes from different MV are deduplicated. [#61601](https://github.com/ClickHouse/ClickHouse/pull/61601) ([Sema Checherinda](https://github.com/CheSema)).
|
||||||
|
|
||||||
#### New Feature
|
#### New Feature
|
||||||
* Add `ASOF JOIN` support for `full_sorting_join` algorithm. [#55051](https://github.com/ClickHouse/ClickHouse/pull/55051) ([vdimir](https://github.com/vdimir)).
|
* Add `ASOF JOIN` support for `full_sorting_join` algorithm. [#55051](https://github.com/ClickHouse/ClickHouse/pull/55051) ([vdimir](https://github.com/vdimir)).
|
||||||
@ -32,22 +33,23 @@
|
|||||||
* Add a new setting to disable/enable writing page index into parquet files. [#65475](https://github.com/ClickHouse/ClickHouse/pull/65475) ([lgbo](https://github.com/lgbo-ustc)).
|
* Add a new setting to disable/enable writing page index into parquet files. [#65475](https://github.com/ClickHouse/ClickHouse/pull/65475) ([lgbo](https://github.com/lgbo-ustc)).
|
||||||
* Introduce `logger.console_log_level` server config to control the log level to the console (if enabled). [#65559](https://github.com/ClickHouse/ClickHouse/pull/65559) ([Azat Khuzhin](https://github.com/azat)).
|
* Introduce `logger.console_log_level` server config to control the log level to the console (if enabled). [#65559](https://github.com/ClickHouse/ClickHouse/pull/65559) ([Azat Khuzhin](https://github.com/azat)).
|
||||||
* Automatically append a wildcard `*` to the end of a directory path with table function `file`. [#66019](https://github.com/ClickHouse/ClickHouse/pull/66019) ([Zhidong (David) Guo](https://github.com/Gun9niR)).
|
* Automatically append a wildcard `*` to the end of a directory path with table function `file`. [#66019](https://github.com/ClickHouse/ClickHouse/pull/66019) ([Zhidong (David) Guo](https://github.com/Gun9niR)).
|
||||||
* Add `--memory-usage` option to client in non interactive mode. [#66393](https://github.com/ClickHouse/ClickHouse/pull/66393) ([vdimir](https://github.com/vdimir)).
|
* Add `--memory-usage` option to client in non-interactive mode. [#66393](https://github.com/ClickHouse/ClickHouse/pull/66393) ([vdimir](https://github.com/vdimir)).
|
||||||
* Make an interactive client for clickhouse-disks, add local disk from the local directory. [#64446](https://github.com/ClickHouse/ClickHouse/pull/64446) ([Daniil Ivanik](https://github.com/divanik)).
|
* Make an interactive client for clickhouse-disks, add local disk from the local directory. [#64446](https://github.com/ClickHouse/ClickHouse/pull/64446) ([Daniil Ivanik](https://github.com/divanik)).
|
||||||
* When lightweight delete happens on a table with projection(s), users have choices either throw an exception (by default) or drop the projection [#65594](https://github.com/ClickHouse/ClickHouse/pull/65594) ([jsc0218](https://github.com/jsc0218)).
|
* When lightweight delete happens on a table with projection(s), users have choices either throw an exception (by default) or drop the projection [#65594](https://github.com/ClickHouse/ClickHouse/pull/65594) ([jsc0218](https://github.com/jsc0218)).
|
||||||
|
* Add system tables with main information about all detached tables. [#65400](https://github.com/ClickHouse/ClickHouse/pull/65400) ([Konstantin Morozov](https://github.com/k-morozov)).
|
||||||
|
|
||||||
#### Experimental Feature
|
#### Experimental Feature
|
||||||
* Change binary serialization of Variant data type: add `compact` mode to avoid writing the same discriminator multiple times for granules with single variant or with only NULL values. Add MergeTree setting `use_compact_variant_discriminators_serialization` that is enabled by default. Note that Variant type is still experimental and backward-incompatible change in serialization is ok. [#62774](https://github.com/ClickHouse/ClickHouse/pull/62774) ([Kruglov Pavel](https://github.com/Avogar)).
|
* Change binary serialization of the `Variant` data type: add `compact` mode to avoid writing the same discriminator multiple times for granules with single variant or with only NULL values. Add MergeTree setting `use_compact_variant_discriminators_serialization` that is enabled by default. Note that Variant type is still experimental and backward-incompatible change in serialization is ok. [#62774](https://github.com/ClickHouse/ClickHouse/pull/62774) ([Kruglov Pavel](https://github.com/Avogar)).
|
||||||
* Support rocksdb as backend storage of keeper. [#56626](https://github.com/ClickHouse/ClickHouse/pull/56626) ([Han Fei](https://github.com/hanfei1991)).
|
* Support on-disk backend storage for clickhouse-keeper. [#56626](https://github.com/ClickHouse/ClickHouse/pull/56626) ([Han Fei](https://github.com/hanfei1991)).
|
||||||
* Refactor JSONExtract functions, support more types including experimental Dynamic type. [#66046](https://github.com/ClickHouse/ClickHouse/pull/66046) ([Kruglov Pavel](https://github.com/Avogar)).
|
* Refactor JSONExtract functions, support more types including experimental Dynamic type. [#66046](https://github.com/ClickHouse/ClickHouse/pull/66046) ([Kruglov Pavel](https://github.com/Avogar)).
|
||||||
* Support null map subcolumn for Variant and Dynamic subcolumns. [#66178](https://github.com/ClickHouse/ClickHouse/pull/66178) ([Kruglov Pavel](https://github.com/Avogar)).
|
* Support null map subcolumn for `Variant` and `Dynamic` subcolumns. [#66178](https://github.com/ClickHouse/ClickHouse/pull/66178) ([Kruglov Pavel](https://github.com/Avogar)).
|
||||||
* Fix reading dynamic subcolumns from altered Memory table. Previously if `max_types` parameter of a Dynamic type was changed in Memory table via alter, further subcolumns reading can return wrong result. [#66066](https://github.com/ClickHouse/ClickHouse/pull/66066) ([Kruglov Pavel](https://github.com/Avogar)).
|
* Fix reading `Dynamic` subcolumns from altered `Memory` table. Previously if `max_types` parameter of a Dynamic type was changed in Memory table via alter, further subcolumns reading can return wrong result. [#66066](https://github.com/ClickHouse/ClickHouse/pull/66066) ([Kruglov Pavel](https://github.com/Avogar)).
|
||||||
* Add support for `cluster_for_parallel_replicas` when using custom key parallel replicas. It allows you to use parallel replicas with custom key with MergeTree tables. [#65453](https://github.com/ClickHouse/ClickHouse/pull/65453) ([Antonio Andelic](https://github.com/antonio2368)).
|
* Add support for `cluster_for_parallel_replicas` when using custom key parallel replicas. It allows you to use parallel replicas with custom key with MergeTree tables. [#65453](https://github.com/ClickHouse/ClickHouse/pull/65453) ([Antonio Andelic](https://github.com/antonio2368)).
|
||||||
|
|
||||||
#### Performance Improvement
|
#### Performance Improvement
|
||||||
* Replace int to string algorithm with a faster one (from a modified amdn/itoa to a modified jeaiii/itoa). [#61661](https://github.com/ClickHouse/ClickHouse/pull/61661) ([Raúl Marín](https://github.com/Algunenano)).
|
* Replace int to string algorithm with a faster one (from a modified amdn/itoa to a modified jeaiii/itoa). [#61661](https://github.com/ClickHouse/ClickHouse/pull/61661) ([Raúl Marín](https://github.com/Algunenano)).
|
||||||
* Sizes of hash tables created by join (`parallel_hash` algorithm) is collected and cached now. This information will be used to preallocate space in hash tables for subsequent query executions and save time on hash table resizes. [#64553](https://github.com/ClickHouse/ClickHouse/pull/64553) ([Nikita Taranov](https://github.com/nickitat)).
|
* Sizes of hash tables created by join (`parallel_hash` algorithm) are collected and cached now. This information will be used to preallocate space in hash tables for subsequent query executions and save time on hash table resizes. [#64553](https://github.com/ClickHouse/ClickHouse/pull/64553) ([Nikita Taranov](https://github.com/nickitat)).
|
||||||
* Optimized queries with `ORDER BY` primary key and `WHERE` that have a condition with high selectivity by using of buffering. It is controlled by setting `read_in_order_use_buffering` (enabled by default) and can increase memory usage of query. [#64607](https://github.com/ClickHouse/ClickHouse/pull/64607) ([Anton Popov](https://github.com/CurtizJ)).
|
* Optimized queries with `ORDER BY` primary key and `WHERE` that have a condition with high selectivity by using buffering. It is controlled by setting `read_in_order_use_buffering` (enabled by default) and can increase memory usage of query. [#64607](https://github.com/ClickHouse/ClickHouse/pull/64607) ([Anton Popov](https://github.com/CurtizJ)).
|
||||||
* Improve performance of loading `plain_rewritable` metadata. [#65634](https://github.com/ClickHouse/ClickHouse/pull/65634) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
* Improve performance of loading `plain_rewritable` metadata. [#65634](https://github.com/ClickHouse/ClickHouse/pull/65634) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
* Attaching tables on read-only disks will use fewer resources by not loading outdated parts. [#65635](https://github.com/ClickHouse/ClickHouse/pull/65635) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
* Attaching tables on read-only disks will use fewer resources by not loading outdated parts. [#65635](https://github.com/ClickHouse/ClickHouse/pull/65635) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
* Support minmax hyperrectangle for Set indices. [#65676](https://github.com/ClickHouse/ClickHouse/pull/65676) ([AntiTopQuark](https://github.com/AntiTopQuark)).
|
* Support minmax hyperrectangle for Set indices. [#65676](https://github.com/ClickHouse/ClickHouse/pull/65676) ([AntiTopQuark](https://github.com/AntiTopQuark)).
|
||||||
@ -59,11 +61,10 @@
|
|||||||
* DatabaseCatalog drops tables faster by using up to database_catalog_drop_table_concurrency threads. [#66065](https://github.com/ClickHouse/ClickHouse/pull/66065) ([Sema Checherinda](https://github.com/CheSema)).
|
* DatabaseCatalog drops tables faster by using up to database_catalog_drop_table_concurrency threads. [#66065](https://github.com/ClickHouse/ClickHouse/pull/66065) ([Sema Checherinda](https://github.com/CheSema)).
|
||||||
|
|
||||||
#### Improvement
|
#### Improvement
|
||||||
|
* Improved ZooKeeper load balancing. The current session doesn't expire until the optimal nodes become available despite `fallback_session_lifetime`. Added support for AZ-aware balancing. [#65570](https://github.com/ClickHouse/ClickHouse/pull/65570) ([Alexander Tokmakov](https://github.com/tavplubix)).
|
||||||
* The setting `optimize_trivial_insert_select` is disabled by default. In most cases, it should be beneficial. Nevertheless, if you are seeing slower INSERT SELECT or increased memory usage, you can enable it back or `SET compatibility = '24.6'`. [#58970](https://github.com/ClickHouse/ClickHouse/pull/58970) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
* The setting `optimize_trivial_insert_select` is disabled by default. In most cases, it should be beneficial. Nevertheless, if you are seeing slower INSERT SELECT or increased memory usage, you can enable it back or `SET compatibility = '24.6'`. [#58970](https://github.com/ClickHouse/ClickHouse/pull/58970) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
* Print stacktrace and diagnostic info if `clickhouse-client` or `clickhouse-local` crashes. [#61109](https://github.com/ClickHouse/ClickHouse/pull/61109) ([Alexander Tokmakov](https://github.com/tavplubix)).
|
* Print stacktrace and diagnostic info if `clickhouse-client` or `clickhouse-local` crashes. [#61109](https://github.com/ClickHouse/ClickHouse/pull/61109) ([Alexander Tokmakov](https://github.com/tavplubix)).
|
||||||
* The result of `SHOW INDEX | INDEXES | INDICES | KEYS` was previously sorted by the primary key column names. Since this was unintuitive, the result is now sorted by the position of the primary key columns within the primary key. [#61131](https://github.com/ClickHouse/ClickHouse/pull/61131) ([Robert Schulze](https://github.com/rschu1ze)).
|
* The result of `SHOW INDEX | INDEXES | INDICES | KEYS` was previously sorted by the primary key column names. Since this was unintuitive, the result is now sorted by the position of the primary key columns within the primary key. [#61131](https://github.com/ClickHouse/ClickHouse/pull/61131) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
* Change how deduplication for Materialized Views works. Fixed a lot of cases like: - on destination table: data is split for 2 or more blocks and that blocks is considered as duplicate when that block is inserted in parallel. - on MV destination table: the equal blocks are deduplicated, that happens when MV often produces equal data as a result for different input data due to performing aggregation. - on MV destination table: the equal blocks which comes from different MV are deduplicated. [#61601](https://github.com/ClickHouse/ClickHouse/pull/61601) ([Sema Checherinda](https://github.com/CheSema)).
|
|
||||||
* Allow matching column names in a case insensitive manner when reading json files (`input_format_json_case_insensitive_column_matching`). [#61750](https://github.com/ClickHouse/ClickHouse/pull/61750) ([kevinyhzou](https://github.com/KevinyhZou)).
|
|
||||||
* Support reading partitioned data DeltaLake data. Infer DeltaLake schema by reading metadata instead of data. [#63201](https://github.com/ClickHouse/ClickHouse/pull/63201) ([Kseniia Sumarokova](https://github.com/kssenii)).
|
* Support reading partitioned data DeltaLake data. Infer DeltaLake schema by reading metadata instead of data. [#63201](https://github.com/ClickHouse/ClickHouse/pull/63201) ([Kseniia Sumarokova](https://github.com/kssenii)).
|
||||||
* In composable protocols TLS layer accepted only `certificateFile` and `privateKeyFile` parameters. https://clickhouse.com/docs/en/operations/settings/composable-protocols. [#63985](https://github.com/ClickHouse/ClickHouse/pull/63985) ([Anton Ivashkin](https://github.com/ianton-ru)).
|
* In composable protocols TLS layer accepted only `certificateFile` and `privateKeyFile` parameters. https://clickhouse.com/docs/en/operations/settings/composable-protocols. [#63985](https://github.com/ClickHouse/ClickHouse/pull/63985) ([Anton Ivashkin](https://github.com/ianton-ru)).
|
||||||
* Added profile event `SelectQueriesWithPrimaryKeyUsage` which indicates how many SELECT queries use the primary key to evaluate the WHERE clause. [#64492](https://github.com/ClickHouse/ClickHouse/pull/64492) ([0x01f](https://github.com/0xfei)).
|
* Added profile event `SelectQueriesWithPrimaryKeyUsage` which indicates how many SELECT queries use the primary key to evaluate the WHERE clause. [#64492](https://github.com/ClickHouse/ClickHouse/pull/64492) ([0x01f](https://github.com/0xfei)).
|
||||||
@ -71,7 +72,6 @@
|
|||||||
* Support aliases in parametrized view function (only new analyzer). [#65190](https://github.com/ClickHouse/ClickHouse/pull/65190) ([Kseniia Sumarokova](https://github.com/kssenii)).
|
* Support aliases in parametrized view function (only new analyzer). [#65190](https://github.com/ClickHouse/ClickHouse/pull/65190) ([Kseniia Sumarokova](https://github.com/kssenii)).
|
||||||
* Updated to mask account key in logs in azureBlobStorage. [#65273](https://github.com/ClickHouse/ClickHouse/pull/65273) ([SmitaRKulkarni](https://github.com/SmitaRKulkarni)).
|
* Updated to mask account key in logs in azureBlobStorage. [#65273](https://github.com/ClickHouse/ClickHouse/pull/65273) ([SmitaRKulkarni](https://github.com/SmitaRKulkarni)).
|
||||||
* Partition pruning for `IN` predicates when filter expression is a part of `PARTITION BY` expression. [#65335](https://github.com/ClickHouse/ClickHouse/pull/65335) ([Eduard Karacharov](https://github.com/korowa)).
|
* Partition pruning for `IN` predicates when filter expression is a part of `PARTITION BY` expression. [#65335](https://github.com/ClickHouse/ClickHouse/pull/65335) ([Eduard Karacharov](https://github.com/korowa)).
|
||||||
* Add system tables with main information about all detached tables. [#65400](https://github.com/ClickHouse/ClickHouse/pull/65400) ([Konstantin Morozov](https://github.com/k-morozov)).
|
|
||||||
* `arrayMin`/`arrayMax` can be applicable to all data types that are comparable. [#65455](https://github.com/ClickHouse/ClickHouse/pull/65455) ([pn](https://github.com/chloro-pn)).
|
* `arrayMin`/`arrayMax` can be applicable to all data types that are comparable. [#65455](https://github.com/ClickHouse/ClickHouse/pull/65455) ([pn](https://github.com/chloro-pn)).
|
||||||
* Improved memory accounting for cgroups v2 to exclude the amount occupied by the page cache. [#65470](https://github.com/ClickHouse/ClickHouse/pull/65470) ([Nikita Taranov](https://github.com/nickitat)).
|
* Improved memory accounting for cgroups v2 to exclude the amount occupied by the page cache. [#65470](https://github.com/ClickHouse/ClickHouse/pull/65470) ([Nikita Taranov](https://github.com/nickitat)).
|
||||||
* Do not create format settings for each row when serializing chunks to insert to EmbeddedRocksDB table. [#65474](https://github.com/ClickHouse/ClickHouse/pull/65474) ([Duc Canh Le](https://github.com/canhld94)).
|
* Do not create format settings for each row when serializing chunks to insert to EmbeddedRocksDB table. [#65474](https://github.com/ClickHouse/ClickHouse/pull/65474) ([Duc Canh Le](https://github.com/canhld94)).
|
||||||
@ -80,36 +80,35 @@
|
|||||||
* Disable filesystem cache background download by default. It will be enabled back when we fix the issue with possible "Memory limit exceeded" because memory deallocation is done outside of query context (while buffer is allocated inside of query context) if we use background download threads. Plus we need to add a separate setting to define max size to download for background workers (currently it is limited by max_file_segment_size, which might be too big). [#65534](https://github.com/ClickHouse/ClickHouse/pull/65534) ([Kseniia Sumarokova](https://github.com/kssenii)).
|
* Disable filesystem cache background download by default. It will be enabled back when we fix the issue with possible "Memory limit exceeded" because memory deallocation is done outside of query context (while buffer is allocated inside of query context) if we use background download threads. Plus we need to add a separate setting to define max size to download for background workers (currently it is limited by max_file_segment_size, which might be too big). [#65534](https://github.com/ClickHouse/ClickHouse/pull/65534) ([Kseniia Sumarokova](https://github.com/kssenii)).
|
||||||
* Add new option to config `<config_reload_interval_ms>` which allow to specify how often clickhouse will reload config. [#65545](https://github.com/ClickHouse/ClickHouse/pull/65545) ([alesapin](https://github.com/alesapin)).
|
* Add new option to config `<config_reload_interval_ms>` which allow to specify how often clickhouse will reload config. [#65545](https://github.com/ClickHouse/ClickHouse/pull/65545) ([alesapin](https://github.com/alesapin)).
|
||||||
* Implement binary encoding for ClickHouse data types and add its specification in docs. Use it in Dynamic binary serialization, allow to use it in RowBinaryWithNamesAndTypes and Native formats under settings. [#65546](https://github.com/ClickHouse/ClickHouse/pull/65546) ([Kruglov Pavel](https://github.com/Avogar)).
|
* Implement binary encoding for ClickHouse data types and add its specification in docs. Use it in Dynamic binary serialization, allow to use it in RowBinaryWithNamesAndTypes and Native formats under settings. [#65546](https://github.com/ClickHouse/ClickHouse/pull/65546) ([Kruglov Pavel](https://github.com/Avogar)).
|
||||||
* Improved ZooKeeper load balancing. The current session doesn't expire until the optimal nodes become available despite `fallback_session_lifetime`. Added support for AZ-aware balancing. [#65570](https://github.com/ClickHouse/ClickHouse/pull/65570) ([Alexander Tokmakov](https://github.com/tavplubix)).
|
|
||||||
* Server settings `compiled_expression_cache_size` and `compiled_expression_cache_elements_size` are now shown in `system.server_settings`. [#65584](https://github.com/ClickHouse/ClickHouse/pull/65584) ([Robert Schulze](https://github.com/rschu1ze)).
|
* Server settings `compiled_expression_cache_size` and `compiled_expression_cache_elements_size` are now shown in `system.server_settings`. [#65584](https://github.com/ClickHouse/ClickHouse/pull/65584) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
* Add support for user identification based on x509 SubjectAltName extension. [#65626](https://github.com/ClickHouse/ClickHouse/pull/65626) ([Anton Kozlov](https://github.com/tonickkozlov)).
|
* Add support for user identification based on x509 SubjectAltName extension. [#65626](https://github.com/ClickHouse/ClickHouse/pull/65626) ([Anton Kozlov](https://github.com/tonickkozlov)).
|
||||||
* `clickhouse-local` will respect the `max_server_memory_usage` and `max_server_memory_usage_to_ram_ratio` from the configuration file. It will also set the max memory usage to 90% of the system memory by default, like `clickhouse-server` does. [#65697](https://github.com/ClickHouse/ClickHouse/pull/65697) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
* `clickhouse-local` will respect the `max_server_memory_usage` and `max_server_memory_usage_to_ram_ratio` from the configuration file. It will also set the max memory usage to 90% of the system memory by default, like `clickhouse-server` does. [#65697](https://github.com/ClickHouse/ClickHouse/pull/65697) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
* Add a script to backup your files to ClickHouse. [#65699](https://github.com/ClickHouse/ClickHouse/pull/65699) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
* Add a script to backup your files to ClickHouse. [#65699](https://github.com/ClickHouse/ClickHouse/pull/65699) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
* PostgreSQL source support cancel. [#65722](https://github.com/ClickHouse/ClickHouse/pull/65722) ([Maksim Kita](https://github.com/kitaisreal)).
|
* PostgreSQL source to support query cancellations. [#65722](https://github.com/ClickHouse/ClickHouse/pull/65722) ([Maksim Kita](https://github.com/kitaisreal)).
|
||||||
* Make allow_experimental_analyzer be controlled by the initiator for distributed queries. This ensures compatibility and correctness during operations in mixed version clusters. [#65777](https://github.com/ClickHouse/ClickHouse/pull/65777) ([Nikita Mikhaylov](https://github.com/nikitamikhaylov)).
|
* Make `allow_experimental_analyzer` be controlled by the initiator for distributed queries. This ensures compatibility and correctness during operations in mixed version clusters. [#65777](https://github.com/ClickHouse/ClickHouse/pull/65777) ([Nikita Mikhaylov](https://github.com/nikitamikhaylov)).
|
||||||
* Respect cgroup CPU limit in Keeper. [#65819](https://github.com/ClickHouse/ClickHouse/pull/65819) ([Antonio Andelic](https://github.com/antonio2368)).
|
* Respect cgroup CPU limit in Keeper. [#65819](https://github.com/ClickHouse/ClickHouse/pull/65819) ([Antonio Andelic](https://github.com/antonio2368)).
|
||||||
* Allow to use `concat` function with empty arguments ``` sql :) select concat();. [#65887](https://github.com/ClickHouse/ClickHouse/pull/65887) ([李扬](https://github.com/taiyang-li)).
|
* Allow to use `concat` function with empty arguments `:) select concat();`. [#65887](https://github.com/ClickHouse/ClickHouse/pull/65887) ([李扬](https://github.com/taiyang-li)).
|
||||||
* Allow controlling named collections in clickhouse-local. [#65973](https://github.com/ClickHouse/ClickHouse/pull/65973) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
* Allow controlling named collections in `clickhouse-local`. [#65973](https://github.com/ClickHouse/ClickHouse/pull/65973) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
* Improve Azure profile events. [#65999](https://github.com/ClickHouse/ClickHouse/pull/65999) ([alesapin](https://github.com/alesapin)).
|
* Improve Azure-related profile events. [#65999](https://github.com/ClickHouse/ClickHouse/pull/65999) ([alesapin](https://github.com/alesapin)).
|
||||||
* Support ORC file read by writer time zone. [#66025](https://github.com/ClickHouse/ClickHouse/pull/66025) ([kevinyhzou](https://github.com/KevinyhZou)).
|
* Support ORC file read by writer's time zone. [#66025](https://github.com/ClickHouse/ClickHouse/pull/66025) ([kevinyhzou](https://github.com/KevinyhZou)).
|
||||||
* Add settings to control connection to the PostgreSQL. * Setting `postgresql_connection_attempt_timeout` specifies the value passed to `connect_timeout` parameter of connection URL. * Setting `postgresql_connection_pool_retries` specifies the number of retries to establish a connection to the PostgreSQL end-point. [#66232](https://github.com/ClickHouse/ClickHouse/pull/66232) ([Dmitry Novik](https://github.com/novikd)).
|
* Add settings to control connections to PostgreSQL. The setting `postgresql_connection_attempt_timeout` specifies the value passed to `connect_timeout` parameter of connection URL. The setting `postgresql_connection_pool_retries` specifies the number of retries to establish a connection to the PostgreSQL end-point. [#66232](https://github.com/ClickHouse/ClickHouse/pull/66232) ([Dmitry Novik](https://github.com/novikd)).
|
||||||
* Reduce inaccuracy of input_wait_elapsed_us/input_wait_elapsed_us/elapsed_us. [#66239](https://github.com/ClickHouse/ClickHouse/pull/66239) ([Azat Khuzhin](https://github.com/azat)).
|
* Reduce inaccuracy of `input_wait_elapsed_us`/`elapsed_us` in the `system.processors_profile_log`. [#66239](https://github.com/ClickHouse/ClickHouse/pull/66239) ([Azat Khuzhin](https://github.com/azat)).
|
||||||
* Improve FilesystemCache ProfileEvents. [#66249](https://github.com/ClickHouse/ClickHouse/pull/66249) ([zhukai](https://github.com/nauu)).
|
* Improve ProfileEvents for the filesystem cache. [#66249](https://github.com/ClickHouse/ClickHouse/pull/66249) ([zhukai](https://github.com/nauu)).
|
||||||
* Add settings to ignore ON CLUSTER clause in queries for named collection management with replicated storage. [#66288](https://github.com/ClickHouse/ClickHouse/pull/66288) ([MikhailBurdukov](https://github.com/MikhailBurdukov)).
|
* Add settings to ignore the `ON CLUSTER` clause in queries for named collection management with the replicated storage. [#66288](https://github.com/ClickHouse/ClickHouse/pull/66288) ([MikhailBurdukov](https://github.com/MikhailBurdukov)).
|
||||||
* Function `generateSnowflakeID` now allows to specify a machine ID as a parameter to prevent collisions in large clusters. [#66374](https://github.com/ClickHouse/ClickHouse/pull/66374) ([ZAWA_ll](https://github.com/Zawa-ll)).
|
* Function `generateSnowflakeID` now allows to specify a machine ID as a parameter to prevent collisions in large clusters. [#66374](https://github.com/ClickHouse/ClickHouse/pull/66374) ([ZAWA_ll](https://github.com/Zawa-ll)).
|
||||||
* Disable suspending on Ctrl+Z in interactive mode. This is a common trap and is not expected behavior for almost all users. I imagine only a few extreme power users could appreciate suspending terminal applications to the background, but I don't know any. [#66511](https://github.com/ClickHouse/ClickHouse/pull/66511) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
* Disable suspending on `Ctrl+Z` in interactive mode. This is a common trap and is not expected behavior for almost all users. I imagine only a few extreme power users could appreciate suspending terminal applications to the background, but I don't know any. [#66511](https://github.com/ClickHouse/ClickHouse/pull/66511) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
* Add option for validating the Primary key type in Dictionaries. Without this option for simple layouts any column type will be implicitly converted to UInt64. ### Documentation entry for user-facing changes. [#66595](https://github.com/ClickHouse/ClickHouse/pull/66595) ([MikhailBurdukov](https://github.com/MikhailBurdukov)).
|
* Add option for validating the primary key type in Dictionaries. Without this option for simple layouts any column type will be implicitly converted to UInt64. [#66595](https://github.com/ClickHouse/ClickHouse/pull/66595) ([MikhailBurdukov](https://github.com/MikhailBurdukov)).
|
||||||
|
|
||||||
#### Bug Fix (user-visible misbehavior in an official stable release)
|
#### Bug Fix (user-visible misbehavior in an official stable release)
|
||||||
* Fix unexpected size of low cardinality column in function calls. [#65298](https://github.com/ClickHouse/ClickHouse/pull/65298) ([Raúl Marín](https://github.com/Algunenano)).
|
|
||||||
* Check cyclic dependencies on CREATE/REPLACE/RENAME/EXCHANGE queries and throw an exception if there is a cyclic dependency. Previously such cyclic dependencies could lead to a deadlock during server startup. Also fix some bugs in dependencies creation. [#65405](https://github.com/ClickHouse/ClickHouse/pull/65405) ([Kruglov Pavel](https://github.com/Avogar)).
|
* Check cyclic dependencies on CREATE/REPLACE/RENAME/EXCHANGE queries and throw an exception if there is a cyclic dependency. Previously such cyclic dependencies could lead to a deadlock during server startup. Also fix some bugs in dependencies creation. [#65405](https://github.com/ClickHouse/ClickHouse/pull/65405) ([Kruglov Pavel](https://github.com/Avogar)).
|
||||||
|
* Fix unexpected sizes of `LowCardinality` columns in function calls. [#65298](https://github.com/ClickHouse/ClickHouse/pull/65298) ([Raúl Marín](https://github.com/Algunenano)).
|
||||||
* Fix crash in maxIntersections. [#65689](https://github.com/ClickHouse/ClickHouse/pull/65689) ([Raúl Marín](https://github.com/Algunenano)).
|
* Fix crash in maxIntersections. [#65689](https://github.com/ClickHouse/ClickHouse/pull/65689) ([Raúl Marín](https://github.com/Algunenano)).
|
||||||
* Fix the VALID UNTIL clause in the user definition resetting after a restart. [#66409](https://github.com/ClickHouse/ClickHouse/pull/66409) ([Nikolay Degterinsky](https://github.com/evillique)).
|
* Fix the `VALID UNTIL` clause in the user definition resetting after a restart. [#66409](https://github.com/ClickHouse/ClickHouse/pull/66409) ([Nikolay Degterinsky](https://github.com/evillique)).
|
||||||
* Fix SHOW MERGES remaining time. [#66735](https://github.com/ClickHouse/ClickHouse/pull/66735) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
* Fix the remaining time column in `SHOW MERGES`. [#66735](https://github.com/ClickHouse/ClickHouse/pull/66735) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
* `Query was cancelled` might have been printed twice in clickhouse-client. This behaviour is fixed. [#66005](https://github.com/ClickHouse/ClickHouse/pull/66005) ([Nikita Mikhaylov](https://github.com/nikitamikhaylov)).
|
* `Query was cancelled` might have been printed twice in clickhouse-client. This behaviour is fixed. [#66005](https://github.com/ClickHouse/ClickHouse/pull/66005) ([Nikita Mikhaylov](https://github.com/nikitamikhaylov)).
|
||||||
* Fixed crash while using MaterializedMySQL with TABLE OVERRIDE that maps MySQL NULL field into ClickHouse not NULL field. [#54649](https://github.com/ClickHouse/ClickHouse/pull/54649) ([Filipp Ozinov](https://github.com/bakwc)).
|
* Fixed crash while using `MaterializedMySQL` (which is an unsupported, experimental feature) with TABLE OVERRIDE that maps MySQL NULL field into ClickHouse not NULL field. [#54649](https://github.com/ClickHouse/ClickHouse/pull/54649) ([Filipp Ozinov](https://github.com/bakwc)).
|
||||||
* Fix logical error when PREWHERE expression read no columns and table has no adaptive index granularity (very old table). [#59173](https://github.com/ClickHouse/ClickHouse/pull/59173) ([Alexander Gololobov](https://github.com/davenger)).
|
* Fix logical error when `PREWHERE` expression read no columns and table has no adaptive index granularity (very old table). [#59173](https://github.com/ClickHouse/ClickHouse/pull/59173) ([Alexander Gololobov](https://github.com/davenger)).
|
||||||
* Fix bug with cancellation buffer when canceling a query. [#64478](https://github.com/ClickHouse/ClickHouse/pull/64478) ([Sema Checherinda](https://github.com/CheSema)).
|
* Fix bug with the cancellation buffer when canceling a query. [#64478](https://github.com/ClickHouse/ClickHouse/pull/64478) ([Sema Checherinda](https://github.com/CheSema)).
|
||||||
* Fix filling parts columns from metadata (when columns.txt does not exists). [#64757](https://github.com/ClickHouse/ClickHouse/pull/64757) ([Azat Khuzhin](https://github.com/azat)).
|
* Fix filling parts columns from metadata (when columns.txt does not exists). [#64757](https://github.com/ClickHouse/ClickHouse/pull/64757) ([Azat Khuzhin](https://github.com/azat)).
|
||||||
* Fix crash for `ALTER TABLE ... ON CLUSTER ... MODIFY SQL SECURITY`. [#64957](https://github.com/ClickHouse/ClickHouse/pull/64957) ([pufit](https://github.com/pufit)).
|
* Fix crash for `ALTER TABLE ... ON CLUSTER ... MODIFY SQL SECURITY`. [#64957](https://github.com/ClickHouse/ClickHouse/pull/64957) ([pufit](https://github.com/pufit)).
|
||||||
* Fix crash on destroying AccessControl: add explicit shutdown. [#64993](https://github.com/ClickHouse/ClickHouse/pull/64993) ([Vitaly Baranov](https://github.com/vitlibar)).
|
* Fix crash on destroying AccessControl: add explicit shutdown. [#64993](https://github.com/ClickHouse/ClickHouse/pull/64993) ([Vitaly Baranov](https://github.com/vitlibar)).
|
||||||
@ -156,7 +155,7 @@
|
|||||||
* Fixed how the ClickHouse server detects the maximum number of usable CPU cores as specified by cgroups v2 if the server runs in a container such as Docker. In more detail, containers often run their process in the root cgroup which has an empty name. In that case, ClickHouse ignored the CPU limits set by cgroups v2. [#66237](https://github.com/ClickHouse/ClickHouse/pull/66237) ([filimonov](https://github.com/filimonov)).
|
* Fixed how the ClickHouse server detects the maximum number of usable CPU cores as specified by cgroups v2 if the server runs in a container such as Docker. In more detail, containers often run their process in the root cgroup which has an empty name. In that case, ClickHouse ignored the CPU limits set by cgroups v2. [#66237](https://github.com/ClickHouse/ClickHouse/pull/66237) ([filimonov](https://github.com/filimonov)).
|
||||||
* Fix the `Not-ready set` error when a subquery with `IN` is used in the constraint. [#66261](https://github.com/ClickHouse/ClickHouse/pull/66261) ([Nikolai Kochetov](https://github.com/KochetovNicolai)).
|
* Fix the `Not-ready set` error when a subquery with `IN` is used in the constraint. [#66261](https://github.com/ClickHouse/ClickHouse/pull/66261) ([Nikolai Kochetov](https://github.com/KochetovNicolai)).
|
||||||
* Fix error reporting while copying to S3 or AzureBlobStorage. [#66295](https://github.com/ClickHouse/ClickHouse/pull/66295) ([Vitaly Baranov](https://github.com/vitlibar)).
|
* Fix error reporting while copying to S3 or AzureBlobStorage. [#66295](https://github.com/ClickHouse/ClickHouse/pull/66295) ([Vitaly Baranov](https://github.com/vitlibar)).
|
||||||
* Prevent watchdog from keeping descriptors of unlinked(rotated) log files. [#66334](https://github.com/ClickHouse/ClickHouse/pull/66334) ([Aleksei Filatov](https://github.com/aalexfvk)).
|
* Prevent watchdog from keeping descriptors of unlinked (rotated) log files. [#66334](https://github.com/ClickHouse/ClickHouse/pull/66334) ([Aleksei Filatov](https://github.com/aalexfvk)).
|
||||||
* Fix the bug that logicalexpressionoptimizerpass lost logical type of constant. [#66344](https://github.com/ClickHouse/ClickHouse/pull/66344) ([pn](https://github.com/chloro-pn)).
|
* Fix the bug that logicalexpressionoptimizerpass lost logical type of constant. [#66344](https://github.com/ClickHouse/ClickHouse/pull/66344) ([pn](https://github.com/chloro-pn)).
|
||||||
* Fix `Column identifier is already registered` error with `group_by_use_nulls=true` and new analyzer. [#66400](https://github.com/ClickHouse/ClickHouse/pull/66400) ([Nikolai Kochetov](https://github.com/KochetovNicolai)).
|
* Fix `Column identifier is already registered` error with `group_by_use_nulls=true` and new analyzer. [#66400](https://github.com/ClickHouse/ClickHouse/pull/66400) ([Nikolai Kochetov](https://github.com/KochetovNicolai)).
|
||||||
* Fix possible incorrect result for queries joining and filtering table external engine (like PostgreSQL), due to too aggressive filter pushdown. Since now, conditions from where section won't be send to external database in case of outer join with external table. [#66402](https://github.com/ClickHouse/ClickHouse/pull/66402) ([vdimir](https://github.com/vdimir)).
|
* Fix possible incorrect result for queries joining and filtering table external engine (like PostgreSQL), due to too aggressive filter pushdown. Since now, conditions from where section won't be send to external database in case of outer join with external table. [#66402](https://github.com/ClickHouse/ClickHouse/pull/66402) ([vdimir](https://github.com/vdimir)).
|
||||||
@ -178,9 +177,6 @@
|
|||||||
* Fix `indexHint` function case found by fuzzer. [#66286](https://github.com/ClickHouse/ClickHouse/pull/66286) ([Anton Popov](https://github.com/CurtizJ)).
|
* Fix `indexHint` function case found by fuzzer. [#66286](https://github.com/ClickHouse/ClickHouse/pull/66286) ([Anton Popov](https://github.com/CurtizJ)).
|
||||||
* Fix AST formatting of 'create table b empty as a'. [#64951](https://github.com/ClickHouse/ClickHouse/pull/64951) ([Michael Kolupaev](https://github.com/al13n321)).
|
* Fix AST formatting of 'create table b empty as a'. [#64951](https://github.com/ClickHouse/ClickHouse/pull/64951) ([Michael Kolupaev](https://github.com/al13n321)).
|
||||||
|
|
||||||
#### Build/Testing/Packaging Improvement
|
|
||||||
* Instantiate template methods ahead in different .cpp files, avoid too large translation units during compiling. [#64818](https://github.com/ClickHouse/ClickHouse/pull/64818) ([lgbo](https://github.com/lgbo-ustc)).
|
|
||||||
|
|
||||||
### <a id="246"></a> ClickHouse release 24.6, 2024-07-01
|
### <a id="246"></a> ClickHouse release 24.6, 2024-07-01
|
||||||
|
|
||||||
#### Backward Incompatible Change
|
#### Backward Incompatible Change
|
||||||
|
@ -14,9 +14,10 @@ The following versions of ClickHouse server are currently supported with securit
|
|||||||
|
|
||||||
| Version | Supported |
|
| Version | Supported |
|
||||||
|:-|:-|
|
|:-|:-|
|
||||||
|
| 24.7 | ✔️ |
|
||||||
| 24.6 | ✔️ |
|
| 24.6 | ✔️ |
|
||||||
| 24.5 | ✔️ |
|
| 24.5 | ✔️ |
|
||||||
| 24.4 | ✔️ |
|
| 24.4 | ❌ |
|
||||||
| 24.3 | ✔️ |
|
| 24.3 | ✔️ |
|
||||||
| 24.2 | ❌ |
|
| 24.2 | ❌ |
|
||||||
| 24.1 | ❌ |
|
| 24.1 | ❌ |
|
||||||
|
@ -261,6 +261,11 @@ namespace Util
|
|||||||
///
|
///
|
||||||
/// Throws a NullPointerException if no Application instance exists.
|
/// Throws a NullPointerException if no Application instance exists.
|
||||||
|
|
||||||
|
static Application * instanceRawPtr();
|
||||||
|
/// Returns a raw pointer to the Application singleton.
|
||||||
|
///
|
||||||
|
/// The caller should check whether the result is nullptr.
|
||||||
|
|
||||||
const Poco::Timestamp & startTime() const;
|
const Poco::Timestamp & startTime() const;
|
||||||
/// Returns the application start time (UTC).
|
/// Returns the application start time (UTC).
|
||||||
|
|
||||||
@ -448,6 +453,12 @@ namespace Util
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
inline Application * Application::instanceRawPtr()
|
||||||
|
{
|
||||||
|
return _pInstance;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
inline const Poco::Timestamp & Application::startTime() const
|
inline const Poco::Timestamp & Application::startTime() const
|
||||||
{
|
{
|
||||||
return _startTime;
|
return _startTime;
|
||||||
|
2
contrib/azure
vendored
2
contrib/azure
vendored
@ -1 +1 @@
|
|||||||
Subproject commit ea3e19a7be08519134c643177d56c7484dfec884
|
Subproject commit 67272b7ee0adff6b69921b26eb071ba1a353062c
|
2
contrib/rocksdb
vendored
2
contrib/rocksdb
vendored
@ -1 +1 @@
|
|||||||
Subproject commit be366233921293bd07a84dc4ea6991858665f202
|
Subproject commit 01e43568fa9f3f7bf107b2b66c00b286b456f33e
|
@ -5,6 +5,9 @@ if (NOT ENABLE_ROCKSDB)
|
|||||||
return()
|
return()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
# not in original build system, otherwise xxHash.cc fails to compile with ClickHouse C++23 default
|
||||||
|
set (CMAKE_CXX_STANDARD 20)
|
||||||
|
|
||||||
# Always disable jemalloc for rocksdb by default because it introduces non-standard jemalloc APIs
|
# Always disable jemalloc for rocksdb by default because it introduces non-standard jemalloc APIs
|
||||||
option(WITH_JEMALLOC "build with JeMalloc" OFF)
|
option(WITH_JEMALLOC "build with JeMalloc" OFF)
|
||||||
|
|
||||||
@ -16,14 +19,6 @@ option(WITH_LZ4 "build with lz4" ON)
|
|||||||
option(WITH_ZLIB "build with zlib" ON)
|
option(WITH_ZLIB "build with zlib" ON)
|
||||||
option(WITH_ZSTD "build with zstd" ON)
|
option(WITH_ZSTD "build with zstd" ON)
|
||||||
|
|
||||||
# third-party/folly is only validated to work on Linux and Windows for now.
|
|
||||||
# So only turn it on there by default.
|
|
||||||
if(CMAKE_SYSTEM_NAME MATCHES "Linux|Windows")
|
|
||||||
option(WITH_FOLLY_DISTRIBUTED_MUTEX "build with folly::DistributedMutex" ON)
|
|
||||||
else()
|
|
||||||
option(WITH_FOLLY_DISTRIBUTED_MUTEX "build with folly::DistributedMutex" OFF)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(WITH_SNAPPY)
|
if(WITH_SNAPPY)
|
||||||
add_definitions(-DSNAPPY)
|
add_definitions(-DSNAPPY)
|
||||||
list(APPEND THIRDPARTY_LIBS ch_contrib::snappy)
|
list(APPEND THIRDPARTY_LIBS ch_contrib::snappy)
|
||||||
@ -44,7 +39,7 @@ if(WITH_ZSTD)
|
|||||||
list(APPEND THIRDPARTY_LIBS ch_contrib::zstd)
|
list(APPEND THIRDPARTY_LIBS ch_contrib::zstd)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
option(PORTABLE "build a portable binary" ON)
|
add_definitions(-DROCKSDB_PORTABLE)
|
||||||
|
|
||||||
if(ENABLE_SSE42 AND ENABLE_PCLMULQDQ)
|
if(ENABLE_SSE42 AND ENABLE_PCLMULQDQ)
|
||||||
add_definitions(-DHAVE_SSE42)
|
add_definitions(-DHAVE_SSE42)
|
||||||
@ -59,11 +54,6 @@ if(CMAKE_SYSTEM_PROCESSOR MATCHES "arm64|aarch64|AARCH64")
|
|||||||
# set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -march=armv8-a+crc+crypto -Wno-unused-function")
|
# set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -march=armv8-a+crc+crypto -Wno-unused-function")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
set (HAVE_THREAD_LOCAL 1)
|
|
||||||
if(HAVE_THREAD_LOCAL)
|
|
||||||
add_definitions(-DROCKSDB_SUPPORT_THREAD_LOCAL)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(CMAKE_SYSTEM_NAME MATCHES "Darwin")
|
if(CMAKE_SYSTEM_NAME MATCHES "Darwin")
|
||||||
add_definitions(-DOS_MACOSX)
|
add_definitions(-DOS_MACOSX)
|
||||||
elseif(CMAKE_SYSTEM_NAME MATCHES "Linux")
|
elseif(CMAKE_SYSTEM_NAME MATCHES "Linux")
|
||||||
@ -89,19 +79,21 @@ set(ROCKSDB_SOURCE_DIR "${ClickHouse_SOURCE_DIR}/contrib/rocksdb")
|
|||||||
|
|
||||||
include_directories(${ROCKSDB_SOURCE_DIR})
|
include_directories(${ROCKSDB_SOURCE_DIR})
|
||||||
include_directories("${ROCKSDB_SOURCE_DIR}/include")
|
include_directories("${ROCKSDB_SOURCE_DIR}/include")
|
||||||
if(WITH_FOLLY_DISTRIBUTED_MUTEX)
|
|
||||||
include_directories("${ROCKSDB_SOURCE_DIR}/third-party/folly")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
set(SOURCES
|
set(SOURCES
|
||||||
${ROCKSDB_SOURCE_DIR}/cache/cache.cc
|
${ROCKSDB_SOURCE_DIR}/cache/cache.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/cache/cache_entry_roles.cc
|
${ROCKSDB_SOURCE_DIR}/cache/cache_entry_roles.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/cache/cache_key.cc
|
${ROCKSDB_SOURCE_DIR}/cache/cache_key.cc
|
||||||
|
${ROCKSDB_SOURCE_DIR}/cache/cache_helpers.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/cache/cache_reservation_manager.cc
|
${ROCKSDB_SOURCE_DIR}/cache/cache_reservation_manager.cc
|
||||||
|
${ROCKSDB_SOURCE_DIR}/cache/charged_cache.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/cache/clock_cache.cc
|
${ROCKSDB_SOURCE_DIR}/cache/clock_cache.cc
|
||||||
|
${ROCKSDB_SOURCE_DIR}/cache/compressed_secondary_cache.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/cache/lru_cache.cc
|
${ROCKSDB_SOURCE_DIR}/cache/lru_cache.cc
|
||||||
|
${ROCKSDB_SOURCE_DIR}/cache/secondary_cache.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/cache/sharded_cache.cc
|
${ROCKSDB_SOURCE_DIR}/cache/sharded_cache.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/arena_wrapped_db_iter.cc
|
${ROCKSDB_SOURCE_DIR}/db/arena_wrapped_db_iter.cc
|
||||||
|
${ROCKSDB_SOURCE_DIR}/db/blob/blob_contents.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/blob/blob_fetcher.cc
|
${ROCKSDB_SOURCE_DIR}/db/blob/blob_fetcher.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/blob/blob_file_addition.cc
|
${ROCKSDB_SOURCE_DIR}/db/blob/blob_file_addition.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/blob/blob_file_builder.cc
|
${ROCKSDB_SOURCE_DIR}/db/blob/blob_file_builder.cc
|
||||||
@ -113,6 +105,7 @@ set(SOURCES
|
|||||||
${ROCKSDB_SOURCE_DIR}/db/blob/blob_log_format.cc
|
${ROCKSDB_SOURCE_DIR}/db/blob/blob_log_format.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/blob/blob_log_sequential_reader.cc
|
${ROCKSDB_SOURCE_DIR}/db/blob/blob_log_sequential_reader.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/blob/blob_log_writer.cc
|
${ROCKSDB_SOURCE_DIR}/db/blob/blob_log_writer.cc
|
||||||
|
${ROCKSDB_SOURCE_DIR}/db/blob/blob_source.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/blob/prefetch_buffer_collection.cc
|
${ROCKSDB_SOURCE_DIR}/db/blob/prefetch_buffer_collection.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/builder.cc
|
${ROCKSDB_SOURCE_DIR}/db/builder.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/c.cc
|
${ROCKSDB_SOURCE_DIR}/db/c.cc
|
||||||
@ -124,7 +117,11 @@ set(SOURCES
|
|||||||
${ROCKSDB_SOURCE_DIR}/db/compaction/compaction_picker_fifo.cc
|
${ROCKSDB_SOURCE_DIR}/db/compaction/compaction_picker_fifo.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/compaction/compaction_picker_level.cc
|
${ROCKSDB_SOURCE_DIR}/db/compaction/compaction_picker_level.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/compaction/compaction_picker_universal.cc
|
${ROCKSDB_SOURCE_DIR}/db/compaction/compaction_picker_universal.cc
|
||||||
|
${ROCKSDB_SOURCE_DIR}/db/compaction/compaction_service_job.cc
|
||||||
|
${ROCKSDB_SOURCE_DIR}/db/compaction/compaction_state.cc
|
||||||
|
${ROCKSDB_SOURCE_DIR}/db/compaction/compaction_outputs.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/compaction/sst_partitioner.cc
|
${ROCKSDB_SOURCE_DIR}/db/compaction/sst_partitioner.cc
|
||||||
|
${ROCKSDB_SOURCE_DIR}/db/compaction/subcompaction_state.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/convenience.cc
|
${ROCKSDB_SOURCE_DIR}/db/convenience.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/db_filesnapshot.cc
|
${ROCKSDB_SOURCE_DIR}/db/db_filesnapshot.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/db_impl/compacted_db_impl.cc
|
${ROCKSDB_SOURCE_DIR}/db/db_impl/compacted_db_impl.cc
|
||||||
@ -159,10 +156,11 @@ set(SOURCES
|
|||||||
${ROCKSDB_SOURCE_DIR}/db/merge_helper.cc
|
${ROCKSDB_SOURCE_DIR}/db/merge_helper.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/merge_operator.cc
|
${ROCKSDB_SOURCE_DIR}/db/merge_operator.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/output_validator.cc
|
${ROCKSDB_SOURCE_DIR}/db/output_validator.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/periodic_work_scheduler.cc
|
${ROCKSDB_SOURCE_DIR}/db/periodic_task_scheduler.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/range_del_aggregator.cc
|
${ROCKSDB_SOURCE_DIR}/db/range_del_aggregator.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/range_tombstone_fragmenter.cc
|
${ROCKSDB_SOURCE_DIR}/db/range_tombstone_fragmenter.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/repair.cc
|
${ROCKSDB_SOURCE_DIR}/db/repair.cc
|
||||||
|
${ROCKSDB_SOURCE_DIR}/db/seqno_to_time_mapping.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/snapshot_impl.cc
|
${ROCKSDB_SOURCE_DIR}/db/snapshot_impl.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/table_cache.cc
|
${ROCKSDB_SOURCE_DIR}/db/table_cache.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/table_properties_collector.cc
|
${ROCKSDB_SOURCE_DIR}/db/table_properties_collector.cc
|
||||||
@ -174,6 +172,8 @@ set(SOURCES
|
|||||||
${ROCKSDB_SOURCE_DIR}/db/version_set.cc
|
${ROCKSDB_SOURCE_DIR}/db/version_set.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/wal_edit.cc
|
${ROCKSDB_SOURCE_DIR}/db/wal_edit.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/wal_manager.cc
|
${ROCKSDB_SOURCE_DIR}/db/wal_manager.cc
|
||||||
|
${ROCKSDB_SOURCE_DIR}/db/wide/wide_column_serialization.cc
|
||||||
|
${ROCKSDB_SOURCE_DIR}/db/wide/wide_columns.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/write_batch.cc
|
${ROCKSDB_SOURCE_DIR}/db/write_batch.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/write_batch_base.cc
|
${ROCKSDB_SOURCE_DIR}/db/write_batch_base.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/db/write_controller.cc
|
${ROCKSDB_SOURCE_DIR}/db/write_controller.cc
|
||||||
@ -182,7 +182,6 @@ set(SOURCES
|
|||||||
${ROCKSDB_SOURCE_DIR}/env/env.cc
|
${ROCKSDB_SOURCE_DIR}/env/env.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/env/env_chroot.cc
|
${ROCKSDB_SOURCE_DIR}/env/env_chroot.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/env/env_encryption.cc
|
${ROCKSDB_SOURCE_DIR}/env/env_encryption.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/env/env_hdfs.cc
|
|
||||||
${ROCKSDB_SOURCE_DIR}/env/file_system.cc
|
${ROCKSDB_SOURCE_DIR}/env/file_system.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/env/file_system_tracer.cc
|
${ROCKSDB_SOURCE_DIR}/env/file_system_tracer.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/env/fs_remap.cc
|
${ROCKSDB_SOURCE_DIR}/env/fs_remap.cc
|
||||||
@ -233,16 +232,17 @@ set(SOURCES
|
|||||||
${ROCKSDB_SOURCE_DIR}/options/options.cc
|
${ROCKSDB_SOURCE_DIR}/options/options.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/options/options_helper.cc
|
${ROCKSDB_SOURCE_DIR}/options/options_helper.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/options/options_parser.cc
|
${ROCKSDB_SOURCE_DIR}/options/options_parser.cc
|
||||||
|
${ROCKSDB_SOURCE_DIR}/port/mmap.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/port/stack_trace.cc
|
${ROCKSDB_SOURCE_DIR}/port/stack_trace.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/table/adaptive/adaptive_table_factory.cc
|
${ROCKSDB_SOURCE_DIR}/table/adaptive/adaptive_table_factory.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/table/block_based/binary_search_index_reader.cc
|
${ROCKSDB_SOURCE_DIR}/table/block_based/binary_search_index_reader.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/table/block_based/block.cc
|
${ROCKSDB_SOURCE_DIR}/table/block_based/block.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/table/block_based/block_based_filter_block.cc
|
|
||||||
${ROCKSDB_SOURCE_DIR}/table/block_based/block_based_table_builder.cc
|
${ROCKSDB_SOURCE_DIR}/table/block_based/block_based_table_builder.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/table/block_based/block_based_table_factory.cc
|
${ROCKSDB_SOURCE_DIR}/table/block_based/block_based_table_factory.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/table/block_based/block_based_table_iterator.cc
|
${ROCKSDB_SOURCE_DIR}/table/block_based/block_based_table_iterator.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/table/block_based/block_based_table_reader.cc
|
${ROCKSDB_SOURCE_DIR}/table/block_based/block_based_table_reader.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/table/block_based/block_builder.cc
|
${ROCKSDB_SOURCE_DIR}/table/block_based/block_builder.cc
|
||||||
|
${ROCKSDB_SOURCE_DIR}/table/block_based/block_cache.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/table/block_based/block_prefetcher.cc
|
${ROCKSDB_SOURCE_DIR}/table/block_based/block_prefetcher.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/table/block_based/block_prefix_index.cc
|
${ROCKSDB_SOURCE_DIR}/table/block_based/block_prefix_index.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/table/block_based/data_block_hash_index.cc
|
${ROCKSDB_SOURCE_DIR}/table/block_based/data_block_hash_index.cc
|
||||||
@ -300,9 +300,12 @@ set(SOURCES
|
|||||||
${ROCKSDB_SOURCE_DIR}/trace_replay/trace_record_result.cc
|
${ROCKSDB_SOURCE_DIR}/trace_replay/trace_record_result.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/trace_replay/trace_record.cc
|
${ROCKSDB_SOURCE_DIR}/trace_replay/trace_record.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/trace_replay/trace_replay.cc
|
${ROCKSDB_SOURCE_DIR}/trace_replay/trace_replay.cc
|
||||||
|
${ROCKSDB_SOURCE_DIR}/util/async_file_reader.cc
|
||||||
|
${ROCKSDB_SOURCE_DIR}/util/cleanable.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/util/coding.cc
|
${ROCKSDB_SOURCE_DIR}/util/coding.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/util/compaction_job_stats_impl.cc
|
${ROCKSDB_SOURCE_DIR}/util/compaction_job_stats_impl.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/util/comparator.cc
|
${ROCKSDB_SOURCE_DIR}/util/comparator.cc
|
||||||
|
${ROCKSDB_SOURCE_DIR}/util/compression.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/util/compression_context_cache.cc
|
${ROCKSDB_SOURCE_DIR}/util/compression_context_cache.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/util/concurrent_task_limiter_impl.cc
|
${ROCKSDB_SOURCE_DIR}/util/concurrent_task_limiter_impl.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/util/crc32c.cc
|
${ROCKSDB_SOURCE_DIR}/util/crc32c.cc
|
||||||
@ -311,16 +314,17 @@ set(SOURCES
|
|||||||
${ROCKSDB_SOURCE_DIR}/util/murmurhash.cc
|
${ROCKSDB_SOURCE_DIR}/util/murmurhash.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/util/random.cc
|
${ROCKSDB_SOURCE_DIR}/util/random.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/util/rate_limiter.cc
|
${ROCKSDB_SOURCE_DIR}/util/rate_limiter.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/util/regex.cc
|
|
||||||
${ROCKSDB_SOURCE_DIR}/util/ribbon_config.cc
|
${ROCKSDB_SOURCE_DIR}/util/ribbon_config.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/util/slice.cc
|
${ROCKSDB_SOURCE_DIR}/util/slice.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/util/file_checksum_helper.cc
|
${ROCKSDB_SOURCE_DIR}/util/file_checksum_helper.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/util/status.cc
|
${ROCKSDB_SOURCE_DIR}/util/status.cc
|
||||||
|
${ROCKSDB_SOURCE_DIR}/util/stderr_logger.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/util/string_util.cc
|
${ROCKSDB_SOURCE_DIR}/util/string_util.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/util/thread_local.cc
|
${ROCKSDB_SOURCE_DIR}/util/thread_local.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/util/threadpool_imp.cc
|
${ROCKSDB_SOURCE_DIR}/util/threadpool_imp.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/util/xxhash.cc
|
${ROCKSDB_SOURCE_DIR}/util/xxhash.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/utilities/backupable/backupable_db.cc
|
${ROCKSDB_SOURCE_DIR}/utilities/agg_merge/agg_merge.cc
|
||||||
|
${ROCKSDB_SOURCE_DIR}/utilities/backup/backup_engine.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/utilities/blob_db/blob_compaction_filter.cc
|
${ROCKSDB_SOURCE_DIR}/utilities/blob_db/blob_compaction_filter.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/utilities/blob_db/blob_db.cc
|
${ROCKSDB_SOURCE_DIR}/utilities/blob_db/blob_db.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/utilities/blob_db/blob_db_impl.cc
|
${ROCKSDB_SOURCE_DIR}/utilities/blob_db/blob_db_impl.cc
|
||||||
@ -335,6 +339,7 @@ set(SOURCES
|
|||||||
${ROCKSDB_SOURCE_DIR}/utilities/checkpoint/checkpoint_impl.cc
|
${ROCKSDB_SOURCE_DIR}/utilities/checkpoint/checkpoint_impl.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/utilities/compaction_filters.cc
|
${ROCKSDB_SOURCE_DIR}/utilities/compaction_filters.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/utilities/compaction_filters/remove_emptyvalue_compactionfilter.cc
|
${ROCKSDB_SOURCE_DIR}/utilities/compaction_filters/remove_emptyvalue_compactionfilter.cc
|
||||||
|
${ROCKSDB_SOURCE_DIR}/utilities/counted_fs.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/utilities/debug.cc
|
${ROCKSDB_SOURCE_DIR}/utilities/debug.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/utilities/env_mirror.cc
|
${ROCKSDB_SOURCE_DIR}/utilities/env_mirror.cc
|
||||||
${ROCKSDB_SOURCE_DIR}/utilities/env_timed.cc
|
${ROCKSDB_SOURCE_DIR}/utilities/env_timed.cc
|
||||||
@ -422,15 +427,6 @@ list(APPEND SOURCES
|
|||||||
"${ROCKSDB_SOURCE_DIR}/env/fs_posix.cc"
|
"${ROCKSDB_SOURCE_DIR}/env/fs_posix.cc"
|
||||||
"${ROCKSDB_SOURCE_DIR}/env/io_posix.cc")
|
"${ROCKSDB_SOURCE_DIR}/env/io_posix.cc")
|
||||||
|
|
||||||
if(WITH_FOLLY_DISTRIBUTED_MUTEX)
|
|
||||||
list(APPEND SOURCES
|
|
||||||
"${ROCKSDB_SOURCE_DIR}/third-party/folly/folly/detail/Futex.cpp"
|
|
||||||
"${ROCKSDB_SOURCE_DIR}/third-party/folly/folly/synchronization/AtomicNotification.cpp"
|
|
||||||
"${ROCKSDB_SOURCE_DIR}/third-party/folly/folly/synchronization/DistributedMutex.cpp"
|
|
||||||
"${ROCKSDB_SOURCE_DIR}/third-party/folly/folly/synchronization/ParkingLot.cpp"
|
|
||||||
"${ROCKSDB_SOURCE_DIR}/third-party/folly/folly/synchronization/WaitOptions.cpp")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
add_library(_rocksdb ${SOURCES})
|
add_library(_rocksdb ${SOURCES})
|
||||||
add_library(ch_contrib::rocksdb ALIAS _rocksdb)
|
add_library(ch_contrib::rocksdb ALIAS _rocksdb)
|
||||||
target_link_libraries(_rocksdb PRIVATE ${THIRDPARTY_LIBS} ${SYSTEM_LIBS})
|
target_link_libraries(_rocksdb PRIVATE ${THIRDPARTY_LIBS} ${SYSTEM_LIBS})
|
||||||
|
@ -1,16 +1,33 @@
|
|||||||
// Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
|
// Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
|
||||||
/// This file was edited for ClickHouse.
|
|
||||||
|
|
||||||
#include <memory>
|
#include <memory>
|
||||||
|
|
||||||
#include "rocksdb/version.h"
|
#include "rocksdb/version.h"
|
||||||
|
#include "rocksdb/utilities/object_registry.h"
|
||||||
#include "util/string_util.h"
|
#include "util/string_util.h"
|
||||||
|
|
||||||
// The build script may replace these values with real values based
|
// The build script may replace these values with real values based
|
||||||
// on whether or not GIT is available and the platform settings
|
// on whether or not GIT is available and the platform settings
|
||||||
static const std::string rocksdb_build_git_sha = "rocksdb_build_git_sha:0";
|
static const std::string rocksdb_build_git_sha = "rocksdb_build_git_sha:72438a678872544809393b831c7273794c074215";
|
||||||
static const std::string rocksdb_build_git_tag = "rocksdb_build_git_tag:master";
|
static const std::string rocksdb_build_git_tag = "rocksdb_build_git_tag:main";
|
||||||
static const std::string rocksdb_build_date = "rocksdb_build_date:2000-01-01";
|
#define HAS_GIT_CHANGES 0
|
||||||
|
#if HAS_GIT_CHANGES == 0
|
||||||
|
// If HAS_GIT_CHANGES is 0, the GIT date is used.
|
||||||
|
// Use the time the branch/tag was last modified
|
||||||
|
static const std::string rocksdb_build_date = "rocksdb_build_date:2024-07-12 16:01:57";
|
||||||
|
#else
|
||||||
|
// If HAS_GIT_CHANGES is > 0, the branch/tag has modifications.
|
||||||
|
// Use the time the build was created.
|
||||||
|
static const std::string rocksdb_build_date = "rocksdb_build_date:2024-07-13 17:15:50";
|
||||||
|
#endif
|
||||||
|
|
||||||
|
extern "C" {
|
||||||
|
|
||||||
|
} // extern "C"
|
||||||
|
|
||||||
|
std::unordered_map<std::string, ROCKSDB_NAMESPACE::RegistrarFunc> ROCKSDB_NAMESPACE::ObjectRegistry::builtins_ = {
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
namespace ROCKSDB_NAMESPACE {
|
namespace ROCKSDB_NAMESPACE {
|
||||||
static void AddProperty(std::unordered_map<std::string, std::string> *props, const std::string& name) {
|
static void AddProperty(std::unordered_map<std::string, std::string> *props, const std::string& name) {
|
||||||
@ -39,12 +56,12 @@ const std::unordered_map<std::string, std::string>& GetRocksBuildProperties() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
std::string GetRocksVersionAsString(bool with_patch) {
|
std::string GetRocksVersionAsString(bool with_patch) {
|
||||||
std::string version = ToString(ROCKSDB_MAJOR) + "." + ToString(ROCKSDB_MINOR);
|
std::string version = std::to_string(ROCKSDB_MAJOR) + "." + std::to_string(ROCKSDB_MINOR);
|
||||||
if (with_patch) {
|
if (with_patch) {
|
||||||
return version + "." + ToString(ROCKSDB_PATCH);
|
return version + "." + std::to_string(ROCKSDB_PATCH);
|
||||||
} else {
|
} else {
|
||||||
return version;
|
return version;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string GetRocksBuildInfoAsString(const std::string& program, bool verbose) {
|
std::string GetRocksBuildInfoAsString(const std::string& program, bool verbose) {
|
||||||
|
@ -34,7 +34,7 @@ RUN arch=${TARGETARCH:-amd64} \
|
|||||||
# lts / testing / prestable / etc
|
# lts / testing / prestable / etc
|
||||||
ARG REPO_CHANNEL="stable"
|
ARG REPO_CHANNEL="stable"
|
||||||
ARG REPOSITORY="https://packages.clickhouse.com/tgz/${REPO_CHANNEL}"
|
ARG REPOSITORY="https://packages.clickhouse.com/tgz/${REPO_CHANNEL}"
|
||||||
ARG VERSION="24.6.2.17"
|
ARG VERSION="24.7.1.2915"
|
||||||
ARG PACKAGES="clickhouse-keeper"
|
ARG PACKAGES="clickhouse-keeper"
|
||||||
ARG DIRECT_DOWNLOAD_URLS=""
|
ARG DIRECT_DOWNLOAD_URLS=""
|
||||||
|
|
||||||
|
@ -32,7 +32,7 @@ RUN arch=${TARGETARCH:-amd64} \
|
|||||||
# lts / testing / prestable / etc
|
# lts / testing / prestable / etc
|
||||||
ARG REPO_CHANNEL="stable"
|
ARG REPO_CHANNEL="stable"
|
||||||
ARG REPOSITORY="https://packages.clickhouse.com/tgz/${REPO_CHANNEL}"
|
ARG REPOSITORY="https://packages.clickhouse.com/tgz/${REPO_CHANNEL}"
|
||||||
ARG VERSION="24.6.2.17"
|
ARG VERSION="24.7.1.2915"
|
||||||
ARG PACKAGES="clickhouse-client clickhouse-server clickhouse-common-static"
|
ARG PACKAGES="clickhouse-client clickhouse-server clickhouse-common-static"
|
||||||
ARG DIRECT_DOWNLOAD_URLS=""
|
ARG DIRECT_DOWNLOAD_URLS=""
|
||||||
|
|
||||||
|
@ -28,7 +28,7 @@ RUN sed -i "s|http://archive.ubuntu.com|${apt_archive}|g" /etc/apt/sources.list
|
|||||||
|
|
||||||
ARG REPO_CHANNEL="stable"
|
ARG REPO_CHANNEL="stable"
|
||||||
ARG REPOSITORY="deb [signed-by=/usr/share/keyrings/clickhouse-keyring.gpg] https://packages.clickhouse.com/deb ${REPO_CHANNEL} main"
|
ARG REPOSITORY="deb [signed-by=/usr/share/keyrings/clickhouse-keyring.gpg] https://packages.clickhouse.com/deb ${REPO_CHANNEL} main"
|
||||||
ARG VERSION="24.6.2.17"
|
ARG VERSION="24.7.1.2915"
|
||||||
ARG PACKAGES="clickhouse-client clickhouse-server clickhouse-common-static"
|
ARG PACKAGES="clickhouse-client clickhouse-server clickhouse-common-static"
|
||||||
|
|
||||||
#docker-official-library:off
|
#docker-official-library:off
|
||||||
|
524
docs/changelogs/v24.7.1.2915-stable.md
Normal file
524
docs/changelogs/v24.7.1.2915-stable.md
Normal file
@ -0,0 +1,524 @@
|
|||||||
|
---
|
||||||
|
sidebar_position: 1
|
||||||
|
sidebar_label: 2024
|
||||||
|
---
|
||||||
|
|
||||||
|
# 2024 Changelog
|
||||||
|
|
||||||
|
### ClickHouse release v24.7.1.2915-stable (a37d2d43da7) FIXME as compared to v24.7.1.1-new (aa023477a92)
|
||||||
|
|
||||||
|
#### Backward Incompatible Change
|
||||||
|
* Change binary serialization of Variant data type: add `compact` mode to avoid writing the same discriminator multiple times for granules with single variant or with only NULL values. Add MergeTree setting `use_compact_variant_discriminators_serialization` that is enabled by default. Note that Variant type is still experimental and backward-incompatible change in serialization is ok. [#62774](https://github.com/ClickHouse/ClickHouse/pull/62774) ([Kruglov Pavel](https://github.com/Avogar)).
|
||||||
|
* Forbid `CREATE MATERIALIZED VIEW ... ENGINE Replicated*MergeTree POPULATE AS SELECT ...` with Replicated databases. [#63963](https://github.com/ClickHouse/ClickHouse/pull/63963) ([vdimir](https://github.com/vdimir)).
|
||||||
|
* `clickhouse-keeper-client` will only accept paths in string literals, such as `ls '/hello/world'`, not bare strings such as `ls /hello/world`. [#65494](https://github.com/ClickHouse/ClickHouse/pull/65494) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Metric `KeeperOutstandingRequets` was renamed to `KeeperOutstandingRequests`. This fixes a typo reported in [#66179](https://github.com/ClickHouse/ClickHouse/issues/66179). [#66206](https://github.com/ClickHouse/ClickHouse/pull/66206) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
|
* Remove `is_deterministic` field from the `system.functions` table. [#66630](https://github.com/ClickHouse/ClickHouse/pull/66630) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
|
||||||
|
#### New Feature
|
||||||
|
* Extend function `tuple` to construct named tuples in query. Introduce function `tupleNames` to extract names from tuples. [#54881](https://github.com/ClickHouse/ClickHouse/pull/54881) ([Amos Bird](https://github.com/amosbird)).
|
||||||
|
* `ASOF JOIN` support for `full_sorting_join` algorithm Close [#54493](https://github.com/ClickHouse/ClickHouse/issues/54493). [#55051](https://github.com/ClickHouse/ClickHouse/pull/55051) ([vdimir](https://github.com/vdimir)).
|
||||||
|
* A new table function, `fuzzQuery,` was added. This function allows you to modify a given query string with random variations. Example: `SELECT query FROM fuzzQuery('SELECT 1');`. [#62103](https://github.com/ClickHouse/ClickHouse/pull/62103) ([pufit](https://github.com/pufit)).
|
||||||
|
* Add new window function `percent_rank`. [#62747](https://github.com/ClickHouse/ClickHouse/pull/62747) ([lgbo](https://github.com/lgbo-ustc)).
|
||||||
|
* Support JWT authentication in `clickhouse-client`. [#62829](https://github.com/ClickHouse/ClickHouse/pull/62829) ([Konstantin Bogdanov](https://github.com/thevar1able)).
|
||||||
|
* Add SQL functions `changeYear`, `changeMonth`, `changeDay`, `changeHour`, `changeMinute`, `changeSecond`. For example, `SELECT changeMonth(toDate('2024-06-14'), 7)` returns date `2024-07-14`. [#63186](https://github.com/ClickHouse/ClickHouse/pull/63186) ([cucumber95](https://github.com/cucumber95)).
|
||||||
|
* Introduce startup scripts, which allow the execution of preconfigured queries at the startup stage. [#64889](https://github.com/ClickHouse/ClickHouse/pull/64889) ([pufit](https://github.com/pufit)).
|
||||||
|
* Support accept_invalid_certificate in client's config in order to allow for client to connect over secure TCP to a server running with self-signed certificate - can be used as a shorthand for corresponding `openSSL` client settings `verificationMode=none` + `invalidCertificateHandler.name=AcceptCertificateHandler`. [#65238](https://github.com/ClickHouse/ClickHouse/pull/65238) ([peacewalker122](https://github.com/peacewalker122)).
|
||||||
|
* Add system.error_log which contains history of error values from table system.errors, periodically flushed to disk. [#65381](https://github.com/ClickHouse/ClickHouse/pull/65381) ([Pablo Marcos](https://github.com/pamarcos)).
|
||||||
|
* Add aggregate function `groupConcat`. About the same as `arrayStringConcat( groupArray(column), ',')` Can receive 2 parameters: a string delimiter and the number of elements to be processed. [#65451](https://github.com/ClickHouse/ClickHouse/pull/65451) ([Yarik Briukhovetskyi](https://github.com/yariks5s)).
|
||||||
|
* Add AzureQueue storage. [#65458](https://github.com/ClickHouse/ClickHouse/pull/65458) ([Kseniia Sumarokova](https://github.com/kssenii)).
|
||||||
|
* Add a new setting to disable/enable writing page index into parquet files. [#65475](https://github.com/ClickHouse/ClickHouse/pull/65475) ([lgbo](https://github.com/lgbo-ustc)).
|
||||||
|
* Allow system administrators to configure `logger.console_log_level`. [#65559](https://github.com/ClickHouse/ClickHouse/pull/65559) ([Azat Khuzhin](https://github.com/azat)).
|
||||||
|
* Automatically append a wildcard `*` to the end of a directory path with table function `file`. [#66019](https://github.com/ClickHouse/ClickHouse/pull/66019) ([Zhidong (David) Guo](https://github.com/Gun9niR)).
|
||||||
|
* Add `--memory-usage` option to client in non interactive mode. [#66393](https://github.com/ClickHouse/ClickHouse/pull/66393) ([vdimir](https://github.com/vdimir)).
|
||||||
|
|
||||||
|
#### Performance Improvement
|
||||||
|
* Enable `optimize_functions_to_subcolumns` by default. [#58661](https://github.com/ClickHouse/ClickHouse/pull/58661) ([Anton Popov](https://github.com/CurtizJ)).
|
||||||
|
* Replace int to string algorithm with a faster one (from a modified amdn/itoa to a modified jeaiii/itoa). [#61661](https://github.com/ClickHouse/ClickHouse/pull/61661) ([Raúl Marín](https://github.com/Algunenano)).
|
||||||
|
* Sizes of hash tables created by join (`parallel_hash` algorithm) is collected and cached now. This information will be used to preallocate space in hash tables for subsequent query executions and save time on hash table resizes. [#64553](https://github.com/ClickHouse/ClickHouse/pull/64553) ([Nikita Taranov](https://github.com/nickitat)).
|
||||||
|
* Optimized queries with `ORDER BY` primary key and `WHERE` that have a condition with high selectivity by using of buffering. It is controlled by setting `read_in_order_use_buffering` (enabled by default) and can increase memory usage of query. [#64607](https://github.com/ClickHouse/ClickHouse/pull/64607) ([Anton Popov](https://github.com/CurtizJ)).
|
||||||
|
* Improve performance of loading `plain_rewritable` metadata. [#65634](https://github.com/ClickHouse/ClickHouse/pull/65634) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Attaching tables on read-only disks will use fewer resources by not loading outdated parts. [#65635](https://github.com/ClickHouse/ClickHouse/pull/65635) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Support minmax hyperrectangle for Set indices. [#65676](https://github.com/ClickHouse/ClickHouse/pull/65676) ([AntiTopQuark](https://github.com/AntiTopQuark)).
|
||||||
|
* Unload primary index of outdated parts to reduce total memory usage. [#65852](https://github.com/ClickHouse/ClickHouse/pull/65852) ([Anton Popov](https://github.com/CurtizJ)).
|
||||||
|
* Functions `replaceRegexpAll` and `replaceRegexpOne` are now significantly faster if the pattern is trivial, i.e. contains no metacharacters, pattern classes, flags, grouping characters etc. (Thanks to Taiyang Li). [#66185](https://github.com/ClickHouse/ClickHouse/pull/66185) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
|
|
||||||
|
#### Improvement
|
||||||
|
* Support rocksdb as backend storage of keeper. [#56626](https://github.com/ClickHouse/ClickHouse/pull/56626) ([Han Fei](https://github.com/hanfei1991)).
|
||||||
|
* The setting `optimize_trivial_insert_select` is disabled by default. In most cases, it should be beneficial. Nevertheless, if you are seeing slower INSERT SELECT or increased memory usage, you can enable it back or `SET compatibility = '24.6'`. [#58970](https://github.com/ClickHouse/ClickHouse/pull/58970) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Print stacktrace and diagnostic info if `clickhouse-client` or `clickhouse-local` crashes. [#61109](https://github.com/ClickHouse/ClickHouse/pull/61109) ([Alexander Tokmakov](https://github.com/tavplubix)).
|
||||||
|
* The result of `SHOW INDEX | INDEXES | INDICES | KEYS` was previously sorted by the primary key column names. Since this was unintuitive, the result is now sorted by the position of the primary key columns within the primary key. [#61131](https://github.com/ClickHouse/ClickHouse/pull/61131) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
|
* This PR changes how deduplication for MV works. Fixed a lot of cases like: - on destination table: data is split for 2 or more blocks and that blocks is considered as duplicate when that block is inserted in parallel. - on MV destination table: the equal blocks are deduplicated, that happens when MV often produces equal data as a result for different input data due to performing aggregation. - on MV destination table: the equal blocks which comes from different MV are deduplicated. [#61601](https://github.com/ClickHouse/ClickHouse/pull/61601) ([Sema Checherinda](https://github.com/CheSema)).
|
||||||
|
* Allow matching column names in a case insensitive manner when reading json files (`input_format_json_case_insensitive_column_matching`). [#61750](https://github.com/ClickHouse/ClickHouse/pull/61750) ([kevinyhzou](https://github.com/KevinyhZou)).
|
||||||
|
* Support reading partitioned data DeltaLake data. Infer DeltaLake schema by reading metadata instead of data. [#63201](https://github.com/ClickHouse/ClickHouse/pull/63201) ([Kseniia Sumarokova](https://github.com/kssenii)).
|
||||||
|
* In composable protocols TLS layer accepted only `certificateFile` and `privateKeyFile` parameters. https://clickhouse.com/docs/en/operations/settings/composable-protocols. [#63985](https://github.com/ClickHouse/ClickHouse/pull/63985) ([Anton Ivashkin](https://github.com/ianton-ru)).
|
||||||
|
* Make an interactive client for clickhouse-disks, add local disk from the local directory. Fixes [#56791](https://github.com/ClickHouse/ClickHouse/issues/56791). [#64446](https://github.com/ClickHouse/ClickHouse/pull/64446) ([Daniil Ivanik](https://github.com/divanik)).
|
||||||
|
* Added profile event `SelectQueriesWithPrimaryKeyUsage` which indicates how many SELECT queries use the primary key to evaluate the WHERE clause. [#64492](https://github.com/ClickHouse/ClickHouse/pull/64492) ([0x01f](https://github.com/0xfei)).
|
||||||
|
* `StorageS3Queue` related fixes and improvements. Deduce a default value of `s3queue_processing_threads_num` according to the number of physical cpu cores on the server (instead of the previous default value as 1). Set default value of `s3queue_loading_retries` to 10. Fix possible vague "Uncaught exception" in exception column of `system.s3queue`. Do not increment retry count on `MEMORY_LIMIT_EXCEEDED` exception. Move files commit to a stage after insertion into table fully finished to avoid files being commited while not inserted. Add settings `s3queue_max_processed_files_before_commit`, `s3queue_max_processed_rows_before_commit`, `s3queue_max_processed_bytes_before_commit`, `s3queue_max_processing_time_sec_before_commit`, to better control commit and flush time. [#65046](https://github.com/ClickHouse/ClickHouse/pull/65046) ([Kseniia Sumarokova](https://github.com/kssenii)).
|
||||||
|
* Fixed broken multiple columns aggregation on s390x. [#65062](https://github.com/ClickHouse/ClickHouse/pull/65062) ([Harry Lee](https://github.com/HarryLeeIBM)).
|
||||||
|
* Support aliases in parametrized view function (only new analyzer). [#65190](https://github.com/ClickHouse/ClickHouse/pull/65190) ([Kseniia Sumarokova](https://github.com/kssenii)).
|
||||||
|
* S3. reduce retires time for queries, increase retries count for backups. 8.5 minutes and 100 retires for queries, 1.2 hours and 1000 retries for backup restore. [#65232](https://github.com/ClickHouse/ClickHouse/pull/65232) ([Sema Checherinda](https://github.com/CheSema)).
|
||||||
|
* Updated to mask account key in logs in azureBlobStorage. [#65273](https://github.com/ClickHouse/ClickHouse/pull/65273) ([SmitaRKulkarni](https://github.com/SmitaRKulkarni)).
|
||||||
|
* Partition pruning for `IN` predicates when filter expression is a part of `PARTITION BY` expression. [#65335](https://github.com/ClickHouse/ClickHouse/pull/65335) ([Eduard Karacharov](https://github.com/korowa)).
|
||||||
|
* Add system tables with main information about all detached tables. [#65400](https://github.com/ClickHouse/ClickHouse/pull/65400) ([Konstantin Morozov](https://github.com/k-morozov)).
|
||||||
|
* Add support for `cluster_for_parallel_replicas` when using custom key parallel replicas. It allows you to use parallel replicas with custom key with MergeTree tables. [#65453](https://github.com/ClickHouse/ClickHouse/pull/65453) ([Antonio Andelic](https://github.com/antonio2368)).
|
||||||
|
* Support query plan LIMIT optimization. Support LIMIT pushdown for PostgreSQL storage and table function. [#65454](https://github.com/ClickHouse/ClickHouse/pull/65454) ([Maksim Kita](https://github.com/kitaisreal)).
|
||||||
|
* Arraymin/max can be applicable to all data types that are comparable. [#65455](https://github.com/ClickHouse/ClickHouse/pull/65455) ([pn](https://github.com/chloro-pn)).
|
||||||
|
* Improved memory accounting for cgroups v2 to exclude the amount occupied by the page cache. [#65470](https://github.com/ClickHouse/ClickHouse/pull/65470) ([Nikita Taranov](https://github.com/nickitat)).
|
||||||
|
* Do not create format settings for each rows when serializing chunks to insert to EmbeddedRocksDB table. [#65474](https://github.com/ClickHouse/ClickHouse/pull/65474) ([Duc Canh Le](https://github.com/canhld94)).
|
||||||
|
* Fixed out-of-range exception in parsing Dwarf5 on s390x. [#65501](https://github.com/ClickHouse/ClickHouse/pull/65501) ([Harry Lee](https://github.com/HarryLeeIBM)).
|
||||||
|
* Reduce `clickhouse-local` prompt to just `:)`. `getFQDNOrHostName()` takes too long on macOS, and we don't want a hostname in the prompt for `clickhouse-local` anyway. [#65510](https://github.com/ClickHouse/ClickHouse/pull/65510) ([Konstantin Bogdanov](https://github.com/thevar1able)).
|
||||||
|
* Avoid printing a message from jemalloc about per-CPU arenas on low-end virtual machines. [#65532](https://github.com/ClickHouse/ClickHouse/pull/65532) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Disable filesystem cache background download by default. It will be enabled back when we fix the issue with possible "Memory limit exceeded" because memory deallocation is done outside of query context (while buffer is allocated inside of query context) if we use background download threads. Plus we need to add a separate setting to define max size to download for background workers (currently it is limited by max_file_segment_size, which might be too big). [#65534](https://github.com/ClickHouse/ClickHouse/pull/65534) ([Kseniia Sumarokova](https://github.com/kssenii)).
|
||||||
|
* Add new option to config `<config_reload_interval_ms>` which allow to specify how often clickhouse will reload config. [#65545](https://github.com/ClickHouse/ClickHouse/pull/65545) ([alesapin](https://github.com/alesapin)).
|
||||||
|
* Implement binary encoding for ClickHouse data types and add its specification in docs. Use it in Dynamic binary serialization, allow to use it in RowBinaryWithNamesAndTypes and Native formats under settings. [#65546](https://github.com/ClickHouse/ClickHouse/pull/65546) ([Kruglov Pavel](https://github.com/Avogar)).
|
||||||
|
* Improved ZooKeeper load balancing. The current session doesn't expire until the optimal nodes become available despite `fallback_session_lifetime`. Added support for AZ-aware balancing. [#65570](https://github.com/ClickHouse/ClickHouse/pull/65570) ([Alexander Tokmakov](https://github.com/tavplubix)).
|
||||||
|
* Server settings `compiled_expression_cache_size` and `compiled_expression_cache_elements_size` are now shown in `system.server_settings`. [#65584](https://github.com/ClickHouse/ClickHouse/pull/65584) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
|
* When lightweight delete happens on a table with projection(s), users have choices either throw an exception (by default) or drop the projection lightweight delete would happen. [#65594](https://github.com/ClickHouse/ClickHouse/pull/65594) ([jsc0218](https://github.com/jsc0218)).
|
||||||
|
* Add support for user identification based on x509 SubjectAltName extension. [#65626](https://github.com/ClickHouse/ClickHouse/pull/65626) ([Anton Kozlov](https://github.com/tonickkozlov)).
|
||||||
|
* `clickhouse-local` will respect the `max_server_memory_usage` and `max_server_memory_usage_to_ram_ratio` from the configuration file. It will also set the max memory usage to 90% of the system memory by default, like `clickhouse-server` does. This closes [#65695](https://github.com/ClickHouse/ClickHouse/issues/65695). [#65697](https://github.com/ClickHouse/ClickHouse/pull/65697) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Add a script to backup your files to ClickHouse. This is strange, but works. [#65699](https://github.com/ClickHouse/ClickHouse/pull/65699) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* PostgreSQL source support cancel. [#65722](https://github.com/ClickHouse/ClickHouse/pull/65722) ([Maksim Kita](https://github.com/kitaisreal)).
|
||||||
|
* Make allow_experimental_analyzer be controlled by the initiator for distributed queries. This ensures compatibility and correctness during operations in mixed version clusters. [#65777](https://github.com/ClickHouse/ClickHouse/pull/65777) ([Nikita Mikhaylov](https://github.com/nikitamikhaylov)).
|
||||||
|
* Respect cgroup CPU limit in Keeper. [#65819](https://github.com/ClickHouse/ClickHouse/pull/65819) ([Antonio Andelic](https://github.com/antonio2368)).
|
||||||
|
* Allow to use `concat` function with empty arguments ``` sql :) select concat();. [#65887](https://github.com/ClickHouse/ClickHouse/pull/65887) ([李扬](https://github.com/taiyang-li)).
|
||||||
|
* Allow controlling named collections in clickhouse-local. [#65973](https://github.com/ClickHouse/ClickHouse/pull/65973) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Improve Azure profile events. [#65999](https://github.com/ClickHouse/ClickHouse/pull/65999) ([alesapin](https://github.com/alesapin)).
|
||||||
|
* `Query was cancelled` might have been printed twice in clickhouse-client. This behaviour is fixed. [#66005](https://github.com/ClickHouse/ClickHouse/pull/66005) ([Nikita Mikhaylov](https://github.com/nikitamikhaylov)).
|
||||||
|
* Support ORC file read by writer time zone. [#66025](https://github.com/ClickHouse/ClickHouse/pull/66025) ([kevinyhzou](https://github.com/KevinyhZou)).
|
||||||
|
* Refactor JSONExtract functions, support more types including experimental Dynamic type. [#66046](https://github.com/ClickHouse/ClickHouse/pull/66046) ([Kruglov Pavel](https://github.com/Avogar)).
|
||||||
|
* DatabaseCatalog drops tables faster by using up to database_catalog_drop_table_concurrency threads. [#66065](https://github.com/ClickHouse/ClickHouse/pull/66065) ([Sema Checherinda](https://github.com/CheSema)).
|
||||||
|
* This PR changes how deduplication for MV works. Fixed a lot of cases like: - on destination table: data is split for 2 or more blocks and that blocks is considered as duplicate when that block is inserted in parallel. - on MV destination table: the equal blocks are deduplicated, that happens when MV often produces equal data as a result for different input data due to performing aggregation. - on MV destination table: the equal blocks which comes from different MV are deduplicated. [#66144](https://github.com/ClickHouse/ClickHouse/pull/66144) ([Sema Checherinda](https://github.com/CheSema)).
|
||||||
|
* Support null map subcolumn for Variant and Dynamic subcolumns. [#66178](https://github.com/ClickHouse/ClickHouse/pull/66178) ([Kruglov Pavel](https://github.com/Avogar)).
|
||||||
|
* Add settings to control connection to the PostgreSQL. * Setting `postgresql_connection_attempt_timeout` specifies the value passed to `connect_timeout` parameter of connection URL. * Setting `postgresql_connection_pool_retries` specifies the number of retries to establish a connection to the PostgreSQL end-point. [#66232](https://github.com/ClickHouse/ClickHouse/pull/66232) ([Dmitry Novik](https://github.com/novikd)).
|
||||||
|
* Reduce inaccuracy of input_wait_elapsed_us/input_wait_elapsed_us/elapsed_us. [#66239](https://github.com/ClickHouse/ClickHouse/pull/66239) ([Azat Khuzhin](https://github.com/azat)).
|
||||||
|
* Improve FilesystemCache ProfileEvents. [#66249](https://github.com/ClickHouse/ClickHouse/pull/66249) ([zhukai](https://github.com/nauu)).
|
||||||
|
* Add settings to ignore ON CLUSTER clause in queries for named collection management with replicated storage. [#66288](https://github.com/ClickHouse/ClickHouse/pull/66288) ([MikhailBurdukov](https://github.com/MikhailBurdukov)).
|
||||||
|
* Upgraded `pocketfft` dependency to the recent commit https://github.com/mreineck/pocketfft/commit/f4c1aa8aa9ce79ad39e80f2c9c41b92ead90fda3. [#66291](https://github.com/ClickHouse/ClickHouse/pull/66291) ([Nikita Mikhaylov](https://github.com/nikitamikhaylov)).
|
||||||
|
* Upgraded `azure-sdk-for-cpp` to the recent commit https://github.com/ClickHouse/azure-sdk-for-cpp/commit/ea3e19a7be08519134c643177d56c7484dfec884. [#66292](https://github.com/ClickHouse/ClickHouse/pull/66292) ([Nikita Mikhaylov](https://github.com/nikitamikhaylov)).
|
||||||
|
* Function `generateSnowflakeID` now allows to specify a machine ID as a parameter to prevent collisions in large clusters. [#66374](https://github.com/ClickHouse/ClickHouse/pull/66374) ([ZAWA_ll](https://github.com/Zawa-ll)).
|
||||||
|
* Disable suspending on Ctrl+Z in interactive mode. This is a common trap and is not expected behavior for almost all users. I imagine only a few extreme power users could appreciate suspending terminal applications to the background, but I don't know any. [#66511](https://github.com/ClickHouse/ClickHouse/pull/66511) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Add option for validating the Primary key type in Dictionaries. Without this option for simple layouts any column type will be implicitly converted to UInt64. ### Documentation entry for user-facing changes. [#66595](https://github.com/ClickHouse/ClickHouse/pull/66595) ([MikhailBurdukov](https://github.com/MikhailBurdukov)).
|
||||||
|
* Fix SHOW MERGES remaining time. [#66735](https://github.com/ClickHouse/ClickHouse/pull/66735) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
|
||||||
|
#### Critical Bug Fix (crash, LOGICAL_ERROR, data loss, RBAC)
|
||||||
|
* Fix unexpeced size of low cardinality column in function calls. [#65298](https://github.com/ClickHouse/ClickHouse/pull/65298) ([Raúl Marín](https://github.com/Algunenano)).
|
||||||
|
* Check cyclic dependencies on CREATE/REPLACE/RENAME/EXCHANGE queries and throw an exception if there is a cyclic dependency. Previously such cyclic dependencies could lead to a deadlock during server startup. Closes [#65355](https://github.com/ClickHouse/ClickHouse/issues/65355). Also fix some bugs in dependencies creation. [#65405](https://github.com/ClickHouse/ClickHouse/pull/65405) ([Kruglov Pavel](https://github.com/Avogar)).
|
||||||
|
* Fix crash in maxIntersections. [#65689](https://github.com/ClickHouse/ClickHouse/pull/65689) ([Raúl Marín](https://github.com/Algunenano)).
|
||||||
|
* Fix the VALID UNTIL clause in the user definition resetting after a restart. Closes [#66405](https://github.com/ClickHouse/ClickHouse/issues/66405). [#66409](https://github.com/ClickHouse/ClickHouse/pull/66409) ([Nikolay Degterinsky](https://github.com/evillique)).
|
||||||
|
|
||||||
|
#### Bug Fix (user-visible misbehavior in an official stable release)
|
||||||
|
* Fixed crash while using MaterializedMySQL with TABLE OVERRIDE that maps MySQL NULL field into ClickHouse not NULL field. [#54649](https://github.com/ClickHouse/ClickHouse/pull/54649) ([Filipp Ozinov](https://github.com/bakwc)).
|
||||||
|
* Fix logical error when PREWHERE expression read no columns and table has no adaptive index granularity (very old table). Fix [#56640](https://github.com/ClickHouse/ClickHouse/issues/56640). [#59173](https://github.com/ClickHouse/ClickHouse/pull/59173) ([Alexander Gololobov](https://github.com/davenger)).
|
||||||
|
* Fix bug with cancelation buffer when canceling a query. [#64478](https://github.com/ClickHouse/ClickHouse/pull/64478) ([Sema Checherinda](https://github.com/CheSema)).
|
||||||
|
* Fix filling parts columns from metadata (when columns.txt does not exists). [#64757](https://github.com/ClickHouse/ClickHouse/pull/64757) ([Azat Khuzhin](https://github.com/azat)).
|
||||||
|
* Fix AST formatting of 'create table b empty as a'. [#64951](https://github.com/ClickHouse/ClickHouse/pull/64951) ([Michael Kolupaev](https://github.com/al13n321)).
|
||||||
|
* Fix crash for `ALTER TABLE ... ON CLUSTER ... MODIFY SQL SECURITY`. [#64957](https://github.com/ClickHouse/ClickHouse/pull/64957) ([pufit](https://github.com/pufit)).
|
||||||
|
* Fix crash on destroying AccessControl: add explicit shutdown. [#64993](https://github.com/ClickHouse/ClickHouse/pull/64993) ([Vitaly Baranov](https://github.com/vitlibar)).
|
||||||
|
* Eliminate injective function in argument of functions `uniq*` recursively. This used to work correctly but was broken in the new analyzer. [#65140](https://github.com/ClickHouse/ClickHouse/pull/65140) ([Duc Canh Le](https://github.com/canhld94)).
|
||||||
|
* Fix unexpected projection name when query with CTE. [#65267](https://github.com/ClickHouse/ClickHouse/pull/65267) ([wudidapaopao](https://github.com/wudidapaopao)).
|
||||||
|
* Require `dictGet` privilege when accessing dictionaries via direct query or the `Dictionary` table engine. [#65359](https://github.com/ClickHouse/ClickHouse/pull/65359) ([Joe Lynch](https://github.com/joelynch)).
|
||||||
|
* Fix user-specific S3 auth with incremental backups. [#65481](https://github.com/ClickHouse/ClickHouse/pull/65481) ([Antonio Andelic](https://github.com/antonio2368)).
|
||||||
|
* Disable `non-intersecting-parts` optimization for queries with `FINAL` in case of `read-in-order` optimization was enabled. This could lead to an incorrect query result. As a workaround, disable `do_not_merge_across_partitions_select_final` and `split_parts_ranges_into_intersecting_and_non_intersecting_final` before this fix is merged. [#65505](https://github.com/ClickHouse/ClickHouse/pull/65505) ([Nikolai Kochetov](https://github.com/KochetovNicolai)).
|
||||||
|
* Fix getting exception `Index out of bound for blob metadata` in case all files from list batch were filtered out. [#65523](https://github.com/ClickHouse/ClickHouse/pull/65523) ([Kseniia Sumarokova](https://github.com/kssenii)).
|
||||||
|
* Fix NOT_FOUND_COLUMN_IN_BLOCK for deduplicate merge of projection. [#65573](https://github.com/ClickHouse/ClickHouse/pull/65573) ([Yakov Olkhovskiy](https://github.com/yakov-olkhovskiy)).
|
||||||
|
* Fixed bug in MergeJoin. Column in sparse serialisation might be treated as a column of its nested type though the required conversion wasn't performed. [#65632](https://github.com/ClickHouse/ClickHouse/pull/65632) ([Nikita Taranov](https://github.com/nickitat)).
|
||||||
|
* Fixed a bug that compatibility level '23.4' was not properly applied. [#65737](https://github.com/ClickHouse/ClickHouse/pull/65737) ([cw5121](https://github.com/cw5121)).
|
||||||
|
* Fix odbc table with nullable fields. [#65738](https://github.com/ClickHouse/ClickHouse/pull/65738) ([Rodolphe Dugé de Bernonville](https://github.com/RodolpheDuge)).
|
||||||
|
* Fix data race in `TCPHandler`, which could happen on fatal error. [#65744](https://github.com/ClickHouse/ClickHouse/pull/65744) ([Kseniia Sumarokova](https://github.com/kssenii)).
|
||||||
|
* Fix invalid exceptions in function `parseDateTime` with `%F` and `%D` placeholders. [#65768](https://github.com/ClickHouse/ClickHouse/pull/65768) ([Antonio Andelic](https://github.com/antonio2368)).
|
||||||
|
* For queries that read from `PostgreSQL`, cancel the internal `PostgreSQL` query if the ClickHouse query is finished. Otherwise, `ClickHouse` query cannot be canceled until the internal `PostgreSQL` query is finished. [#65771](https://github.com/ClickHouse/ClickHouse/pull/65771) ([Maksim Kita](https://github.com/kitaisreal)).
|
||||||
|
* Fix a bug in short circuit logic when old analyzer and dictGetOrDefault is used. [#65802](https://github.com/ClickHouse/ClickHouse/pull/65802) ([jsc0218](https://github.com/jsc0218)).
|
||||||
|
* Fix a bug leads to EmbeddedRocksDB with TTL write corrupted SST files. [#65816](https://github.com/ClickHouse/ClickHouse/pull/65816) ([Duc Canh Le](https://github.com/canhld94)).
|
||||||
|
* Functions `bitTest`, `bitTestAll`, and `bitTestAny` now return an error if the specified bit index is out-of-bounds (issue [#65517](https://github.com/ClickHouse/ClickHouse/issues/65517)). [#65818](https://github.com/ClickHouse/ClickHouse/pull/65818) ([Pablo Marcos](https://github.com/pamarcos)).
|
||||||
|
* Setting `join_any_take_last_row` is supported in any query with hash join. [#65820](https://github.com/ClickHouse/ClickHouse/pull/65820) ([vdimir](https://github.com/vdimir)).
|
||||||
|
* Better handling of join conditions involving `IS NULL` checks (for example `ON (a = b AND (a IS NOT NULL) AND (b IS NOT NULL) ) OR ( (a IS NULL) AND (b IS NULL) )` is rewritten to `ON a <=> b`), fix incorrect optimization when condition other then `IS NULL` are present. [#65835](https://github.com/ClickHouse/ClickHouse/pull/65835) ([vdimir](https://github.com/vdimir)).
|
||||||
|
* Functions `bitShiftLeft` and `bitShitfRight` return an error for out of bounds shift positions (issue [#65516](https://github.com/ClickHouse/ClickHouse/issues/65516)). [#65838](https://github.com/ClickHouse/ClickHouse/pull/65838) ([Pablo Marcos](https://github.com/pamarcos)).
|
||||||
|
* Fix growing memory usage in S3Queue. [#65839](https://github.com/ClickHouse/ClickHouse/pull/65839) ([Kseniia Sumarokova](https://github.com/kssenii)).
|
||||||
|
* Fix tie handling in `arrayAUC` to match sklearn. [#65840](https://github.com/ClickHouse/ClickHouse/pull/65840) ([gabrielmcg44](https://github.com/gabrielmcg44)).
|
||||||
|
* Fix possible issues with MySQL server protocol TLS connections. [#65917](https://github.com/ClickHouse/ClickHouse/pull/65917) ([Azat Khuzhin](https://github.com/azat)).
|
||||||
|
* Fix possible issues with MySQL client protocol TLS connections. [#65938](https://github.com/ClickHouse/ClickHouse/pull/65938) ([Azat Khuzhin](https://github.com/azat)).
|
||||||
|
* Fix handling of `SSL_ERROR_WANT_READ`/`SSL_ERROR_WANT_WRITE` with zero timeout. [#65941](https://github.com/ClickHouse/ClickHouse/pull/65941) ([Azat Khuzhin](https://github.com/azat)).
|
||||||
|
* Add missing settings `input_format_csv_skip_first_lines/input_format_tsv_skip_first_lines/input_format_csv_try_infer_numbers_from_strings/input_format_csv_try_infer_strings_from_quoted_tuples` in schema inference cache because they can change the resulting schema. It prevents from incorrect result of schema inference with these settings changed. [#65980](https://github.com/ClickHouse/ClickHouse/pull/65980) ([Kruglov Pavel](https://github.com/Avogar)).
|
||||||
|
* Column _size in s3 engine and s3 table function denotes the size of a file inside the archive, not a size of the archive itself. [#65993](https://github.com/ClickHouse/ClickHouse/pull/65993) ([Daniil Ivanik](https://github.com/divanik)).
|
||||||
|
* Fix resolving dynamic subcolumns in analyzer, avoid reading the whole column on dynamic subcolumn reading. [#66004](https://github.com/ClickHouse/ClickHouse/pull/66004) ([Kruglov Pavel](https://github.com/Avogar)).
|
||||||
|
* Fix config merging for from_env with replace overrides. [#66034](https://github.com/ClickHouse/ClickHouse/pull/66034) ([Azat Khuzhin](https://github.com/azat)).
|
||||||
|
* Fix a possible hanging in `GRPCServer` during shutdown. This PR fixes [#65622](https://github.com/ClickHouse/ClickHouse/issues/65622). [#66061](https://github.com/ClickHouse/ClickHouse/pull/66061) ([Vitaly Baranov](https://github.com/vitlibar)).
|
||||||
|
* Fix reading dynamic subcolumns from altered Memory table. Previously if `max_types` peremeter of a Dynamic type was changed in Memory table via alter, further subcolumns reading can return wrong result. [#66066](https://github.com/ClickHouse/ClickHouse/pull/66066) ([Kruglov Pavel](https://github.com/Avogar)).
|
||||||
|
* Fixed several cases in function `has` with non-constant `LowCardinality` arguments. [#66088](https://github.com/ClickHouse/ClickHouse/pull/66088) ([Anton Popov](https://github.com/CurtizJ)).
|
||||||
|
* Fix for `groupArrayIntersect`. It had incorrect behavior in the `merge()` function. Also, fixed behavior in `deserialise()` for numeric and general data. [#66103](https://github.com/ClickHouse/ClickHouse/pull/66103) ([Yarik Briukhovetskyi](https://github.com/yariks5s)).
|
||||||
|
* Fixed buffer overflow bug in `unbin`/`unhex` implementation. [#66106](https://github.com/ClickHouse/ClickHouse/pull/66106) ([Nikita Taranov](https://github.com/nickitat)).
|
||||||
|
* Disable the `merge-filters` optimization introduced in [#64760](https://github.com/ClickHouse/ClickHouse/issues/64760). It may cause an exception if optimization merges two filter expressions and does not apply a short-circuit evaluation. [#66126](https://github.com/ClickHouse/ClickHouse/pull/66126) ([Nikolai Kochetov](https://github.com/KochetovNicolai)).
|
||||||
|
* Fixed the issue when the server failed to parse Avro files with negative block size arrays encoded, which is now allowed by the Avro specification. [#66130](https://github.com/ClickHouse/ClickHouse/pull/66130) ([Serge Klochkov](https://github.com/slvrtrn)).
|
||||||
|
* Fixed a bug in ZooKeeper client: a session could get stuck in unusable state after receiving a hardware error from ZooKeeper. For example, this might happen due to "soft memory limit" in ClickHouse Keeper. [#66140](https://github.com/ClickHouse/ClickHouse/pull/66140) ([Alexander Tokmakov](https://github.com/tavplubix)).
|
||||||
|
* Fix issue in SumIfToCountIfVisitor and signed integers. [#66146](https://github.com/ClickHouse/ClickHouse/pull/66146) ([Raúl Marín](https://github.com/Algunenano)).
|
||||||
|
* Fix rare case with missing data in the result of distributed query, close [#61432](https://github.com/ClickHouse/ClickHouse/issues/61432). [#66174](https://github.com/ClickHouse/ClickHouse/pull/66174) ([vdimir](https://github.com/vdimir)).
|
||||||
|
* Fix order of parsing metadata fields in StorageDeltaLake. [#66211](https://github.com/ClickHouse/ClickHouse/pull/66211) ([Kseniia Sumarokova](https://github.com/kssenii)).
|
||||||
|
* Don't throw `TIMEOUT_EXCEEDED` for `none_only_active` mode of `distributed_ddl_output_mode`. [#66218](https://github.com/ClickHouse/ClickHouse/pull/66218) ([Alexander Tokmakov](https://github.com/tavplubix)).
|
||||||
|
* Fix handling limit for `system.numbers_mt` when no index can be used. [#66231](https://github.com/ClickHouse/ClickHouse/pull/66231) ([János Benjamin Antal](https://github.com/antaljanosbenjamin)).
|
||||||
|
* Fixed how the ClickHouse server detects the maximum number of usable CPU cores as specified by cgroups v2 if the server runs in a container such as Docker. In more detail, containers often run their process in the root cgroup which has an empty name. In that case, ClickHouse ignored the CPU limits set by cgroups v2. [#66237](https://github.com/ClickHouse/ClickHouse/pull/66237) ([filimonov](https://github.com/filimonov)).
|
||||||
|
* Fix the `Not-ready set` error when a subquery with `IN` is used in the constraint. [#66261](https://github.com/ClickHouse/ClickHouse/pull/66261) ([Nikolai Kochetov](https://github.com/KochetovNicolai)).
|
||||||
|
* Fix indexHint function case found by fuzzer. [#66286](https://github.com/ClickHouse/ClickHouse/pull/66286) ([Anton Popov](https://github.com/CurtizJ)).
|
||||||
|
* Fix error reporting while copying to S3 or AzureBlobStorage. [#66295](https://github.com/ClickHouse/ClickHouse/pull/66295) ([Vitaly Baranov](https://github.com/vitlibar)).
|
||||||
|
* Prevent watchdog from keeping descriptors of unlinked(rotated) log files. [#66334](https://github.com/ClickHouse/ClickHouse/pull/66334) ([Aleksei Filatov](https://github.com/aalexfvk)).
|
||||||
|
* Fix the bug that logicalexpressionoptimizerpass lost logical type of constant. closes [#64487](https://github.com/ClickHouse/ClickHouse/issues/64487). [#66344](https://github.com/ClickHouse/ClickHouse/pull/66344) ([pn](https://github.com/chloro-pn)).
|
||||||
|
* Fix `Column identifier is already registered` error with `group_by_use_nulls=true` and new analyzer. [#66400](https://github.com/ClickHouse/ClickHouse/pull/66400) ([Nikolai Kochetov](https://github.com/KochetovNicolai)).
|
||||||
|
* Fix possible incorrect result for queries joining and filtering table external engine (like PostgreSQL), due to too aggressive filter pushdown. Since now, conditions from where section won't be send to external database in case of outer join with external table. [#66402](https://github.com/ClickHouse/ClickHouse/pull/66402) ([vdimir](https://github.com/vdimir)).
|
||||||
|
* Added missing column materialization for cross join. [#66413](https://github.com/ClickHouse/ClickHouse/pull/66413) ([lgbo](https://github.com/lgbo-ustc)).
|
||||||
|
* Fix `Cannot find column` error for queries with constant expression in `GROUP BY` key and new analyzer enabled. [#66433](https://github.com/ClickHouse/ClickHouse/pull/66433) ([Nikolai Kochetov](https://github.com/KochetovNicolai)).
|
||||||
|
* Avoid possible logical error during import from Npy format in case of bad array nesting level, fix testing of other kinds of errors. [#66461](https://github.com/ClickHouse/ClickHouse/pull/66461) ([Yarik Briukhovetskyi](https://github.com/yariks5s)).
|
||||||
|
* Fix wrong count() result when there is non-deterministic function in predicate. [#66510](https://github.com/ClickHouse/ClickHouse/pull/66510) ([Duc Canh Le](https://github.com/canhld94)).
|
||||||
|
* Correctly track memory for `Allocator::realloc`. [#66548](https://github.com/ClickHouse/ClickHouse/pull/66548) ([Antonio Andelic](https://github.com/antonio2368)).
|
||||||
|
* Fix reading of uninitialized memory when hashing empty tuples. This closes [#66559](https://github.com/ClickHouse/ClickHouse/issues/66559). [#66562](https://github.com/ClickHouse/ClickHouse/pull/66562) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Fix an invalid result for queries with `WINDOW`. This could happen when `PARTITION` columns have sparse serialization and window functions are executed in parallel. [#66579](https://github.com/ClickHouse/ClickHouse/pull/66579) ([Nikolai Kochetov](https://github.com/KochetovNicolai)).
|
||||||
|
* Fix removing named collections in local storage. [#66599](https://github.com/ClickHouse/ClickHouse/pull/66599) ([János Benjamin Antal](https://github.com/antaljanosbenjamin)).
|
||||||
|
* Fix logical error in `PrometheusRequestHandler`. [#66621](https://github.com/ClickHouse/ClickHouse/pull/66621) ([Vitaly Baranov](https://github.com/vitlibar)).
|
||||||
|
* `column_length` is not updated in `ColumnTuple::insertManyFrom`. [#66626](https://github.com/ClickHouse/ClickHouse/pull/66626) ([lgbo](https://github.com/lgbo-ustc)).
|
||||||
|
* Fix `Unknown identifier` and `Column is not under aggregate function` errors for queries with the expression `(column IS NULL).` The bug was triggered by [#65088](https://github.com/ClickHouse/ClickHouse/issues/65088), with the disabled analyzer only. [#66654](https://github.com/ClickHouse/ClickHouse/pull/66654) ([Nikolai Kochetov](https://github.com/KochetovNicolai)).
|
||||||
|
* Fix `Method getResultType is not supported for QUERY query node` error when scalar subquery was used as the first argument of IN (with new analyzer). [#66655](https://github.com/ClickHouse/ClickHouse/pull/66655) ([Nikolai Kochetov](https://github.com/KochetovNicolai)).
|
||||||
|
* Fix possible PARAMETER_OUT_OF_BOUND error during reading variant subcolumn. [#66659](https://github.com/ClickHouse/ClickHouse/pull/66659) ([Kruglov Pavel](https://github.com/Avogar)).
|
||||||
|
* Fix rare case of stuck merge after drop column. [#66707](https://github.com/ClickHouse/ClickHouse/pull/66707) ([Raúl Marín](https://github.com/Algunenano)).
|
||||||
|
* Fix assertion `isUniqTypes` when insert select from remote sources. [#66722](https://github.com/ClickHouse/ClickHouse/pull/66722) ([Sema Checherinda](https://github.com/CheSema)).
|
||||||
|
* Backported in [#67026](https://github.com/ClickHouse/ClickHouse/issues/67026): In rare cases ClickHouse could consider parts as broken because of some unexpected projections on disk. Now it's fixed. [#66898](https://github.com/ClickHouse/ClickHouse/pull/66898) ([alesapin](https://github.com/alesapin)).
|
||||||
|
* Backported in [#67443](https://github.com/ClickHouse/ClickHouse/issues/67443): Forbid create as select even when database_replicated_allow_heavy_create is set. It was unconditionally forbidden in 23.12 and accidentally allowed under the setting in unreleased 24.7. [#66980](https://github.com/ClickHouse/ClickHouse/pull/66980) ([vdimir](https://github.com/vdimir)).
|
||||||
|
* Backported in [#67201](https://github.com/ClickHouse/ClickHouse/issues/67201): TRUNCATE DATABASE used to stop replication as if it was a DROP DATABASE query, it's fixed. [#67129](https://github.com/ClickHouse/ClickHouse/pull/67129) ([Alexander Tokmakov](https://github.com/tavplubix)).
|
||||||
|
* Backported in [#67383](https://github.com/ClickHouse/ClickHouse/issues/67383): Fix error `Cannot convert column because it is non constant in source stream but must be constant in result.` for a query that reads from the `Merge` table over the `Distriburted` table with one shard. [#67146](https://github.com/ClickHouse/ClickHouse/pull/67146) ([Nikolai Kochetov](https://github.com/KochetovNicolai)).
|
||||||
|
* Backported in [#67246](https://github.com/ClickHouse/ClickHouse/issues/67246): This closes [#67156](https://github.com/ClickHouse/ClickHouse/issues/67156). This closes [#66447](https://github.com/ClickHouse/ClickHouse/issues/66447). The bug was introduced in https://github.com/ClickHouse/ClickHouse/pull/62907. [#67178](https://github.com/ClickHouse/ClickHouse/pull/67178) ([Maksim Kita](https://github.com/kitaisreal)).
|
||||||
|
|
||||||
|
#### Build/Testing/Packaging Improvement
|
||||||
|
* Instantiate template methods ahead in different .cpp files, avoid too large translation units during compiling. [#64818](https://github.com/ClickHouse/ClickHouse/pull/64818) ([lgbo](https://github.com/lgbo-ustc)).
|
||||||
|
* Stateless tests: Improve tests speed and decrease number of parallel jobs. [#65186](https://github.com/ClickHouse/ClickHouse/pull/65186) ([Nikita Fomichev](https://github.com/fm4v)).
|
||||||
|
* Add tests for `base64URLEncode` and `base64URLDecode`. Add analyzer tests. [#65979](https://github.com/ClickHouse/ClickHouse/pull/65979) ([Nikita Fomichev](https://github.com/fm4v)).
|
||||||
|
* Fix problem when github terminate instances by timeout and artifacts are not collected and full test report is not generated. [#66036](https://github.com/ClickHouse/ClickHouse/pull/66036) ([Nikita Fomichev](https://github.com/fm4v)).
|
||||||
|
* Fix test [test_grpc_protocol/test.py::test_progress](https://s3.amazonaws.com/clickhouse-test-reports/57695/188f8a3df74caf830ad1ced3c4cf6dfb0aa90093/integration_tests__asan__old_analyzer__[4_6].html). [#66063](https://github.com/ClickHouse/ClickHouse/pull/66063) ([Vitaly Baranov](https://github.com/vitlibar)).
|
||||||
|
* Stateless tests: Improve tests speed and decrease number of parallel jobs. [#66305](https://github.com/ClickHouse/ClickHouse/pull/66305) ([Nikita Fomichev](https://github.com/fm4v)).
|
||||||
|
* Stateless tests: Improve tests speed and decrease number of parallel jobs 3. [#66363](https://github.com/ClickHouse/ClickHouse/pull/66363) ([Nikita Fomichev](https://github.com/fm4v)).
|
||||||
|
* Tests: fix tests hang up in cases when gdb catches error. [#66411](https://github.com/ClickHouse/ClickHouse/pull/66411) ([Nikita Fomichev](https://github.com/fm4v)).
|
||||||
|
* ... since [Release v24.6.1.4423-stable](https://github.com/ClickHouse/ClickHouse/releases/tag/v24.6.1.4423-stable) when build in ppc64le with dynamic openssl build (`cmake -DENABLE_OPENSSL_DYNAMIC=1 -DCMAKE_TOOLCHAIN_FILE= cmake/linux/toolchain-ppc64le.cmake `) got error: ` ld.lld: error: duplicate symbol: OPENSSL_cleanse`. [#66733](https://github.com/ClickHouse/ClickHouse/pull/66733) ([Yong Wang](https://github.com/kashwy)).
|
||||||
|
|
||||||
|
#### NO CL CATEGORY
|
||||||
|
|
||||||
|
* Backported in [#67084](https://github.com/ClickHouse/ClickHouse/issues/67084):. [#67040](https://github.com/ClickHouse/ClickHouse/pull/67040) ([Raúl Marín](https://github.com/Algunenano)).
|
||||||
|
* Backported in [#67452](https://github.com/ClickHouse/ClickHouse/issues/67452):. [#67392](https://github.com/ClickHouse/ClickHouse/pull/67392) ([alesapin](https://github.com/alesapin)).
|
||||||
|
|
||||||
|
#### NO CL ENTRY
|
||||||
|
|
||||||
|
* NO CL ENTRY: 'Revert "Revert "Small fix for 02340_parts_refcnt_mergetree""'. [#65155](https://github.com/ClickHouse/ClickHouse/pull/65155) ([Nikita Taranov](https://github.com/nickitat)).
|
||||||
|
* NO CL ENTRY: 'Revert "Use 1MB HTTP buffers to avoid frequent send syscalls"'. [#65498](https://github.com/ClickHouse/ClickHouse/pull/65498) ([Sergei Trifonov](https://github.com/serxa)).
|
||||||
|
* NO CL ENTRY: 'Revert "Resubmit http_external_tables_memory_tracking test"'. [#65500](https://github.com/ClickHouse/ClickHouse/pull/65500) ([Nikita Taranov](https://github.com/nickitat)).
|
||||||
|
* NO CL ENTRY: 'Revert "Add an assertion in ReplicatedMergeTreeQueue"'. [#65686](https://github.com/ClickHouse/ClickHouse/pull/65686) ([Raúl Marín](https://github.com/Algunenano)).
|
||||||
|
* NO CL ENTRY: 'Revert "insertion deduplication on retries for materialised views"'. [#66134](https://github.com/ClickHouse/ClickHouse/pull/66134) ([Sema Checherinda](https://github.com/CheSema)).
|
||||||
|
|
||||||
|
#### NOT FOR CHANGELOG / INSIGNIFICANT
|
||||||
|
|
||||||
|
* Return and fix 01600_parts_states_metrics_long test. [#58748](https://github.com/ClickHouse/ClickHouse/pull/58748) ([Yakov Olkhovskiy](https://github.com/yakov-olkhovskiy)).
|
||||||
|
* Add azure_cache as storage policy to tests. [#59943](https://github.com/ClickHouse/ClickHouse/pull/59943) ([SmitaRKulkarni](https://github.com/SmitaRKulkarni)).
|
||||||
|
* Minor: replaced expression with LEGACY_MAX_LEVEL. [#61268](https://github.com/ClickHouse/ClickHouse/pull/61268) ([Vasily Nemkov](https://github.com/Enmk)).
|
||||||
|
* Make write to temporary data in cache do all checks and assertions as during write to ordinary cache. [#63348](https://github.com/ClickHouse/ClickHouse/pull/63348) ([Kseniia Sumarokova](https://github.com/kssenii)).
|
||||||
|
* Refactoring near azure blob storage. [#63636](https://github.com/ClickHouse/ClickHouse/pull/63636) ([Anton Popov](https://github.com/CurtizJ)).
|
||||||
|
* Everything should work with Analyzer. [#63643](https://github.com/ClickHouse/ClickHouse/pull/63643) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* add some log for non using detached tables. [#64992](https://github.com/ClickHouse/ClickHouse/pull/64992) ([Konstantin Morozov](https://github.com/k-morozov)).
|
||||||
|
* Remove dag flags. [#65234](https://github.com/ClickHouse/ClickHouse/pull/65234) ([Nikolai Kochetov](https://github.com/KochetovNicolai)).
|
||||||
|
* Fix flaky autocompletion test. [#65246](https://github.com/ClickHouse/ClickHouse/pull/65246) ([Konstantin Bogdanov](https://github.com/thevar1able)).
|
||||||
|
* Disable userspace page cache by default. [#65305](https://github.com/ClickHouse/ClickHouse/pull/65305) ([Michael Kolupaev](https://github.com/al13n321)).
|
||||||
|
* Update version_date.tsv and changelogs after v24.4.3.25-stable. [#65308](https://github.com/ClickHouse/ClickHouse/pull/65308) ([robot-clickhouse](https://github.com/robot-clickhouse)).
|
||||||
|
* Do not raise a NOT_IMPLEMENTED error when getting s3 metrics with a multiple disk configuration. [#65403](https://github.com/ClickHouse/ClickHouse/pull/65403) ([Elena Torró](https://github.com/elenatorro)).
|
||||||
|
* Dodging reading from wrong table with parallel replicas. [#65417](https://github.com/ClickHouse/ClickHouse/pull/65417) ([Nikita Taranov](https://github.com/nickitat)).
|
||||||
|
* Fix: return error if can't connect to any replicas chosen for query execution. [#65467](https://github.com/ClickHouse/ClickHouse/pull/65467) ([Igor Nikonov](https://github.com/devcrafter)).
|
||||||
|
* Fix `AzureObjectStorage::exists` method. [#65471](https://github.com/ClickHouse/ClickHouse/pull/65471) ([Anton Popov](https://github.com/CurtizJ)).
|
||||||
|
* Update version after release. [#65483](https://github.com/ClickHouse/ClickHouse/pull/65483) ([Raúl Marín](https://github.com/Algunenano)).
|
||||||
|
* Generate 24.6 changelog. [#65485](https://github.com/ClickHouse/ClickHouse/pull/65485) ([Raúl Marín](https://github.com/Algunenano)).
|
||||||
|
* Fix of `PlanSquashingTransform`: pipeline stuck. [#65487](https://github.com/ClickHouse/ClickHouse/pull/65487) ([Yarik Briukhovetskyi](https://github.com/yariks5s)).
|
||||||
|
* Fix bad test `02922_deduplication_with_zero_copy`. [#65492](https://github.com/ClickHouse/ClickHouse/pull/65492) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Disable clang-format in special areas. [#65495](https://github.com/ClickHouse/ClickHouse/pull/65495) ([Nikita Taranov](https://github.com/nickitat)).
|
||||||
|
* Fix `test_keeper_snapshots`. [#65497](https://github.com/ClickHouse/ClickHouse/pull/65497) ([Antonio Andelic](https://github.com/antonio2368)).
|
||||||
|
* Update to libunwind 8.1.7. [#65509](https://github.com/ClickHouse/ClickHouse/pull/65509) ([Michael Kolupaev](https://github.com/al13n321)).
|
||||||
|
* Setting `uniform_snowflake_conversion_functions` (not in any release yet) was replaced by setting `allow_deprecated_snowflake_conversion_functions`. The latter controls if the legacy snowflake conversion functions are available (by default, they are not). [#65522](https://github.com/ClickHouse/ClickHouse/pull/65522) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
|
* Try CI without RerunCheck, jobs can be easily rerun manually though extra amount of work in CI will follow on workflow restart. [#65524](https://github.com/ClickHouse/ClickHouse/pull/65524) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Bump re2 to latest HEAD. [#65526](https://github.com/ClickHouse/ClickHouse/pull/65526) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
|
* OpenSSL: Replace temporary fix for unsynchronized access by official fix. [#65529](https://github.com/ClickHouse/ClickHouse/pull/65529) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
|
* Update README.md. [#65531](https://github.com/ClickHouse/ClickHouse/pull/65531) ([Tyler Hannan](https://github.com/tylerhannan)).
|
||||||
|
* CI: some time there are timeouts on DROP TABLES for random tests. [#65535](https://github.com/ClickHouse/ClickHouse/pull/65535) ([Sema Checherinda](https://github.com/CheSema)).
|
||||||
|
* Synchronize `MARK_CACHE_SIZE` value in default settings and config. [#65547](https://github.com/ClickHouse/ClickHouse/pull/65547) ([Denny Crane](https://github.com/den-crane)).
|
||||||
|
* CI: Skip removed test files in stateless flaky check job. [#65553](https://github.com/ClickHouse/ClickHouse/pull/65553) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Renames Build report jobs. [#65554](https://github.com/ClickHouse/ClickHouse/pull/65554) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Parse user from URL for dashboard.html (useful for sharing). [#65556](https://github.com/ClickHouse/ClickHouse/pull/65556) ([Azat Khuzhin](https://github.com/azat)).
|
||||||
|
* Remove tech debt. [#65561](https://github.com/ClickHouse/ClickHouse/pull/65561) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Maybe fix test `00763_lock_buffer_long.sh`. [#65562](https://github.com/ClickHouse/ClickHouse/pull/65562) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Fix clickhouse-keeper with not system-wide directories and provide override for local development. [#65563](https://github.com/ClickHouse/ClickHouse/pull/65563) ([Azat Khuzhin](https://github.com/azat)).
|
||||||
|
* Re-configure yamllint to allow document-start. [#65565](https://github.com/ClickHouse/ClickHouse/pull/65565) ([Azat Khuzhin](https://github.com/azat)).
|
||||||
|
* Fix flaky test `01254_dict_load_after_detach_attach.sql`. [#65571](https://github.com/ClickHouse/ClickHouse/pull/65571) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Improve flaky test to provide more diagnostics. [#65586](https://github.com/ClickHouse/ClickHouse/pull/65586) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Fix test_parallel_replicas_distributed_skip_shards flakiness. [#65588](https://github.com/ClickHouse/ClickHouse/pull/65588) ([Igor Nikonov](https://github.com/devcrafter)).
|
||||||
|
* Fix an error in the test about metadata_type. [#65592](https://github.com/ClickHouse/ClickHouse/pull/65592) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Fix slow test. [#65593](https://github.com/ClickHouse/ClickHouse/pull/65593) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* fix flaky 02864_statistics_uniq. [#65599](https://github.com/ClickHouse/ClickHouse/pull/65599) ([Han Fei](https://github.com/hanfei1991)).
|
||||||
|
* Fix 03172_error_log_table_not_empty. [#65604](https://github.com/ClickHouse/ClickHouse/pull/65604) ([Pablo Marcos](https://github.com/pamarcos)).
|
||||||
|
* Enable realtime digest for Jepsen tests. [#65608](https://github.com/ClickHouse/ClickHouse/pull/65608) ([Antonio Andelic](https://github.com/antonio2368)).
|
||||||
|
* CI: Return Job Rerun check. [#65613](https://github.com/ClickHouse/ClickHouse/pull/65613) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Update CHANGELOG.md. [#65624](https://github.com/ClickHouse/ClickHouse/pull/65624) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Module is required for authenticating in GH (in cloud). [#65628](https://github.com/ClickHouse/ClickHouse/pull/65628) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Update IObjectStorage.h. [#65631](https://github.com/ClickHouse/ClickHouse/pull/65631) ([Kseniia Sumarokova](https://github.com/kssenii)).
|
||||||
|
* Fix 02834_apache_arrow_abort flakiness with MSAN. [#65640](https://github.com/ClickHouse/ClickHouse/pull/65640) ([Michael Kolupaev](https://github.com/al13n321)).
|
||||||
|
* Fix overflow in StorageWindowView. [#65641](https://github.com/ClickHouse/ClickHouse/pull/65641) ([Michael Kolupaev](https://github.com/al13n321)).
|
||||||
|
* Fix inconsistent AST formatting when a keyword is used as type name. [#65648](https://github.com/ClickHouse/ClickHouse/pull/65648) ([Michael Kolupaev](https://github.com/al13n321)).
|
||||||
|
* CI: Single point of setting mergeable check status. [#65658](https://github.com/ClickHouse/ClickHouse/pull/65658) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Miscellaneous and insignificant changes around Client/ClientBase. [#65669](https://github.com/ClickHouse/ClickHouse/pull/65669) ([Nikita Mikhaylov](https://github.com/nikitamikhaylov)).
|
||||||
|
* Add Replicated database names to ZooKeeper for introspection. [#65675](https://github.com/ClickHouse/ClickHouse/pull/65675) ([Alexander Tokmakov](https://github.com/tavplubix)).
|
||||||
|
* Introduce type contract checks in `IColumn`. [#65687](https://github.com/ClickHouse/ClickHouse/pull/65687) ([Nikita Taranov](https://github.com/nickitat)).
|
||||||
|
* Print slightly more information in 02982_aggregation_states_destruction. [#65688](https://github.com/ClickHouse/ClickHouse/pull/65688) ([Michael Kolupaev](https://github.com/al13n321)).
|
||||||
|
* Disable stacktrace collection in GWPAsan by default. [#65701](https://github.com/ClickHouse/ClickHouse/pull/65701) ([Antonio Andelic](https://github.com/antonio2368)).
|
||||||
|
* Build jemalloc with profiler. [#65702](https://github.com/ClickHouse/ClickHouse/pull/65702) ([Antonio Andelic](https://github.com/antonio2368)).
|
||||||
|
* Fix duplicate symbol linkage error. [#65705](https://github.com/ClickHouse/ClickHouse/pull/65705) ([Nikita Taranov](https://github.com/nickitat)).
|
||||||
|
* Fix server restarts in performance tests. [#65717](https://github.com/ClickHouse/ClickHouse/pull/65717) ([Antonio Andelic](https://github.com/antonio2368)).
|
||||||
|
* Update 03002_part_log_rmt_fetch_mutate_error.sql. [#65720](https://github.com/ClickHouse/ClickHouse/pull/65720) ([Alexander Tokmakov](https://github.com/tavplubix)).
|
||||||
|
* Fix bug with session closing in Keeper. [#65735](https://github.com/ClickHouse/ClickHouse/pull/65735) ([Antonio Andelic](https://github.com/antonio2368)).
|
||||||
|
* Fix flaky `02265_column_ttl`. Closes [#65719](https://github.com/ClickHouse/ClickHouse/issues/65719). [#65742](https://github.com/ClickHouse/ClickHouse/pull/65742) ([János Benjamin Antal](https://github.com/antaljanosbenjamin)).
|
||||||
|
* See [#65745](https://github.com/ClickHouse/ClickHouse/issues/65745). It doesn't solve the issue, but helps a bit. [#65746](https://github.com/ClickHouse/ClickHouse/pull/65746) ([Alexander Tokmakov](https://github.com/tavplubix)).
|
||||||
|
* Update CHANGELOG.md. [#65752](https://github.com/ClickHouse/ClickHouse/pull/65752) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* document declarative ssh-keys authentication. [#65756](https://github.com/ClickHouse/ClickHouse/pull/65756) ([Tobias Florek](https://github.com/ibotty)).
|
||||||
|
* `base64En/Decode64Url` --> `base64En/Decode64URL`. [#65760](https://github.com/ClickHouse/ClickHouse/pull/65760) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
|
* Fix for issue [#65757](https://github.com/ClickHouse/ClickHouse/issues/65757). [#65763](https://github.com/ClickHouse/ClickHouse/pull/65763) ([Yarik Briukhovetskyi](https://github.com/yariks5s)).
|
||||||
|
* Fix flaky `test_replicated_database::test_alter_attach`. [#65766](https://github.com/ClickHouse/ClickHouse/pull/65766) ([Antonio Andelic](https://github.com/antonio2368)).
|
||||||
|
* Fix: progress bar for read in order queries. [#65769](https://github.com/ClickHouse/ClickHouse/pull/65769) ([Igor Nikonov](https://github.com/devcrafter)).
|
||||||
|
* CI: Fix for Builds report job in backports and releases. [#65774](https://github.com/ClickHouse/ClickHouse/pull/65774) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* CI: New create release workflow. [#65775](https://github.com/ClickHouse/ClickHouse/pull/65775) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* fixed misspelled word. [#65778](https://github.com/ClickHouse/ClickHouse/pull/65778) ([Linh Giang](https://github.com/linhgiang24)).
|
||||||
|
* Refactor statistics interface. [#65792](https://github.com/ClickHouse/ClickHouse/pull/65792) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
|
* Try to make `test_ldap_external_user_directory` less flaky. [#65794](https://github.com/ClickHouse/ClickHouse/pull/65794) ([Andrey Zvonov](https://github.com/zvonand)).
|
||||||
|
* AMI image with gh and jwt. [#65795](https://github.com/ClickHouse/ClickHouse/pull/65795) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Forbid join algorithm randomisation for 03094_one_thousand_joins. [#65798](https://github.com/ClickHouse/ClickHouse/pull/65798) ([Nikita Taranov](https://github.com/nickitat)).
|
||||||
|
* Fix 02931_rewrite_sum_column_and_constant flakiness. [#65800](https://github.com/ClickHouse/ClickHouse/pull/65800) ([Michael Kolupaev](https://github.com/al13n321)).
|
||||||
|
* Update StorageMaterializedView.cpp. [#65801](https://github.com/ClickHouse/ClickHouse/pull/65801) ([Nikolay Degterinsky](https://github.com/evillique)).
|
||||||
|
* Fix slow `getFQDNOrHostNameImpl` on macOS. [#65803](https://github.com/ClickHouse/ClickHouse/pull/65803) ([Konstantin Bogdanov](https://github.com/thevar1able)).
|
||||||
|
* No jemalloc profiler for non-Linux. [#65834](https://github.com/ClickHouse/ClickHouse/pull/65834) ([Antonio Andelic](https://github.com/antonio2368)).
|
||||||
|
* Add missing workload identity changes. [#65848](https://github.com/ClickHouse/ClickHouse/pull/65848) ([SmitaRKulkarni](https://github.com/SmitaRKulkarni)).
|
||||||
|
* Fix rocksdb. [#65858](https://github.com/ClickHouse/ClickHouse/pull/65858) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Update the list of easy tasks. [#65865](https://github.com/ClickHouse/ClickHouse/pull/65865) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Update CHANGELOG.md. [#65866](https://github.com/ClickHouse/ClickHouse/pull/65866) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* This closes [#43003](https://github.com/ClickHouse/ClickHouse/issues/43003). [#65870](https://github.com/ClickHouse/ClickHouse/pull/65870) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Uninteresting changes. [#65871](https://github.com/ClickHouse/ClickHouse/pull/65871) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Max sessions for user tests improvements. [#65888](https://github.com/ClickHouse/ClickHouse/pull/65888) ([Alexey Gerasimchuck](https://github.com/Demilivor)).
|
||||||
|
* Update version_date.tsv and changelogs after v24.6.1.4423-stable. [#65909](https://github.com/ClickHouse/ClickHouse/pull/65909) ([robot-clickhouse](https://github.com/robot-clickhouse)).
|
||||||
|
* Remove standalone Keeper build. [#65910](https://github.com/ClickHouse/ClickHouse/pull/65910) ([Antonio Andelic](https://github.com/antonio2368)).
|
||||||
|
* Add extra profiling helpers for Keeper. [#65918](https://github.com/ClickHouse/ClickHouse/pull/65918) ([Antonio Andelic](https://github.com/antonio2368)).
|
||||||
|
* PostgreSQL source cancel query comments. [#65919](https://github.com/ClickHouse/ClickHouse/pull/65919) ([Maksim Kita](https://github.com/kitaisreal)).
|
||||||
|
* Remove mysqlxx::Pool::Entry assignment operator. [#65920](https://github.com/ClickHouse/ClickHouse/pull/65920) ([Azat Khuzhin](https://github.com/azat)).
|
||||||
|
* No random settings for a test with `Object(JSON)`. [#65921](https://github.com/ClickHouse/ClickHouse/pull/65921) ([Nikita Mikhaylov](https://github.com/nikitamikhaylov)).
|
||||||
|
* Follow up to [#65046](https://github.com/ClickHouse/ClickHouse/issues/65046). [#65928](https://github.com/ClickHouse/ClickHouse/pull/65928) ([Kseniia Sumarokova](https://github.com/kssenii)).
|
||||||
|
* add restriction for storage join. [#65936](https://github.com/ClickHouse/ClickHouse/pull/65936) ([Han Fei](https://github.com/hanfei1991)).
|
||||||
|
* Update version_date.tsv and changelogs after v24.5.4.49-stable. [#65937](https://github.com/ClickHouse/ClickHouse/pull/65937) ([robot-clickhouse](https://github.com/robot-clickhouse)).
|
||||||
|
* Add table name to MergeTreeSource spans. [#65940](https://github.com/ClickHouse/ClickHouse/pull/65940) ([Nikita Taranov](https://github.com/nickitat)).
|
||||||
|
* Fix SettingsChangesHistory 24.7. [#65945](https://github.com/ClickHouse/ClickHouse/pull/65945) ([Raúl Marín](https://github.com/Algunenano)).
|
||||||
|
* Fix logical error "Expected ReadBufferFromFile, but got DB::EmptyReadBuffer". [#65949](https://github.com/ClickHouse/ClickHouse/pull/65949) ([Kseniia Sumarokova](https://github.com/kssenii)).
|
||||||
|
* Use -Og instead of -O0 for debug builds. [#65953](https://github.com/ClickHouse/ClickHouse/pull/65953) ([Michael Kolupaev](https://github.com/al13n321)).
|
||||||
|
* Fix data race for Keeper snapshot queue. [#65970](https://github.com/ClickHouse/ClickHouse/pull/65970) ([Antonio Andelic](https://github.com/antonio2368)).
|
||||||
|
* Minor changes in CHANGELOG. [#65971](https://github.com/ClickHouse/ClickHouse/pull/65971) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Remove unnatural punctuation from Parquet. [#65972](https://github.com/ClickHouse/ClickHouse/pull/65972) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Try fix "Check timeout expired" without any server logs in report in stateless tests. [#65977](https://github.com/ClickHouse/ClickHouse/pull/65977) ([Kseniia Sumarokova](https://github.com/kssenii)).
|
||||||
|
* Fix support of non-const scale arguments in rounding functions. [#65983](https://github.com/ClickHouse/ClickHouse/pull/65983) ([Mikhail Gorshkov](https://github.com/mgorshkov)).
|
||||||
|
* More aesthetic error messages. [#65985](https://github.com/ClickHouse/ClickHouse/pull/65985) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
|
* Fix race in s3queue. [#65986](https://github.com/ClickHouse/ClickHouse/pull/65986) ([Kseniia Sumarokova](https://github.com/kssenii)).
|
||||||
|
* Now it's possible to specify `s3-storage`, `azure-object-storage` and in general `object-storage`. [#65988](https://github.com/ClickHouse/ClickHouse/pull/65988) ([alesapin](https://github.com/alesapin)).
|
||||||
|
* Fix flaky test_storage_s3_queue tests. [#66009](https://github.com/ClickHouse/ClickHouse/pull/66009) ([Kseniia Sumarokova](https://github.com/kssenii)).
|
||||||
|
* Relax the check in 02982_aggregation_states_destruction. [#66011](https://github.com/ClickHouse/ClickHouse/pull/66011) ([Nikita Taranov](https://github.com/nickitat)).
|
||||||
|
* Fix `01158_zookeeper_log_long`. [#66012](https://github.com/ClickHouse/ClickHouse/pull/66012) ([Alexander Tokmakov](https://github.com/tavplubix)).
|
||||||
|
* Remove scary jemalloc log. [#66028](https://github.com/ClickHouse/ClickHouse/pull/66028) ([Antonio Andelic](https://github.com/antonio2368)).
|
||||||
|
* Move experimental settings to the experimental block. [#66030](https://github.com/ClickHouse/ClickHouse/pull/66030) ([Raúl Marín](https://github.com/Algunenano)).
|
||||||
|
* Fix lock-order-inversion in DatabaseCatalog. [#66038](https://github.com/ClickHouse/ClickHouse/pull/66038) ([Nikolay Degterinsky](https://github.com/evillique)).
|
||||||
|
* Try disabling jemalloc background threads. [#66041](https://github.com/ClickHouse/ClickHouse/pull/66041) ([Antonio Andelic](https://github.com/antonio2368)).
|
||||||
|
* Try to avoid conflicts in `SettingsChangesHistory.cpp`. [#66042](https://github.com/ClickHouse/ClickHouse/pull/66042) ([Anton Popov](https://github.com/CurtizJ)).
|
||||||
|
* Add profile events for regex cache. [#66050](https://github.com/ClickHouse/ClickHouse/pull/66050) ([Antonio Andelic](https://github.com/antonio2368)).
|
||||||
|
* Bump vectorscan to 5.4.10.1. [#66056](https://github.com/ClickHouse/ClickHouse/pull/66056) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
|
* Remove obsolete comment. [#66059](https://github.com/ClickHouse/ClickHouse/pull/66059) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
|
* Maybe fix tsan assert in `test_mysql_killed_while_insert_8_0`. [#66064](https://github.com/ClickHouse/ClickHouse/pull/66064) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
|
* Move some of `HTTPHandler` stuff to separate source files in order to reuse it in `PrometheusRequestHandler`. This PR is required for https://github.com/ClickHouse/ClickHouse/pull/64183. [#66067](https://github.com/ClickHouse/ClickHouse/pull/66067) ([Vitaly Baranov](https://github.com/vitlibar)).
|
||||||
|
* Bump rocksdb to v6.23.3. [#66068](https://github.com/ClickHouse/ClickHouse/pull/66068) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
|
* Add protobufs for `Prometheus` `remote-write` / `remote-read` protocols to our repository. Fix cmake script for compiling protobufs. [#66069](https://github.com/ClickHouse/ClickHouse/pull/66069) ([Vitaly Baranov](https://github.com/vitlibar)).
|
||||||
|
* Use pinned versions of all python packages in CI docker images. Also makes clang-18.1.8 work with sanitizers and surprisingly fixes [#66049](https://github.com/ClickHouse/ClickHouse/issues/66049). [#66070](https://github.com/ClickHouse/ClickHouse/pull/66070) ([alesapin](https://github.com/alesapin)).
|
||||||
|
* Clean-up custom LLVM 15 patches. [#66072](https://github.com/ClickHouse/ClickHouse/pull/66072) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
|
* Minor JWT client fixes. [#66073](https://github.com/ClickHouse/ClickHouse/pull/66073) ([Konstantin Bogdanov](https://github.com/thevar1able)).
|
||||||
|
* Bump vectorscan to 5.4.11. [#66082](https://github.com/ClickHouse/ClickHouse/pull/66082) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
|
* Print stacktrace in case of abort after logical error. [#66091](https://github.com/ClickHouse/ClickHouse/pull/66091) ([Nikolai Kochetov](https://github.com/KochetovNicolai)).
|
||||||
|
* fix flaky 03172_error_log_table_not_empty. [#66093](https://github.com/ClickHouse/ClickHouse/pull/66093) ([Sema Checherinda](https://github.com/CheSema)).
|
||||||
|
* Bump s2geometry to latest master. [#66094](https://github.com/ClickHouse/ClickHouse/pull/66094) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
|
* update keeper bench example config file. [#66095](https://github.com/ClickHouse/ClickHouse/pull/66095) ([Han Fei](https://github.com/hanfei1991)).
|
||||||
|
* Avoid using source directory for generated files. [#66097](https://github.com/ClickHouse/ClickHouse/pull/66097) ([Azat Khuzhin](https://github.com/azat)).
|
||||||
|
* More precise warning message about sanitizers. [#66098](https://github.com/ClickHouse/ClickHouse/pull/66098) ([Anton Popov](https://github.com/CurtizJ)).
|
||||||
|
* Slightly better calculation of primary index. [#66099](https://github.com/ClickHouse/ClickHouse/pull/66099) ([Anton Popov](https://github.com/CurtizJ)).
|
||||||
|
* Bump Azure to 1.12. [#66100](https://github.com/ClickHouse/ClickHouse/pull/66100) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
|
* Add a test for [#58998](https://github.com/ClickHouse/ClickHouse/issues/58998). [#66101](https://github.com/ClickHouse/ClickHouse/pull/66101) ([Anton Popov](https://github.com/CurtizJ)).
|
||||||
|
* CI: Fix sync pr merge. [#66105](https://github.com/ClickHouse/ClickHouse/pull/66105) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Remove flaky case from 02956_rocksdb_bulk_sink. [#66107](https://github.com/ClickHouse/ClickHouse/pull/66107) ([vdimir](https://github.com/vdimir)).
|
||||||
|
* Fix bugfix checker. [#66120](https://github.com/ClickHouse/ClickHouse/pull/66120) ([Raúl Marín](https://github.com/Algunenano)).
|
||||||
|
* Correctly print long processing requests in Keeper. [#66124](https://github.com/ClickHouse/ClickHouse/pull/66124) ([Antonio Andelic](https://github.com/antonio2368)).
|
||||||
|
* Update version_date.tsv and changelogs after v24.6.2.17-stable. [#66127](https://github.com/ClickHouse/ClickHouse/pull/66127) ([robot-clickhouse](https://github.com/robot-clickhouse)).
|
||||||
|
* Bump s2geometry again. [#66136](https://github.com/ClickHouse/ClickHouse/pull/66136) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
|
* Switch submodule `contrib/orc` to a proper commit in the [main](https://github.com/ClickHouse/orc/tree/main) branch. Previously a commit from a removed branch was used ([see](https://github.com/ClickHouse/orc/pull/13)). [#66137](https://github.com/ClickHouse/ClickHouse/pull/66137) ([Vitaly Baranov](https://github.com/vitlibar)).
|
||||||
|
* Finalize MergedBlockOutputStream in dtor. [#66138](https://github.com/ClickHouse/ClickHouse/pull/66138) ([Nikita Taranov](https://github.com/nickitat)).
|
||||||
|
* Proper destruction order of AsyncLoader::Pool fields. [#66145](https://github.com/ClickHouse/ClickHouse/pull/66145) ([Sergei Trifonov](https://github.com/serxa)).
|
||||||
|
* Playing minesweeper with build system. [#66147](https://github.com/ClickHouse/ClickHouse/pull/66147) ([Nikita Taranov](https://github.com/nickitat)).
|
||||||
|
* Fix clang-tidy error in BufferWithOwnMemory.h. [#66161](https://github.com/ClickHouse/ClickHouse/pull/66161) ([Nikita Taranov](https://github.com/nickitat)).
|
||||||
|
* Use peak_threads_usage instead of arrayUniq(thread_ids) in tests. [#66162](https://github.com/ClickHouse/ClickHouse/pull/66162) ([Azat Khuzhin](https://github.com/azat)).
|
||||||
|
* Fix crash when adding empty tuple to query cache. [#66168](https://github.com/ClickHouse/ClickHouse/pull/66168) ([Michael Kolupaev](https://github.com/al13n321)).
|
||||||
|
* tests: fix 01563_distributed_query_finish flakiness (due to system.*_log_sender). [#66171](https://github.com/ClickHouse/ClickHouse/pull/66171) ([Azat Khuzhin](https://github.com/azat)).
|
||||||
|
* Refactor `OptimizeIfWithConstantConditionVisitor` using `InDepthNodeVisitor`. [#66184](https://github.com/ClickHouse/ClickHouse/pull/66184) ([zhongyuankai](https://github.com/zhongyuankai)).
|
||||||
|
* Update README.md. [#66186](https://github.com/ClickHouse/ClickHouse/pull/66186) ([Tyler Hannan](https://github.com/tylerhannan)).
|
||||||
|
* Fix 01246_buffer_flush flakiness. [#66188](https://github.com/ClickHouse/ClickHouse/pull/66188) ([Azat Khuzhin](https://github.com/azat)).
|
||||||
|
* Avoid using harmful function `rand()` in grpc. [#66191](https://github.com/ClickHouse/ClickHouse/pull/66191) ([Vitaly Baranov](https://github.com/vitlibar)).
|
||||||
|
* Bump RocksDB. [#66216](https://github.com/ClickHouse/ClickHouse/pull/66216) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
|
* Update README.md. [#66217](https://github.com/ClickHouse/ClickHouse/pull/66217) ([Tyler Hannan](https://github.com/tylerhannan)).
|
||||||
|
* Fixes peak_threads_usage metric when materialised views are involved. [#66230](https://github.com/ClickHouse/ClickHouse/pull/66230) ([Sema Checherinda](https://github.com/CheSema)).
|
||||||
|
* Remove test as requested in https://github.com/ClickHouse/ClickHouse/pull/65277#issuecomment-2211361465. [#66233](https://github.com/ClickHouse/ClickHouse/pull/66233) ([Arthur Passos](https://github.com/arthurpassos)).
|
||||||
|
* Fix test `00504_mergetree_arrays_rw.sql`. [#66248](https://github.com/ClickHouse/ClickHouse/pull/66248) ([Anton Popov](https://github.com/CurtizJ)).
|
||||||
|
* CI: Do not finalize CI running status unless all success. [#66276](https://github.com/ClickHouse/ClickHouse/pull/66276) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Collect core dumps in more tests. [#66281](https://github.com/ClickHouse/ClickHouse/pull/66281) ([Antonio Andelic](https://github.com/antonio2368)).
|
||||||
|
* Add a stateless test for gRPC protocol. [#66284](https://github.com/ClickHouse/ClickHouse/pull/66284) ([Vitaly Baranov](https://github.com/vitlibar)).
|
||||||
|
* Log message: Failed to connect to replica ... [#66289](https://github.com/ClickHouse/ClickHouse/pull/66289) ([Igor Nikonov](https://github.com/devcrafter)).
|
||||||
|
* Update run.sh. [#66290](https://github.com/ClickHouse/ClickHouse/pull/66290) ([Kseniia Sumarokova](https://github.com/kssenii)).
|
||||||
|
* Some changes in the codebase as a preparation for LLVM 18. [#66293](https://github.com/ClickHouse/ClickHouse/pull/66293) ([Nikita Mikhaylov](https://github.com/nikitamikhaylov)).
|
||||||
|
* There's some problem with iptables in parallel tests. [#66304](https://github.com/ClickHouse/ClickHouse/pull/66304) ([Alexander Tokmakov](https://github.com/tavplubix)).
|
||||||
|
* Disable broken cases from 02911_join_on_nullsafe_optimization. [#66310](https://github.com/ClickHouse/ClickHouse/pull/66310) ([vdimir](https://github.com/vdimir)).
|
||||||
|
* Build failure if ENABLE_AWS_S3 is OFF fixed. [#66335](https://github.com/ClickHouse/ClickHouse/pull/66335) ([Ilya Golshtein](https://github.com/ilejn)).
|
||||||
|
* Enable checks in assert_cast under sanitizers. [#66336](https://github.com/ClickHouse/ClickHouse/pull/66336) ([Nikita Taranov](https://github.com/nickitat)).
|
||||||
|
* Create release workflow. [#66339](https://github.com/ClickHouse/ClickHouse/pull/66339) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Fix invalid XML. [#66342](https://github.com/ClickHouse/ClickHouse/pull/66342) ([János Benjamin Antal](https://github.com/antaljanosbenjamin)).
|
||||||
|
* Fix possible deadlock for jemalloc with enabled profiler. [#66346](https://github.com/ClickHouse/ClickHouse/pull/66346) ([Azat Khuzhin](https://github.com/azat)).
|
||||||
|
* Fix test_parallel_replicas_custom_key. [#66349](https://github.com/ClickHouse/ClickHouse/pull/66349) ([Antonio Andelic](https://github.com/antonio2368)).
|
||||||
|
* Collect logs from `minio` in stateless and statefull tests. [#66353](https://github.com/ClickHouse/ClickHouse/pull/66353) ([János Benjamin Antal](https://github.com/antaljanosbenjamin)).
|
||||||
|
* Fix "Sending a batch of X files to Y (0.00 rows, 0.00 B bytes)." in case of batch restoring. [#66375](https://github.com/ClickHouse/ClickHouse/pull/66375) ([Azat Khuzhin](https://github.com/azat)).
|
||||||
|
* Fix 03030_system_flush_distributed_settings flakiness. [#66376](https://github.com/ClickHouse/ClickHouse/pull/66376) ([Azat Khuzhin](https://github.com/azat)).
|
||||||
|
* PR cleanup: remove redundant code. [#66380](https://github.com/ClickHouse/ClickHouse/pull/66380) ([Igor Nikonov](https://github.com/devcrafter)).
|
||||||
|
* New slack bot to post messages about CI events - Post message if OOM. [#66392](https://github.com/ClickHouse/ClickHouse/pull/66392) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Ignore subquery for IN in DDLLoadingDependencyVisitor. [#66395](https://github.com/ClickHouse/ClickHouse/pull/66395) ([Nikolai Kochetov](https://github.com/KochetovNicolai)).
|
||||||
|
* Update test_storage_rabbitmq/test.py. [#66396](https://github.com/ClickHouse/ClickHouse/pull/66396) ([Kseniia Sumarokova](https://github.com/kssenii)).
|
||||||
|
* Add query elapsed time for non-default format in play UI. [#66398](https://github.com/ClickHouse/ClickHouse/pull/66398) ([Azat Khuzhin](https://github.com/azat)).
|
||||||
|
* Untangle setting headers. [#66404](https://github.com/ClickHouse/ClickHouse/pull/66404) ([Raúl Marín](https://github.com/Algunenano)).
|
||||||
|
* Remove noisy message. [#66406](https://github.com/ClickHouse/ClickHouse/pull/66406) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* If job detected as in-progress in PR workflow run - just remove it from todo list, as it not affected by the change. [#66407](https://github.com/ClickHouse/ClickHouse/pull/66407) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* CI: CIBuddy to post from master only. [#66417](https://github.com/ClickHouse/ClickHouse/pull/66417) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Add a test for [#66333](https://github.com/ClickHouse/ClickHouse/issues/66333). [#66432](https://github.com/ClickHouse/ClickHouse/pull/66432) ([max-vostrikov](https://github.com/max-vostrikov)).
|
||||||
|
* Limit number of linker jobs on arm to avoid OOM during build. [#66435](https://github.com/ClickHouse/ClickHouse/pull/66435) ([Nikita Taranov](https://github.com/nickitat)).
|
||||||
|
* [RFC] Fix jemalloc assertion due to non-monotonic CLOCK_MONOTONIC_COARSE. [#66439](https://github.com/ClickHouse/ClickHouse/pull/66439) ([Azat Khuzhin](https://github.com/azat)).
|
||||||
|
* CI: Do not block CI on few number of test failures. [#66440](https://github.com/ClickHouse/ClickHouse/pull/66440) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Stateless tests: fix flaky tests 01037_polygon_dicts*. [#66445](https://github.com/ClickHouse/ClickHouse/pull/66445) ([Nikita Fomichev](https://github.com/fm4v)).
|
||||||
|
* Related to https://github.com/ClickHouse/ClickHouse/pull/62067 https://s3.amazonaws.com/clickhouse-test-reports/66410/5557dce188cabc7477bb4e874d47e3b80278ee66/stateless_tests__release_.html ``` 2024-07-12 16:04:29 +Queries for alter_table did not finish automatically after 250+ seconds 2024-07-12 16:04:29 +==================== QUERIES ==================== 2024-07-12 16:04:29 +Row 1: 2024-07-12 16:04:29 +────── 2024-07-12 16:04:29 +is_initial_query: 1 2024-07-12 16:04:29 +user: default 2024-07-12 16:04:29 +query_id: b43ffd7d-aee6-4161-aa82-bf9fff9d78c0 2024-07-12 16:04:29 +address: ::1 2024-07-12 16:04:29 +port: 58360 2024-07-12 16:04:29 +initial_user: default 2024-07-12 16:04:29 +initial_query_id: b43ffd7d-aee6-4161-aa82-bf9fff9d78c0 ... 2024-07-12 16:04:29 +query: OPTIMIZE TABLE alter_table0 FINAL ```. [#66460](https://github.com/ClickHouse/ClickHouse/pull/66460) ([Alexander Tokmakov](https://github.com/tavplubix)).
|
||||||
|
* OOM error was not visible since process is killed and status is not set Change sets ERROR status if job was killed. [#66463](https://github.com/ClickHouse/ClickHouse/pull/66463) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Add AST fuzzers jobs for CI caching so that they can be skipped in PRs not related to build or tests. [#66468](https://github.com/ClickHouse/ClickHouse/pull/66468) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* If job with the same digest has been seen in master's CI it should be skipped in PR run. [#66471](https://github.com/ClickHouse/ClickHouse/pull/66471) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* CI: Check job's exit status and report if killed. [#66477](https://github.com/ClickHouse/ClickHouse/pull/66477) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* This closes [#37557](https://github.com/ClickHouse/ClickHouse/issues/37557). [#66482](https://github.com/ClickHouse/ClickHouse/pull/66482) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* CI: Add retry for GH set_status_comment call. [#66488](https://github.com/ClickHouse/ClickHouse/pull/66488) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* OpenSSL: Minor follow-up to [#66064](https://github.com/ClickHouse/ClickHouse/issues/66064). [#66489](https://github.com/ClickHouse/ClickHouse/pull/66489) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
|
* CI: Fix for job filtering in PRs. [#66490](https://github.com/ClickHouse/ClickHouse/pull/66490) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* CI: Create release workflow updates. [#66498](https://github.com/ClickHouse/ClickHouse/pull/66498) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Add one more revision to ignore. [#66499](https://github.com/ClickHouse/ClickHouse/pull/66499) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Unit tests vomit a ton of garbage, see https://s3.amazonaws.com/clickhouse-test-reports/66457/0c82dc91f07b29ba503d7579c7d3ebecba532b73/unit_tests__tsan_/run.log - remove it. [#66501](https://github.com/ClickHouse/ClickHouse/pull/66501) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Fix double whitespace in EXPLAIN AST CREATE. [#66505](https://github.com/ClickHouse/ClickHouse/pull/66505) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Fix bad test `02530_dictionaries_update_field`. [#66507](https://github.com/ClickHouse/ClickHouse/pull/66507) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Https://play.clickhouse.com/play?user=play#u0vmrunuignozwnrx3n0yxj0x3rpbwusignozwnrx25hbwusihrlc3rfbmftzswgcmvwb3j0x3vybapguk9nignozwnrcwpxsevsrsbjagvja19zdgfydf90aw1lid49ig5vdygpic0gsu5urvjwquwgmjqwiehpvvikicagieforcbwdwxsx3jlcxvlc3rfbnvtymvyid0gmaogicagqu5eihrlc3rfc3rhdhvzice9icdts0lquevejwogicagqu5eihrlc3rfc3rhdhvziexjs0ugj0yljwogicagqu5eignozwnrx3n0yxr1cyahpsanc3vjy2vzcyckicagieforcbwb3npdglvbih0zxn0x25hbwusicdhcgfjagvfyxjyb3cnksa+idakt1jervigqlkgy2hly2tfc3rhcnrfdgltzq==. [#66508](https://github.com/ClickHouse/ClickHouse/pull/66508) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Fix MSan report in GRPC. [#66509](https://github.com/ClickHouse/ClickHouse/pull/66509) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* CI: Fix for skipping Builds_2 in PRs' CI. [#66512](https://github.com/ClickHouse/ClickHouse/pull/66512) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* CI: Do not block Tests_3 unless MAX_FAILED_TESTS exceeded. [#66513](https://github.com/ClickHouse/ClickHouse/pull/66513) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Fix `02918_parallel_replicas_custom_key_unavailable_replica`. [#66516](https://github.com/ClickHouse/ClickHouse/pull/66516) ([Antonio Andelic](https://github.com/antonio2368)).
|
||||||
|
* Stateless tests: improvements related to OOM of test runs. [#66520](https://github.com/ClickHouse/ClickHouse/pull/66520) ([Nikita Fomichev](https://github.com/fm4v)).
|
||||||
|
* Tests: rename bad log names. [#66522](https://github.com/ClickHouse/ClickHouse/pull/66522) ([Nikita Fomichev](https://github.com/fm4v)).
|
||||||
|
* Add additional log masking in CI. [#66523](https://github.com/ClickHouse/ClickHouse/pull/66523) ([Raúl Marín](https://github.com/Algunenano)).
|
||||||
|
* CI: Multiple fixes for handling killed jobs. [#66524](https://github.com/ClickHouse/ClickHouse/pull/66524) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Allow GWP Asan allocations only when initialization is finished. [#66526](https://github.com/ClickHouse/ClickHouse/pull/66526) ([Alexey Katsman](https://github.com/alexkats)).
|
||||||
|
* Update 02443_detach_attach_partition.sh. [#66529](https://github.com/ClickHouse/ClickHouse/pull/66529) ([Alexander Tokmakov](https://github.com/tavplubix)).
|
||||||
|
* Follow up [#66435](https://github.com/ClickHouse/ClickHouse/issues/66435). [#66530](https://github.com/ClickHouse/ClickHouse/pull/66530) ([Nikita Taranov](https://github.com/nickitat)).
|
||||||
|
* fix log in keeper tcp handler. [#66531](https://github.com/ClickHouse/ClickHouse/pull/66531) ([Han Fei](https://github.com/hanfei1991)).
|
||||||
|
* CI: Report job start and finish to CI DB. [#66533](https://github.com/ClickHouse/ClickHouse/pull/66533) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Update 01396_inactive_replica_cleanup_nodes_zookeeper.sh. [#66535](https://github.com/ClickHouse/ClickHouse/pull/66535) ([Alexander Tokmakov](https://github.com/tavplubix)).
|
||||||
|
* Add dedicated runner to libfuzzer, update docker. [#66551](https://github.com/ClickHouse/ClickHouse/pull/66551) ([Yakov Olkhovskiy](https://github.com/yakov-olkhovskiy)).
|
||||||
|
* fix tidy build. [#66552](https://github.com/ClickHouse/ClickHouse/pull/66552) ([Sema Checherinda](https://github.com/CheSema)).
|
||||||
|
* No-op env change. [#66553](https://github.com/ClickHouse/ClickHouse/pull/66553) ([Raúl Marín](https://github.com/Algunenano)).
|
||||||
|
* Fix typo in new_delete.cpp. [#66554](https://github.com/ClickHouse/ClickHouse/pull/66554) ([alesapin](https://github.com/alesapin)).
|
||||||
|
* Fix something in Fast Test. [#66558](https://github.com/ClickHouse/ClickHouse/pull/66558) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* update trusted contributors. [#66561](https://github.com/ClickHouse/ClickHouse/pull/66561) ([Xu Jia](https://github.com/XuJia0210)).
|
||||||
|
* Delete bad test `02805_distributed_queries_timeouts`. [#66563](https://github.com/ClickHouse/ClickHouse/pull/66563) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* More clarity in the test `03001_consider_lwd_when_merge`. [#66564](https://github.com/ClickHouse/ClickHouse/pull/66564) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Stateless tests: temporary disable sequential tests in parallel. [#66585](https://github.com/ClickHouse/ClickHouse/pull/66585) ([Nikita Fomichev](https://github.com/fm4v)).
|
||||||
|
* Move view targets to separate AST class `ASTViewTargets` in order to allow extending it to support more kinds of view targets. [#66590](https://github.com/ClickHouse/ClickHouse/pull/66590) ([Vitaly Baranov](https://github.com/vitlibar)).
|
||||||
|
* Fix bsdtar for @nikitamikhaylov. [#66592](https://github.com/ClickHouse/ClickHouse/pull/66592) ([alesapin](https://github.com/alesapin)).
|
||||||
|
* CI: POC for Auto Releases. [#66593](https://github.com/ClickHouse/ClickHouse/pull/66593) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Fix clang tidy after [#66402](https://github.com/ClickHouse/ClickHouse/issues/66402). [#66597](https://github.com/ClickHouse/ClickHouse/pull/66597) ([vdimir](https://github.com/vdimir)).
|
||||||
|
* Adjust the runtime of some slow performance test. [#66619](https://github.com/ClickHouse/ClickHouse/pull/66619) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
|
* CI: Scale down AutoScaling Groups from runners. [#66622](https://github.com/ClickHouse/ClickHouse/pull/66622) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Allow to run clang-tidy with clang-19. [#66625](https://github.com/ClickHouse/ClickHouse/pull/66625) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Fix terrible test @arthurpassos. [#66632](https://github.com/ClickHouse/ClickHouse/pull/66632) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Fix bad log message. [#66633](https://github.com/ClickHouse/ClickHouse/pull/66633) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Negative sign in prewhere optimization. [#66637](https://github.com/ClickHouse/ClickHouse/pull/66637) ([cangyin](https://github.com/cangyin)).
|
||||||
|
* Closes [#66639](https://github.com/ClickHouse/ClickHouse/issues/66639#event-13533944949). [#66640](https://github.com/ClickHouse/ClickHouse/pull/66640) ([Kruglov Pavel](https://github.com/Avogar)).
|
||||||
|
* Avoid generating named tuple for special keywords (null, true, false). [#66641](https://github.com/ClickHouse/ClickHouse/pull/66641) ([Amos Bird](https://github.com/amosbird)).
|
||||||
|
* rearrange heavy tests 03008_deduplication. [#66642](https://github.com/ClickHouse/ClickHouse/pull/66642) ([Sema Checherinda](https://github.com/CheSema)).
|
||||||
|
* Fix data race in S3::ClientCache. [#66644](https://github.com/ClickHouse/ClickHouse/pull/66644) ([Konstantin Morozov](https://github.com/k-morozov)).
|
||||||
|
* CI: Remove aws lambda packages from oss. [#66651](https://github.com/ClickHouse/ClickHouse/pull/66651) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Introduce separate DEBUG_OR_SANITIZER_BUILD macro. [#66652](https://github.com/ClickHouse/ClickHouse/pull/66652) ([Nikita Taranov](https://github.com/nickitat)).
|
||||||
|
* Increase backoff because with slow builds sometimes 100ms is not enough to recover. [#66653](https://github.com/ClickHouse/ClickHouse/pull/66653) ([alesapin](https://github.com/alesapin)).
|
||||||
|
* Fix wrong queries hung error because of 02044_url_glob_parallel_connection_refused. [#66657](https://github.com/ClickHouse/ClickHouse/pull/66657) ([Nikita Taranov](https://github.com/nickitat)).
|
||||||
|
* add log for splitBlockIntoParts. [#66658](https://github.com/ClickHouse/ClickHouse/pull/66658) ([Han Fei](https://github.com/hanfei1991)).
|
||||||
|
* Minor: Make `CaseSensitiveness` an enum class. [#66673](https://github.com/ClickHouse/ClickHouse/pull/66673) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
|
* Fix bad test `02210_processors_profile_log`. [#66684](https://github.com/ClickHouse/ClickHouse/pull/66684) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Fix something around clang-tidy. [#66694](https://github.com/ClickHouse/ClickHouse/pull/66694) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* ci: dump dmesg in case of OOM. [#66705](https://github.com/ClickHouse/ClickHouse/pull/66705) ([Azat Khuzhin](https://github.com/azat)).
|
||||||
|
* fix clang tidy. [#66706](https://github.com/ClickHouse/ClickHouse/pull/66706) ([Han Fei](https://github.com/hanfei1991)).
|
||||||
|
* Https://s3.amazonaws.com/clickhouse-test-reports/61109/5cf2b53f146c1a4f24d8212f9f810d587c46bfc0/stateless_tests__release_.html. [#66724](https://github.com/ClickHouse/ClickHouse/pull/66724) ([Alexander Tokmakov](https://github.com/tavplubix)).
|
||||||
|
* Support one more case in JOIN ON ... IS NULL. [#66725](https://github.com/ClickHouse/ClickHouse/pull/66725) ([vdimir](https://github.com/vdimir)).
|
||||||
|
* CI: Fix issue with a skipped Build report. [#66726](https://github.com/ClickHouse/ClickHouse/pull/66726) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* relax condition in test, remove unused counters. [#66730](https://github.com/ClickHouse/ClickHouse/pull/66730) ([Sema Checherinda](https://github.com/CheSema)).
|
||||||
|
* Remove bad test `host_resolver_fail_count`. [#66731](https://github.com/ClickHouse/ClickHouse/pull/66731) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Fix bad test `03036_join_filter_push_down_equivalent_sets`. [#66736](https://github.com/ClickHouse/ClickHouse/pull/66736) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Fix bad tests `long_select_and_alter`. [#66737](https://github.com/ClickHouse/ClickHouse/pull/66737) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Add test test_storage_mysql/test.py::test_joins. [#66743](https://github.com/ClickHouse/ClickHouse/pull/66743) ([vdimir](https://github.com/vdimir)).
|
||||||
|
* Disallow build exclusion only by CI settings (ci_include_, ci_exclude_) to avoid running builds in auto sync prs. [#66744](https://github.com/ClickHouse/ClickHouse/pull/66744) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Use non-existent address to check connection error at table creation. [#66760](https://github.com/ClickHouse/ClickHouse/pull/66760) ([János Benjamin Antal](https://github.com/antaljanosbenjamin)).
|
||||||
|
* Backported in [#67063](https://github.com/ClickHouse/ClickHouse/issues/67063): Increase asio pool size in case the server is tiny. [#66761](https://github.com/ClickHouse/ClickHouse/pull/66761) ([alesapin](https://github.com/alesapin)).
|
||||||
|
* Fix flakiness of async insert tests due to adaptive timeout. [#66771](https://github.com/ClickHouse/ClickHouse/pull/66771) ([Raúl Marín](https://github.com/Algunenano)).
|
||||||
|
* Attempt to fix flakiness of 01194_http_query_id. [#66774](https://github.com/ClickHouse/ClickHouse/pull/66774) ([Raúl Marín](https://github.com/Algunenano)).
|
||||||
|
* Turn off randomization of harmful setting. [#66776](https://github.com/ClickHouse/ClickHouse/pull/66776) ([alesapin](https://github.com/alesapin)).
|
||||||
|
* The number of batches was reduced in https://github.com/ClickHouse/ClickHouse/pull/65186, but then the parallel execution was disabled in https://github.com/ClickHouse/ClickHouse/pull/66585. So now tasks fail with timeout sometimes: https://s3.amazonaws.com/clickhouse-test-reports/66724/36275fdacc34206931f69087fe77539e25bbbedd/stateless_tests__tsan__s3_storage__[2_3].html. [#66783](https://github.com/ClickHouse/ClickHouse/pull/66783) ([Alexander Tokmakov](https://github.com/tavplubix)).
|
||||||
|
* Remove obsolete code from CMakeLists. [#66786](https://github.com/ClickHouse/ClickHouse/pull/66786) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Stateless tests: split parallel tests more evenly. [#66787](https://github.com/ClickHouse/ClickHouse/pull/66787) ([Nikita Fomichev](https://github.com/fm4v)).
|
||||||
|
* Fix test `02724_limit_num_mutations.sh`. [#66788](https://github.com/ClickHouse/ClickHouse/pull/66788) ([Anton Popov](https://github.com/CurtizJ)).
|
||||||
|
* Better diagnostics in `test_disk_configuration`. [#66802](https://github.com/ClickHouse/ClickHouse/pull/66802) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Fix bad test `02950_part_log_bytes_uncompressed`. [#66803](https://github.com/ClickHouse/ClickHouse/pull/66803) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Better diagnostics for test trace_events_stress. [#66804](https://github.com/ClickHouse/ClickHouse/pull/66804) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Make test `00997_set_index_array` lighter. [#66817](https://github.com/ClickHouse/ClickHouse/pull/66817) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Miscellaneous. [#66818](https://github.com/ClickHouse/ClickHouse/pull/66818) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Fix inconsistent formatting of lambda functions inside composite types. [#66819](https://github.com/ClickHouse/ClickHouse/pull/66819) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Small fix in realloc memory tracking. [#66820](https://github.com/ClickHouse/ClickHouse/pull/66820) ([Antonio Andelic](https://github.com/antonio2368)).
|
||||||
|
* Never await in CI on BuildReport - just redo (await can be longer) - Remove BuildReport if no build jobs in workflow (for instance: Docs change) - Do not fail CheckReadyForMerge job if the only non-green status is Cloud Sync. [#66822](https://github.com/ClickHouse/ClickHouse/pull/66822) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Remove bad tests @azat. [#66823](https://github.com/ClickHouse/ClickHouse/pull/66823) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* CI: New Release workflow updates and fixes. [#66830](https://github.com/ClickHouse/ClickHouse/pull/66830) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Fix signed integer overflow in function `age`. [#66831](https://github.com/ClickHouse/ClickHouse/pull/66831) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
|
* Fix RocksDB bs. [#66838](https://github.com/ClickHouse/ClickHouse/pull/66838) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Split a test for index. [#66839](https://github.com/ClickHouse/ClickHouse/pull/66839) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Fix inconsistent formatting of `NOT ((SELECT ...))`. [#66840](https://github.com/ClickHouse/ClickHouse/pull/66840) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Make test `01592_long_window_functions1` lighter. [#66841](https://github.com/ClickHouse/ClickHouse/pull/66841) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* What if I will change the test for SSL authentication?. [#66844](https://github.com/ClickHouse/ClickHouse/pull/66844) ([Alexey Milovidov](https://github.com/alexey-milovidov)).
|
||||||
|
* Functions `[a-g]*`: Iterate over `input_rows_count` where appropriate. [#66846](https://github.com/ClickHouse/ClickHouse/pull/66846) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
|
* Revert libunwind patch. [#66850](https://github.com/ClickHouse/ClickHouse/pull/66850) ([Antonio Andelic](https://github.com/antonio2368)).
|
||||||
|
* Split test 03038_nested_dynamic_merges to avoid timeouts. [#66863](https://github.com/ClickHouse/ClickHouse/pull/66863) ([Kruglov Pavel](https://github.com/Avogar)).
|
||||||
|
* CI: Print instance info in runner's init script. [#66868](https://github.com/ClickHouse/ClickHouse/pull/66868) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Backported in [#67257](https://github.com/ClickHouse/ClickHouse/issues/67257): Followup [#66725](https://github.com/ClickHouse/ClickHouse/issues/66725). [#66869](https://github.com/ClickHouse/ClickHouse/pull/66869) ([vdimir](https://github.com/vdimir)).
|
||||||
|
* CI: CI Buddy to notify about fatal workflow failures. [#66890](https://github.com/ClickHouse/ClickHouse/pull/66890) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* CI: Add ec2 instance lifecycle metadata to CIDB. [#66918](https://github.com/ClickHouse/ClickHouse/pull/66918) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* CI: Remove ci runners scripts from oss. [#66920](https://github.com/ClickHouse/ClickHouse/pull/66920) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Backported in [#67209](https://github.com/ClickHouse/ClickHouse/issues/67209): Decrease rate limit in `01923_network_receive_time_metric_insert`. [#66924](https://github.com/ClickHouse/ClickHouse/pull/66924) ([János Benjamin Antal](https://github.com/antaljanosbenjamin)).
|
||||||
|
* Backported in [#67227](https://github.com/ClickHouse/ClickHouse/issues/67227): Grouparrayintersect: fix serialization bug. [#66928](https://github.com/ClickHouse/ClickHouse/pull/66928) ([Raúl Marín](https://github.com/Algunenano)).
|
||||||
|
* Backported in [#67207](https://github.com/ClickHouse/ClickHouse/issues/67207): Un-flake test_runtime_configurable_cache_size. [#66934](https://github.com/ClickHouse/ClickHouse/pull/66934) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
|
* Backported in [#66975](https://github.com/ClickHouse/ClickHouse/issues/66975): CI: Fixes docker server build for release branches. [#66955](https://github.com/ClickHouse/ClickHouse/pull/66955) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Backported in [#67213](https://github.com/ClickHouse/ClickHouse/issues/67213): [CI Fest] Split dynamic tests and rewrite them from sh to sql to avoid timeouts. [#66981](https://github.com/ClickHouse/ClickHouse/pull/66981) ([Kruglov Pavel](https://github.com/Avogar)).
|
||||||
|
* Backported in [#67033](https://github.com/ClickHouse/ClickHouse/issues/67033): [CI Fest] Fix use-of-uninitialized-value in JSONExtract* numeric functions. [#66984](https://github.com/ClickHouse/ClickHouse/pull/66984) ([Kruglov Pavel](https://github.com/Avogar)).
|
||||||
|
* Backported in [#67051](https://github.com/ClickHouse/ClickHouse/issues/67051): CI: Fix for workflow results parsing. [#67000](https://github.com/ClickHouse/ClickHouse/pull/67000) ([Max K.](https://github.com/maxknv)).
|
||||||
|
* Backported in [#67116](https://github.com/ClickHouse/ClickHouse/issues/67116): Disable setting `optimize_functions_to_subcolumns`. [#67046](https://github.com/ClickHouse/ClickHouse/pull/67046) ([Anton Popov](https://github.com/CurtizJ)).
|
||||||
|
* Backported in [#67205](https://github.com/ClickHouse/ClickHouse/issues/67205): Increase max allocation size for sanitizers. [#67049](https://github.com/ClickHouse/ClickHouse/pull/67049) ([János Benjamin Antal](https://github.com/antaljanosbenjamin)).
|
||||||
|
* Backported in [#67124](https://github.com/ClickHouse/ClickHouse/issues/67124): Very sad failure: ``` 2024.07.24 13:28:45.517777 [ 10 ] {08745bf9-4bc1-4946-b9a8-c03d82ec55dc} <Debug> executeQuery: (from 172.16.11.1:55890) OPTIMIZE TABLE replicated_mt FINAL (stage: Complete) 2024.07.24 13:28:45.525945 [ 10 ] {08745bf9-4bc1-4946-b9a8-c03d82ec55dc} <Trace> default.replicated_mt (ReplicatedMergeTreeQueue): Waiting for 4 entries to be processed: queue-0000000004, queue-0000000002, queue-0000000001, queue-0000000000 2024.07.24 13:29:15.528024 [ 10 ] {08745bf9-4bc1-4946-b9a8-c03d82ec55dc} <Debug> default.replicated_mt (6581a6fb-8458-466d-8350-89951eb1ac8e) (MergerMutator): Selected 3 parts from all_0_0_0 to all_2_2_0 2024.07.24 13:29:15.530736 [ 10 ] {08745bf9-4bc1-4946-b9a8-c03d82ec55dc} <Trace> default.replicated_mt (6581a6fb-8458-466d-8350-89951eb1ac8e): Created log entry /clickhouse/tables/replicated_mt/log/log-0000000004 for merge all_0_2_1 2024.07.24 13:29:15.530873 [ 10 ] {08745bf9-4bc1-4946-b9a8-c03d82ec55dc} <Debug> default.replicated_mt (6581a6fb-8458-466d-8350-89951eb1ac8e): Waiting for node1 to process log entry 2024.07.24 13:29:15.530919 [ 10 ] {08745bf9-4bc1-4946-b9a8-c03d82ec55dc} <Debug> default.replicated_mt (6581a6fb-8458-466d-8350-89951eb1ac8e): Waiting for node1 to pull log-0000000004 to queue 2024.07.24 13:29:15.534286 [ 10 ] {08745bf9-4bc1-4946-b9a8-c03d82ec55dc} <Debug> default.replicated_mt (6581a6fb-8458-466d-8350-89951eb1ac8e): Looking for node corresponding to log-0000000004 in node1 queue 2024.07.24 13:29:15.534793 [ 10 ] {08745bf9-4bc1-4946-b9a8-c03d82ec55dc} <Debug> default.replicated_mt (6581a6fb-8458-466d-8350-89951eb1ac8e): Waiting for queue-0000000005 to disappear from node1 queue 2024.07.24 13:29:15.585533 [ 10 ] {08745bf9-4bc1-4946-b9a8-c03d82ec55dc} <Debug> TCPHandler: Processed in 30.067804125 sec. ```. [#67067](https://github.com/ClickHouse/ClickHouse/pull/67067) ([alesapin](https://github.com/alesapin)).
|
||||||
|
* Backported in [#67203](https://github.com/ClickHouse/ClickHouse/issues/67203): Fix flaky `test_seekable_formats_url` and `test_seekable_formats` S3 storage tests. [#67070](https://github.com/ClickHouse/ClickHouse/pull/67070) ([János Benjamin Antal](https://github.com/antaljanosbenjamin)).
|
||||||
|
* Backported in [#67222](https://github.com/ClickHouse/ClickHouse/issues/67222): Fix 2680 flasky. [#67078](https://github.com/ClickHouse/ClickHouse/pull/67078) ([jsc0218](https://github.com/jsc0218)).
|
||||||
|
* Backported in [#67190](https://github.com/ClickHouse/ClickHouse/issues/67190): Attempt to fix flakiness of some window view tests. [#67130](https://github.com/ClickHouse/ClickHouse/pull/67130) ([Robert Schulze](https://github.com/rschu1ze)).
|
||||||
|
* Backported in [#67272](https://github.com/ClickHouse/ClickHouse/issues/67272): Rename (unreleased) bad setting. [#67149](https://github.com/ClickHouse/ClickHouse/pull/67149) ([Raúl Marín](https://github.com/Algunenano)).
|
||||||
|
* Backported in [#67441](https://github.com/ClickHouse/ClickHouse/issues/67441): Try to fix 2572. [#67158](https://github.com/ClickHouse/ClickHouse/pull/67158) ([jsc0218](https://github.com/jsc0218)).
|
||||||
|
* Backported in [#67416](https://github.com/ClickHouse/ClickHouse/issues/67416): CI: Fix build results for release branches. [#67402](https://github.com/ClickHouse/ClickHouse/pull/67402) ([Max K.](https://github.com/maxknv)).
|
||||||
|
|
@ -346,7 +346,9 @@ Result:
|
|||||||
## materialize
|
## materialize
|
||||||
|
|
||||||
Turns a constant into a full column containing a single value.
|
Turns a constant into a full column containing a single value.
|
||||||
Full columns and constants are represented differently in memory. Functions usually execute different code for normal and constant arguments, although the result should typically be the same. This function can be used to debug this behavior.
|
Full columns and constants are represented differently in memory.
|
||||||
|
Functions usually execute different code for normal and constant arguments, although the result should typically be the same.
|
||||||
|
This function can be used to debug this behavior.
|
||||||
|
|
||||||
**Syntax**
|
**Syntax**
|
||||||
|
|
||||||
@ -354,6 +356,34 @@ Full columns and constants are represented differently in memory. Functions usua
|
|||||||
materialize(x)
|
materialize(x)
|
||||||
```
|
```
|
||||||
|
|
||||||
|
**Parameters**
|
||||||
|
|
||||||
|
- `x` — A constant. [Constant](../functions/index.md/#constants).
|
||||||
|
|
||||||
|
**Returned value**
|
||||||
|
|
||||||
|
- A column containing a single value `x`.
|
||||||
|
|
||||||
|
**Example**
|
||||||
|
|
||||||
|
In the example below the `countMatches` function expects a constant second argument.
|
||||||
|
This behaviour can be debugged by using the `materialize` function to turn a constant into a full column,
|
||||||
|
verifying that the function throws an error for a non-constant argument.
|
||||||
|
|
||||||
|
Query:
|
||||||
|
|
||||||
|
```sql
|
||||||
|
SELECT countMatches('foobarfoo', 'foo');
|
||||||
|
SELECT countMatches('foobarfoo', materialize('foo'));
|
||||||
|
```
|
||||||
|
|
||||||
|
Result:
|
||||||
|
|
||||||
|
```response
|
||||||
|
2
|
||||||
|
Code: 44. DB::Exception: Received from localhost:9000. DB::Exception: Illegal type of argument #2 'pattern' of function countMatches, expected constant String, got String
|
||||||
|
```
|
||||||
|
|
||||||
## ignore
|
## ignore
|
||||||
|
|
||||||
Accepts any arguments, including `NULL` and does nothing. Always returns 0.
|
Accepts any arguments, including `NULL` and does nothing. Always returns 0.
|
||||||
|
@ -23,7 +23,7 @@ For more detail on window function syntax see: [Window Functions - Syntax](./ind
|
|||||||
**Parameters**
|
**Parameters**
|
||||||
- `x` — Column name.
|
- `x` — Column name.
|
||||||
- `offset` — Offset to apply. [(U)Int*](../data-types/int-uint.md). (Optional - `1` by default).
|
- `offset` — Offset to apply. [(U)Int*](../data-types/int-uint.md). (Optional - `1` by default).
|
||||||
- `default` — Value to return if calculated row exceeds the boundaries of the window frame. (Optional - `null` by default).
|
- `default` — Value to return if calculated row exceeds the boundaries of the window frame. (Optional - default value of column type when omitted).
|
||||||
|
|
||||||
**Returned value**
|
**Returned value**
|
||||||
|
|
||||||
|
@ -23,7 +23,7 @@ For more detail on window function syntax see: [Window Functions - Syntax](./ind
|
|||||||
**Parameters**
|
**Parameters**
|
||||||
- `x` — Column name.
|
- `x` — Column name.
|
||||||
- `offset` — Offset to apply. [(U)Int*](../data-types/int-uint.md). (Optional - `1` by default).
|
- `offset` — Offset to apply. [(U)Int*](../data-types/int-uint.md). (Optional - `1` by default).
|
||||||
- `default` — Value to return if calculated row exceeds the boundaries of the window frame. (Optional - `null` by default).
|
- `default` — Value to return if calculated row exceeds the boundaries of the window frame. (Optional - default value of column type when omitted).
|
||||||
|
|
||||||
**Returned value**
|
**Returned value**
|
||||||
|
|
||||||
|
@ -1,14 +1,16 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <Client/ClientBase.h>
|
#include <Client/ClientApplicationBase.h>
|
||||||
|
|
||||||
|
|
||||||
namespace DB
|
namespace DB
|
||||||
{
|
{
|
||||||
|
|
||||||
class Client : public ClientBase
|
class Client : public ClientApplicationBase
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
using Arguments = ClientApplicationBase::Arguments;
|
||||||
|
|
||||||
Client() = default;
|
Client() = default;
|
||||||
|
|
||||||
void initialize(Poco::Util::Application & self) override;
|
void initialize(Poco::Util::Application & self) override;
|
||||||
|
@ -80,7 +80,7 @@ namespace ErrorCodes
|
|||||||
|
|
||||||
void applySettingsOverridesForLocal(ContextMutablePtr context)
|
void applySettingsOverridesForLocal(ContextMutablePtr context)
|
||||||
{
|
{
|
||||||
Settings settings = context->getSettings();
|
Settings settings = context->getSettingsCopy();
|
||||||
|
|
||||||
settings.allow_introspection_functions = true;
|
settings.allow_introspection_functions = true;
|
||||||
settings.storage_file_read_method = LocalFSReadMethod::mmap;
|
settings.storage_file_read_method = LocalFSReadMethod::mmap;
|
||||||
@ -184,6 +184,11 @@ void LocalServer::initialize(Poco::Util::Application & self)
|
|||||||
cleanup_threads,
|
cleanup_threads,
|
||||||
0, // We don't need any threads one all the parts will be deleted
|
0, // We don't need any threads one all the parts will be deleted
|
||||||
cleanup_threads);
|
cleanup_threads);
|
||||||
|
|
||||||
|
getDatabaseCatalogDropTablesThreadPool().initialize(
|
||||||
|
server_settings.database_catalog_drop_table_concurrency,
|
||||||
|
0, // We don't need any threads if there are no DROP queries.
|
||||||
|
server_settings.database_catalog_drop_table_concurrency);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <Client/ClientBase.h>
|
#include <Client/ClientApplicationBase.h>
|
||||||
#include <Client/LocalConnection.h>
|
#include <Client/LocalConnection.h>
|
||||||
|
|
||||||
#include <Core/ServerSettings.h>
|
#include <Core/ServerSettings.h>
|
||||||
@ -21,7 +21,7 @@ namespace DB
|
|||||||
/// Lightweight Application for clickhouse-local
|
/// Lightweight Application for clickhouse-local
|
||||||
/// No networking, no extra configs and working directories, no pid and status files, no dictionaries, no logging.
|
/// No networking, no extra configs and working directories, no pid and status files, no dictionaries, no logging.
|
||||||
/// Quiet mode by default
|
/// Quiet mode by default
|
||||||
class LocalServer : public ClientBase, public Loggers
|
class LocalServer : public ClientApplicationBase, public Loggers
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
LocalServer() = default;
|
LocalServer() = default;
|
||||||
|
@ -1043,6 +1043,11 @@ try
|
|||||||
0, // We don't need any threads once all the tables will be created
|
0, // We don't need any threads once all the tables will be created
|
||||||
max_database_replicated_create_table_thread_pool_size);
|
max_database_replicated_create_table_thread_pool_size);
|
||||||
|
|
||||||
|
getDatabaseCatalogDropTablesThreadPool().initialize(
|
||||||
|
server_settings.database_catalog_drop_table_concurrency,
|
||||||
|
0, // We don't need any threads if there are no DROP queries.
|
||||||
|
server_settings.database_catalog_drop_table_concurrency);
|
||||||
|
|
||||||
/// Initialize global local cache for remote filesystem.
|
/// Initialize global local cache for remote filesystem.
|
||||||
if (config().has("local_cache_for_remote_fs"))
|
if (config().has("local_cache_for_remote_fs"))
|
||||||
{
|
{
|
||||||
@ -1590,6 +1595,8 @@ try
|
|||||||
global_context->setMacros(std::make_unique<Macros>(*config, "macros", log));
|
global_context->setMacros(std::make_unique<Macros>(*config, "macros", log));
|
||||||
global_context->setExternalAuthenticatorsConfig(*config);
|
global_context->setExternalAuthenticatorsConfig(*config);
|
||||||
|
|
||||||
|
global_context->setDashboardsConfig(config);
|
||||||
|
|
||||||
if (global_context->isServerCompletelyStarted())
|
if (global_context->isServerCompletelyStarted())
|
||||||
{
|
{
|
||||||
/// It does not make sense to reload anything before server has started.
|
/// It does not make sense to reload anything before server has started.
|
||||||
|
@ -1312,6 +1312,31 @@
|
|||||||
<ttl>event_date + INTERVAL 30 DAY</ttl>
|
<ttl>event_date + INTERVAL 30 DAY</ttl>
|
||||||
</blob_storage_log>
|
</blob_storage_log>
|
||||||
|
|
||||||
|
<!-- Configure system.dashboards for dashboard.html.
|
||||||
|
|
||||||
|
Could have any query parameters, for which there will be an input on the page.
|
||||||
|
For instance an example from comments have the following:
|
||||||
|
- seconds
|
||||||
|
- rounding
|
||||||
|
|
||||||
|
NOTE: All default dashboards will be overwritten if it was set here. -->
|
||||||
|
<!-- Here is an example without merge() function, to make it work with readonly user -->
|
||||||
|
<!--
|
||||||
|
<dashboards>
|
||||||
|
<dashboard>
|
||||||
|
<dashboard>Overview</dashboard>
|
||||||
|
<title>Queries/second</title>
|
||||||
|
<query>
|
||||||
|
SELECT toStartOfInterval(event_time, INTERVAL {rounding:UInt32} SECOND)::INT AS t, avg(ProfileEvent_Query)
|
||||||
|
FROM system.metric_log
|
||||||
|
WHERE event_date >= toDate(now() - {seconds:UInt32}) AND event_time >= now() - {seconds:UInt32}
|
||||||
|
GROUP BY t
|
||||||
|
ORDER BY t WITH FILL STEP {rounding:UInt32}
|
||||||
|
</query>
|
||||||
|
</dashboard>
|
||||||
|
</dashboards>
|
||||||
|
-->
|
||||||
|
|
||||||
<!-- <top_level_domains_path>/var/lib/clickhouse/top_level_domains/</top_level_domains_path> -->
|
<!-- <top_level_domains_path>/var/lib/clickhouse/top_level_domains/</top_level_domains_path> -->
|
||||||
<!-- Custom TLD lists.
|
<!-- Custom TLD lists.
|
||||||
Format: <name>/path/to/file</name>
|
Format: <name>/path/to/file</name>
|
||||||
|
@ -237,7 +237,7 @@ QueryTreeNodePtr QueryTreeBuilder::buildSelectExpression(const ASTPtr & select_q
|
|||||||
/// Remove global settings limit and offset
|
/// Remove global settings limit and offset
|
||||||
if (const auto & settings_ref = updated_context->getSettingsRef(); settings_ref.limit || settings_ref.offset)
|
if (const auto & settings_ref = updated_context->getSettingsRef(); settings_ref.limit || settings_ref.offset)
|
||||||
{
|
{
|
||||||
Settings settings = updated_context->getSettings();
|
Settings settings = updated_context->getSettingsCopy();
|
||||||
limit = settings.limit;
|
limit = settings.limit;
|
||||||
offset = settings.offset;
|
offset = settings.offset;
|
||||||
settings.limit = 0;
|
settings.limit = 0;
|
||||||
|
@ -503,7 +503,7 @@ void QueryAnalyzer::evaluateScalarSubqueryIfNeeded(QueryTreeNodePtr & node, Iden
|
|||||||
ProfileEvents::increment(ProfileEvents::ScalarSubqueriesCacheMiss);
|
ProfileEvents::increment(ProfileEvents::ScalarSubqueriesCacheMiss);
|
||||||
auto subquery_context = Context::createCopy(context);
|
auto subquery_context = Context::createCopy(context);
|
||||||
|
|
||||||
Settings subquery_settings = context->getSettings();
|
Settings subquery_settings = context->getSettingsCopy();
|
||||||
subquery_settings.max_result_rows = 1;
|
subquery_settings.max_result_rows = 1;
|
||||||
subquery_settings.extremes = false;
|
subquery_settings.extremes = false;
|
||||||
subquery_context->setSettings(subquery_settings);
|
subquery_context->setSettings(subquery_settings);
|
||||||
|
@ -867,7 +867,7 @@ void updateContextForSubqueryExecution(ContextMutablePtr & mutable_context)
|
|||||||
* max_rows_in_join, max_bytes_in_join, join_overflow_mode,
|
* max_rows_in_join, max_bytes_in_join, join_overflow_mode,
|
||||||
* which are checked separately (in the Set, Join objects).
|
* which are checked separately (in the Set, Join objects).
|
||||||
*/
|
*/
|
||||||
Settings subquery_settings = mutable_context->getSettings();
|
Settings subquery_settings = mutable_context->getSettingsCopy();
|
||||||
subquery_settings.max_result_rows = 0;
|
subquery_settings.max_result_rows = 0;
|
||||||
subquery_settings.max_result_bytes = 0;
|
subquery_settings.max_result_bytes = 0;
|
||||||
/// The calculation of extremes does not make sense and is not necessary (if you do it, then the extremes of the subquery can be taken for whole query).
|
/// The calculation of extremes does not make sense and is not necessary (if you do it, then the extremes of the subquery can be taken for whole query).
|
||||||
|
@ -384,6 +384,7 @@ BackupsWorker::BackupsWorker(ContextMutablePtr global_context, size_t num_backup
|
|||||||
, allow_concurrent_backups(global_context->getConfigRef().getBool("backups.allow_concurrent_backups", true))
|
, allow_concurrent_backups(global_context->getConfigRef().getBool("backups.allow_concurrent_backups", true))
|
||||||
, allow_concurrent_restores(global_context->getConfigRef().getBool("backups.allow_concurrent_restores", true))
|
, allow_concurrent_restores(global_context->getConfigRef().getBool("backups.allow_concurrent_restores", true))
|
||||||
, remove_backup_files_after_failure(global_context->getConfigRef().getBool("backups.remove_backup_files_after_failure", true))
|
, remove_backup_files_after_failure(global_context->getConfigRef().getBool("backups.remove_backup_files_after_failure", true))
|
||||||
|
, test_randomize_order(global_context->getConfigRef().getBool("backups.test_randomize_order", false))
|
||||||
, test_inject_sleep(global_context->getConfigRef().getBool("backups.test_inject_sleep", false))
|
, test_inject_sleep(global_context->getConfigRef().getBool("backups.test_inject_sleep", false))
|
||||||
, log(getLogger("BackupsWorker"))
|
, log(getLogger("BackupsWorker"))
|
||||||
, backup_log(global_context->getBackupLog())
|
, backup_log(global_context->getBackupLog())
|
||||||
@ -713,14 +714,25 @@ void BackupsWorker::writeBackupEntries(
|
|||||||
bool always_single_threaded = !backup->supportsWritingInMultipleThreads();
|
bool always_single_threaded = !backup->supportsWritingInMultipleThreads();
|
||||||
auto & thread_pool = getThreadPool(ThreadPoolId::BACKUP_COPY_FILES);
|
auto & thread_pool = getThreadPool(ThreadPoolId::BACKUP_COPY_FILES);
|
||||||
|
|
||||||
|
std::vector<size_t> writing_order;
|
||||||
|
if (test_randomize_order)
|
||||||
|
{
|
||||||
|
/// Randomize the order in which we write backup entries to the backup.
|
||||||
|
writing_order.resize(backup_entries.size());
|
||||||
|
std::iota(writing_order.begin(), writing_order.end(), 0);
|
||||||
|
std::shuffle(writing_order.begin(), writing_order.end(), thread_local_rng);
|
||||||
|
}
|
||||||
|
|
||||||
ThreadPoolCallbackRunnerLocal<void> runner(thread_pool, "BackupWorker");
|
ThreadPoolCallbackRunnerLocal<void> runner(thread_pool, "BackupWorker");
|
||||||
for (size_t i = 0; i != backup_entries.size(); ++i)
|
for (size_t i = 0; i != backup_entries.size(); ++i)
|
||||||
{
|
{
|
||||||
if (failed)
|
if (failed)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
auto & entry = backup_entries[i].second;
|
size_t index = !writing_order.empty() ? writing_order[i] : i;
|
||||||
const auto & file_info = file_infos[i];
|
|
||||||
|
auto & entry = backup_entries[index].second;
|
||||||
|
const auto & file_info = file_infos[index];
|
||||||
|
|
||||||
auto job = [&]()
|
auto job = [&]()
|
||||||
{
|
{
|
||||||
|
@ -119,6 +119,7 @@ private:
|
|||||||
const bool allow_concurrent_backups;
|
const bool allow_concurrent_backups;
|
||||||
const bool allow_concurrent_restores;
|
const bool allow_concurrent_restores;
|
||||||
const bool remove_backup_files_after_failure;
|
const bool remove_backup_files_after_failure;
|
||||||
|
const bool test_randomize_order;
|
||||||
const bool test_inject_sleep;
|
const bool test_inject_sleep;
|
||||||
|
|
||||||
LoggerPtr log;
|
LoggerPtr log;
|
||||||
|
@ -232,7 +232,7 @@ int IBridge::main(const std::vector<std::string> & /*args*/)
|
|||||||
auto context = Context::createGlobal(shared_context.get());
|
auto context = Context::createGlobal(shared_context.get());
|
||||||
context->makeGlobalContext();
|
context->makeGlobalContext();
|
||||||
|
|
||||||
auto settings = context->getSettings();
|
auto settings = context->getSettingsCopy();
|
||||||
settings.set("http_max_field_value_size", http_max_field_value_size);
|
settings.set("http_max_field_value_size", http_max_field_value_size);
|
||||||
context->setSettings(settings);
|
context->setSettings(settings);
|
||||||
|
|
||||||
|
395
src/Client/ClientApplicationBase.cpp
Normal file
395
src/Client/ClientApplicationBase.cpp
Normal file
@ -0,0 +1,395 @@
|
|||||||
|
#include <Client/ClientApplicationBase.h>
|
||||||
|
|
||||||
|
#include <base/argsToConfig.h>
|
||||||
|
#include <base/safeExit.h>
|
||||||
|
#include <Core/BaseSettingsProgramOptions.h>
|
||||||
|
#include <Common/clearPasswordFromCommandLine.h>
|
||||||
|
#include <Common/TerminalSize.h>
|
||||||
|
#include <Common/Exception.h>
|
||||||
|
#include <Common/SignalHandlers.h>
|
||||||
|
|
||||||
|
#include <Common/config_version.h>
|
||||||
|
#include "config.h"
|
||||||
|
|
||||||
|
#include <unordered_set>
|
||||||
|
#include <string>
|
||||||
|
#include <boost/algorithm/string/case_conv.hpp>
|
||||||
|
#include <boost/algorithm/string/replace.hpp>
|
||||||
|
#include <boost/algorithm/string/split.hpp>
|
||||||
|
|
||||||
|
using namespace std::literals;
|
||||||
|
|
||||||
|
namespace CurrentMetrics
|
||||||
|
{
|
||||||
|
extern const Metric MemoryTracking;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace DB
|
||||||
|
{
|
||||||
|
|
||||||
|
namespace ErrorCodes
|
||||||
|
{
|
||||||
|
extern const int BAD_ARGUMENTS;
|
||||||
|
extern const int CANNOT_SET_SIGNAL_HANDLER;
|
||||||
|
}
|
||||||
|
|
||||||
|
static ClientInfo::QueryKind parseQueryKind(const String & query_kind)
|
||||||
|
{
|
||||||
|
if (query_kind == "initial_query")
|
||||||
|
return ClientInfo::QueryKind::INITIAL_QUERY;
|
||||||
|
if (query_kind == "secondary_query")
|
||||||
|
return ClientInfo::QueryKind::SECONDARY_QUERY;
|
||||||
|
if (query_kind == "no_query")
|
||||||
|
return ClientInfo::QueryKind::NO_QUERY;
|
||||||
|
throw Exception(ErrorCodes::BAD_ARGUMENTS, "Unknown query kind {}", query_kind);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// This signal handler is set only for SIGINT and SIGQUIT.
|
||||||
|
void interruptSignalHandler(int signum)
|
||||||
|
{
|
||||||
|
/// Signal handler might be called even before the setup is fully finished
|
||||||
|
/// and client application started to process the query.
|
||||||
|
/// Because of that we have to manually check it.
|
||||||
|
if (auto * instance = ClientApplicationBase::instanceRawPtr(); instance)
|
||||||
|
if (auto * base = dynamic_cast<ClientApplicationBase *>(instance); base)
|
||||||
|
if (base->tryStopQuery())
|
||||||
|
safeExit(128 + signum);
|
||||||
|
}
|
||||||
|
|
||||||
|
ClientApplicationBase::~ClientApplicationBase()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
writeSignalIDtoSignalPipe(SignalListener::StopThread);
|
||||||
|
signal_listener_thread.join();
|
||||||
|
HandledSignals::instance().reset();
|
||||||
|
}
|
||||||
|
catch (...)
|
||||||
|
{
|
||||||
|
tryLogCurrentException(__PRETTY_FUNCTION__);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ClientApplicationBase::ClientApplicationBase() : ClientBase(STDIN_FILENO, STDOUT_FILENO, STDERR_FILENO, std::cin, std::cout, std::cerr) {}
|
||||||
|
|
||||||
|
ClientApplicationBase & ClientApplicationBase::getInstance()
|
||||||
|
{
|
||||||
|
return dynamic_cast<ClientApplicationBase&>(Poco::Util::Application::instance());
|
||||||
|
}
|
||||||
|
|
||||||
|
void ClientApplicationBase::setupSignalHandler()
|
||||||
|
{
|
||||||
|
ClientApplicationBase::getInstance().stopQuery();
|
||||||
|
|
||||||
|
struct sigaction new_act;
|
||||||
|
memset(&new_act, 0, sizeof(new_act));
|
||||||
|
|
||||||
|
new_act.sa_handler = interruptSignalHandler;
|
||||||
|
new_act.sa_flags = 0;
|
||||||
|
|
||||||
|
#if defined(OS_DARWIN)
|
||||||
|
sigemptyset(&new_act.sa_mask);
|
||||||
|
#else
|
||||||
|
if (sigemptyset(&new_act.sa_mask))
|
||||||
|
throw ErrnoException(ErrorCodes::CANNOT_SET_SIGNAL_HANDLER, "Cannot set signal handler");
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (sigaction(SIGINT, &new_act, nullptr))
|
||||||
|
throw ErrnoException(ErrorCodes::CANNOT_SET_SIGNAL_HANDLER, "Cannot set signal handler");
|
||||||
|
|
||||||
|
if (sigaction(SIGQUIT, &new_act, nullptr))
|
||||||
|
throw ErrnoException(ErrorCodes::CANNOT_SET_SIGNAL_HANDLER, "Cannot set signal handler");
|
||||||
|
}
|
||||||
|
|
||||||
|
void ClientApplicationBase::addMultiquery(std::string_view query, Arguments & common_arguments) const
|
||||||
|
{
|
||||||
|
common_arguments.emplace_back("--multiquery");
|
||||||
|
common_arguments.emplace_back("-q");
|
||||||
|
common_arguments.emplace_back(query);
|
||||||
|
}
|
||||||
|
|
||||||
|
Poco::Util::LayeredConfiguration & ClientApplicationBase::getClientConfiguration()
|
||||||
|
{
|
||||||
|
return config();
|
||||||
|
}
|
||||||
|
|
||||||
|
void ClientApplicationBase::init(int argc, char ** argv)
|
||||||
|
{
|
||||||
|
namespace po = boost::program_options;
|
||||||
|
|
||||||
|
/// Don't parse options with Poco library, we prefer neat boost::program_options.
|
||||||
|
stopOptionsProcessing();
|
||||||
|
|
||||||
|
stdin_is_a_tty = isatty(STDIN_FILENO);
|
||||||
|
stdout_is_a_tty = isatty(STDOUT_FILENO);
|
||||||
|
stderr_is_a_tty = isatty(STDERR_FILENO);
|
||||||
|
terminal_width = getTerminalWidth();
|
||||||
|
|
||||||
|
std::vector<Arguments> external_tables_arguments;
|
||||||
|
Arguments common_arguments = {""}; /// 0th argument is ignored.
|
||||||
|
std::vector<Arguments> hosts_and_ports_arguments;
|
||||||
|
|
||||||
|
if (argc)
|
||||||
|
argv0 = argv[0];
|
||||||
|
readArguments(argc, argv, common_arguments, external_tables_arguments, hosts_and_ports_arguments);
|
||||||
|
|
||||||
|
/// Support for Unicode dashes
|
||||||
|
/// Interpret Unicode dashes as default double-hyphen
|
||||||
|
for (auto & arg : common_arguments)
|
||||||
|
{
|
||||||
|
// replace em-dash(U+2014)
|
||||||
|
boost::replace_all(arg, "—", "--");
|
||||||
|
// replace en-dash(U+2013)
|
||||||
|
boost::replace_all(arg, "–", "--");
|
||||||
|
// replace mathematical minus(U+2212)
|
||||||
|
boost::replace_all(arg, "−", "--");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
OptionsDescription options_description;
|
||||||
|
options_description.main_description.emplace(createOptionsDescription("Main options", terminal_width));
|
||||||
|
|
||||||
|
/// Common options for clickhouse-client and clickhouse-local.
|
||||||
|
options_description.main_description->add_options()
|
||||||
|
("help", "print usage summary, combine with --verbose to display all options")
|
||||||
|
("verbose", "print query and other debugging info")
|
||||||
|
("version,V", "print version information and exit")
|
||||||
|
("version-clean", "print version in machine-readable format and exit")
|
||||||
|
|
||||||
|
("config-file,C", po::value<std::string>(), "config-file path")
|
||||||
|
|
||||||
|
("query,q", po::value<std::vector<std::string>>()->multitoken(), R"(Query. Can be specified multiple times (--query "SELECT 1" --query "SELECT 2") or once with multiple comma-separated queries (--query "SELECT 1; SELECT 2;"). In the latter case, INSERT queries with non-VALUE format must be separated by empty lines.)")
|
||||||
|
("queries-file", po::value<std::vector<std::string>>()->multitoken(), "file path with queries to execute; multiple files can be specified (--queries-file file1 file2...)")
|
||||||
|
("multiquery,n", "Obsolete, does nothing")
|
||||||
|
("multiline,m", "If specified, allow multiline queries (do not send the query on Enter)")
|
||||||
|
("database,d", po::value<std::string>(), "database")
|
||||||
|
("query_kind", po::value<std::string>()->default_value("initial_query"), "One of initial_query/secondary_query/no_query")
|
||||||
|
("query_id", po::value<std::string>(), "query_id")
|
||||||
|
|
||||||
|
("history_file", po::value<std::string>(), "path to history file")
|
||||||
|
|
||||||
|
("stage", po::value<std::string>()->default_value("complete"), "Request query processing up to specified stage: complete,fetch_columns,with_mergeable_state,with_mergeable_state_after_aggregation,with_mergeable_state_after_aggregation_and_limit")
|
||||||
|
("progress", po::value<ProgressOption>()->implicit_value(ProgressOption::TTY, "tty")->default_value(ProgressOption::DEFAULT, "default"), "Print progress of queries execution - to TTY: tty|on|1|true|yes; to STDERR non-interactive mode: err; OFF: off|0|false|no; DEFAULT - interactive to TTY, non-interactive is off")
|
||||||
|
|
||||||
|
("disable_suggestion,A", "Disable loading suggestion data. Note that suggestion data is loaded asynchronously through a second connection to ClickHouse server. Also it is reasonable to disable suggestion if you want to paste a query with TAB characters. Shorthand option -A is for those who get used to mysql client.")
|
||||||
|
("wait_for_suggestions_to_load", "Load suggestion data synchonously.")
|
||||||
|
("time,t", "print query execution time to stderr in non-interactive mode (for benchmarks)")
|
||||||
|
("memory-usage", po::value<std::string>()->implicit_value("default")->default_value("none"), "print memory usage to stderr in non-interactive mode (for benchmarks). Values: 'none', 'default', 'readable'")
|
||||||
|
|
||||||
|
("echo", "in batch mode, print query before execution")
|
||||||
|
|
||||||
|
("log-level", po::value<std::string>(), "log level")
|
||||||
|
("server_logs_file", po::value<std::string>(), "put server logs into specified file")
|
||||||
|
|
||||||
|
("suggestion_limit", po::value<int>()->default_value(10000), "Suggestion limit for how many databases, tables and columns to fetch.")
|
||||||
|
|
||||||
|
("format,f", po::value<std::string>(), "default output format (and input format for clickhouse-local)")
|
||||||
|
("output-format", po::value<std::string>(), "default output format (this option has preference over --format)")
|
||||||
|
|
||||||
|
("vertical,E", "vertical output format, same as --format=Vertical or FORMAT Vertical or \\G at end of command")
|
||||||
|
("highlight", po::value<bool>()->default_value(true), "enable or disable basic syntax highlight in interactive command line")
|
||||||
|
|
||||||
|
("ignore-error", "do not stop processing when an error occurs")
|
||||||
|
("stacktrace", "print stack traces of exceptions")
|
||||||
|
("hardware-utilization", "print hardware utilization information in progress bar")
|
||||||
|
("print-profile-events", po::value(&profile_events.print)->zero_tokens(), "Printing ProfileEvents packets")
|
||||||
|
("profile-events-delay-ms", po::value<UInt64>()->default_value(profile_events.delay_ms), "Delay between printing `ProfileEvents` packets (-1 - print only totals, 0 - print every single packet)")
|
||||||
|
("processed-rows", "print the number of locally processed rows")
|
||||||
|
|
||||||
|
("interactive", "Process queries-file or --query query and start interactive mode")
|
||||||
|
("pager", po::value<std::string>(), "Pipe all output into this command (less or similar)")
|
||||||
|
("max_memory_usage_in_client", po::value<std::string>(), "Set memory limit in client/local server")
|
||||||
|
|
||||||
|
("fuzzer-args", po::value<std::string>(), "Command line arguments for the LLVM's libFuzzer driver. Only relevant if the application is compiled with libFuzzer.")
|
||||||
|
|
||||||
|
("client_logs_file", po::value<std::string>(), "Path to a file for writing client logs. Currently we only have fatal logs (when the client crashes)")
|
||||||
|
;
|
||||||
|
|
||||||
|
addOptions(options_description);
|
||||||
|
|
||||||
|
OptionsDescription options_description_non_verbose = options_description;
|
||||||
|
|
||||||
|
auto getter = [](const auto & op)
|
||||||
|
{
|
||||||
|
String op_long_name = op->long_name();
|
||||||
|
return "--" + String(op_long_name);
|
||||||
|
};
|
||||||
|
|
||||||
|
if (options_description.main_description)
|
||||||
|
{
|
||||||
|
const auto & main_options = options_description.main_description->options();
|
||||||
|
std::transform(main_options.begin(), main_options.end(), std::back_inserter(cmd_options), getter);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (options_description.external_description)
|
||||||
|
{
|
||||||
|
const auto & external_options = options_description.external_description->options();
|
||||||
|
std::transform(external_options.begin(), external_options.end(), std::back_inserter(cmd_options), getter);
|
||||||
|
}
|
||||||
|
|
||||||
|
po::variables_map options;
|
||||||
|
parseAndCheckOptions(options_description, options, common_arguments);
|
||||||
|
po::notify(options);
|
||||||
|
|
||||||
|
if (options.count("version") || options.count("V"))
|
||||||
|
{
|
||||||
|
showClientVersion();
|
||||||
|
exit(0); // NOLINT(concurrency-mt-unsafe)
|
||||||
|
}
|
||||||
|
|
||||||
|
if (options.count("version-clean"))
|
||||||
|
{
|
||||||
|
output_stream << VERSION_STRING;
|
||||||
|
exit(0); // NOLINT(concurrency-mt-unsafe)
|
||||||
|
}
|
||||||
|
|
||||||
|
if (options.count("verbose"))
|
||||||
|
getClientConfiguration().setBool("verbose", true);
|
||||||
|
|
||||||
|
/// Output of help message.
|
||||||
|
if (options.count("help")
|
||||||
|
|| (options.count("host") && options["host"].as<std::string>() == "elp")) /// If user writes -help instead of --help.
|
||||||
|
{
|
||||||
|
if (getClientConfiguration().getBool("verbose", false))
|
||||||
|
printHelpMessage(options_description, true);
|
||||||
|
else
|
||||||
|
printHelpMessage(options_description_non_verbose, false);
|
||||||
|
exit(0); // NOLINT(concurrency-mt-unsafe)
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Common options for clickhouse-client and clickhouse-local.
|
||||||
|
|
||||||
|
/// Output execution time to stderr in batch mode.
|
||||||
|
if (options.count("time"))
|
||||||
|
getClientConfiguration().setBool("print-time-to-stderr", true);
|
||||||
|
if (options.count("memory-usage"))
|
||||||
|
{
|
||||||
|
const auto & memory_usage_mode = options["memory-usage"].as<std::string>();
|
||||||
|
if (memory_usage_mode != "none" && memory_usage_mode != "default" && memory_usage_mode != "readable")
|
||||||
|
throw Exception(ErrorCodes::BAD_ARGUMENTS, "Unknown memory-usage mode: {}", memory_usage_mode);
|
||||||
|
getClientConfiguration().setString("print-memory-to-stderr", memory_usage_mode);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (options.count("query"))
|
||||||
|
queries = options["query"].as<std::vector<std::string>>();
|
||||||
|
if (options.count("query_id"))
|
||||||
|
getClientConfiguration().setString("query_id", options["query_id"].as<std::string>());
|
||||||
|
if (options.count("database"))
|
||||||
|
getClientConfiguration().setString("database", options["database"].as<std::string>());
|
||||||
|
if (options.count("config-file"))
|
||||||
|
getClientConfiguration().setString("config-file", options["config-file"].as<std::string>());
|
||||||
|
if (options.count("queries-file"))
|
||||||
|
queries_files = options["queries-file"].as<std::vector<std::string>>();
|
||||||
|
if (options.count("multiline"))
|
||||||
|
getClientConfiguration().setBool("multiline", true);
|
||||||
|
if (options.count("ignore-error"))
|
||||||
|
getClientConfiguration().setBool("ignore-error", true);
|
||||||
|
if (options.count("format"))
|
||||||
|
getClientConfiguration().setString("format", options["format"].as<std::string>());
|
||||||
|
if (options.count("output-format"))
|
||||||
|
getClientConfiguration().setString("output-format", options["output-format"].as<std::string>());
|
||||||
|
if (options.count("vertical"))
|
||||||
|
getClientConfiguration().setBool("vertical", true);
|
||||||
|
if (options.count("stacktrace"))
|
||||||
|
getClientConfiguration().setBool("stacktrace", true);
|
||||||
|
if (options.count("print-profile-events"))
|
||||||
|
getClientConfiguration().setBool("print-profile-events", true);
|
||||||
|
if (options.count("profile-events-delay-ms"))
|
||||||
|
getClientConfiguration().setUInt64("profile-events-delay-ms", options["profile-events-delay-ms"].as<UInt64>());
|
||||||
|
/// Whether to print the number of processed rows at
|
||||||
|
if (options.count("processed-rows"))
|
||||||
|
getClientConfiguration().setBool("print-num-processed-rows", true);
|
||||||
|
if (options.count("progress"))
|
||||||
|
{
|
||||||
|
switch (options["progress"].as<ProgressOption>())
|
||||||
|
{
|
||||||
|
case DEFAULT:
|
||||||
|
getClientConfiguration().setString("progress", "default");
|
||||||
|
break;
|
||||||
|
case OFF:
|
||||||
|
getClientConfiguration().setString("progress", "off");
|
||||||
|
break;
|
||||||
|
case TTY:
|
||||||
|
getClientConfiguration().setString("progress", "tty");
|
||||||
|
break;
|
||||||
|
case ERR:
|
||||||
|
getClientConfiguration().setString("progress", "err");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (options.count("echo"))
|
||||||
|
getClientConfiguration().setBool("echo", true);
|
||||||
|
if (options.count("disable_suggestion"))
|
||||||
|
getClientConfiguration().setBool("disable_suggestion", true);
|
||||||
|
if (options.count("wait_for_suggestions_to_load"))
|
||||||
|
getClientConfiguration().setBool("wait_for_suggestions_to_load", true);
|
||||||
|
if (options.count("suggestion_limit"))
|
||||||
|
getClientConfiguration().setInt("suggestion_limit", options["suggestion_limit"].as<int>());
|
||||||
|
if (options.count("highlight"))
|
||||||
|
getClientConfiguration().setBool("highlight", options["highlight"].as<bool>());
|
||||||
|
if (options.count("history_file"))
|
||||||
|
getClientConfiguration().setString("history_file", options["history_file"].as<std::string>());
|
||||||
|
if (options.count("interactive"))
|
||||||
|
getClientConfiguration().setBool("interactive", true);
|
||||||
|
if (options.count("pager"))
|
||||||
|
getClientConfiguration().setString("pager", options["pager"].as<std::string>());
|
||||||
|
|
||||||
|
if (options.count("log-level"))
|
||||||
|
Poco::Logger::root().setLevel(options["log-level"].as<std::string>());
|
||||||
|
if (options.count("server_logs_file"))
|
||||||
|
server_logs_file = options["server_logs_file"].as<std::string>();
|
||||||
|
|
||||||
|
query_processing_stage = QueryProcessingStage::fromString(options["stage"].as<std::string>());
|
||||||
|
query_kind = parseQueryKind(options["query_kind"].as<std::string>());
|
||||||
|
profile_events.print = options.count("print-profile-events");
|
||||||
|
profile_events.delay_ms = options["profile-events-delay-ms"].as<UInt64>();
|
||||||
|
|
||||||
|
processOptions(options_description, options, external_tables_arguments, hosts_and_ports_arguments);
|
||||||
|
{
|
||||||
|
std::unordered_set<std::string> alias_names;
|
||||||
|
alias_names.reserve(options_description.main_description->options().size());
|
||||||
|
for (const auto& option : options_description.main_description->options())
|
||||||
|
alias_names.insert(option->long_name());
|
||||||
|
argsToConfig(common_arguments, getClientConfiguration(), 100, &alias_names);
|
||||||
|
}
|
||||||
|
|
||||||
|
clearPasswordFromCommandLine(argc, argv);
|
||||||
|
|
||||||
|
/// Limit on total memory usage
|
||||||
|
std::string max_client_memory_usage = getClientConfiguration().getString("max_memory_usage_in_client", "0" /*default value*/);
|
||||||
|
if (max_client_memory_usage != "0")
|
||||||
|
{
|
||||||
|
UInt64 max_client_memory_usage_int = parseWithSizeSuffix<UInt64>(max_client_memory_usage.c_str(), max_client_memory_usage.length());
|
||||||
|
|
||||||
|
total_memory_tracker.setHardLimit(max_client_memory_usage_int);
|
||||||
|
total_memory_tracker.setDescription("(total)");
|
||||||
|
total_memory_tracker.setMetric(CurrentMetrics::MemoryTracking);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Print stacktrace in case of crash
|
||||||
|
HandledSignals::instance().setupTerminateHandler();
|
||||||
|
HandledSignals::instance().setupCommonDeadlySignalHandlers();
|
||||||
|
/// We don't setup signal handlers for SIGINT, SIGQUIT, SIGTERM because we don't
|
||||||
|
/// have an option for client to shutdown gracefully.
|
||||||
|
|
||||||
|
fatal_channel_ptr = new Poco::SplitterChannel;
|
||||||
|
fatal_console_channel_ptr = new Poco::ConsoleChannel;
|
||||||
|
fatal_channel_ptr->addChannel(fatal_console_channel_ptr);
|
||||||
|
if (options.count("client_logs_file"))
|
||||||
|
{
|
||||||
|
fatal_file_channel_ptr = new Poco::SimpleFileChannel(options["client_logs_file"].as<std::string>());
|
||||||
|
fatal_channel_ptr->addChannel(fatal_file_channel_ptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
fatal_log = createLogger("ClientBase", fatal_channel_ptr.get(), Poco::Message::PRIO_FATAL);
|
||||||
|
signal_listener = std::make_unique<SignalListener>(nullptr, fatal_log);
|
||||||
|
signal_listener_thread.start(*signal_listener);
|
||||||
|
|
||||||
|
#if USE_GWP_ASAN
|
||||||
|
GWPAsan::initFinished();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
64
src/Client/ClientApplicationBase.h
Normal file
64
src/Client/ClientApplicationBase.h
Normal file
@ -0,0 +1,64 @@
|
|||||||
|
#pragma once
|
||||||
|
|
||||||
|
|
||||||
|
#include <Poco/Util/Application.h>
|
||||||
|
#include <Client/ClientBase.h>
|
||||||
|
#include <Client/Suggest.h>
|
||||||
|
#include <Common/NamePrompter.h>
|
||||||
|
#include <Poco/ConsoleChannel.h>
|
||||||
|
#include <Poco/SimpleFileChannel.h>
|
||||||
|
#include <Poco/SplitterChannel.h>
|
||||||
|
|
||||||
|
#include <boost/program_options.hpp>
|
||||||
|
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
|
namespace po = boost::program_options;
|
||||||
|
|
||||||
|
namespace DB
|
||||||
|
{
|
||||||
|
|
||||||
|
void interruptSignalHandler(int signum);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The base class for client appliucations such as
|
||||||
|
* clickhouse-client or clickhouse-local.
|
||||||
|
* The main purpose and responsibility of it is dealing with
|
||||||
|
* application-specific stuff such as command line arguments parsing
|
||||||
|
* and setting up signal handlers, so queries will be cancelled after
|
||||||
|
* Ctrl+C is pressed.
|
||||||
|
*/
|
||||||
|
class ClientApplicationBase : public ClientBase, public Poco::Util::Application, public IHints<2>
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
using ClientBase::processOptions;
|
||||||
|
using Arguments = ClientBase::Arguments;
|
||||||
|
|
||||||
|
static ClientApplicationBase & getInstance();
|
||||||
|
|
||||||
|
ClientApplicationBase();
|
||||||
|
~ClientApplicationBase() override;
|
||||||
|
|
||||||
|
void init(int argc, char ** argv);
|
||||||
|
std::vector<String> getAllRegisteredNames() const override { return cmd_options; }
|
||||||
|
|
||||||
|
protected:
|
||||||
|
Poco::Util::LayeredConfiguration & getClientConfiguration() override;
|
||||||
|
void setupSignalHandler() override;
|
||||||
|
void addMultiquery(std::string_view query, Arguments & common_arguments) const;
|
||||||
|
|
||||||
|
private:
|
||||||
|
void parseAndCheckOptions(OptionsDescription & options_description, po::variables_map & options, Arguments & arguments);
|
||||||
|
|
||||||
|
std::vector<String> cmd_options;
|
||||||
|
|
||||||
|
LoggerPtr fatal_log;
|
||||||
|
Poco::AutoPtr<Poco::SplitterChannel> fatal_channel_ptr;
|
||||||
|
Poco::AutoPtr<Poco::Channel> fatal_console_channel_ptr;
|
||||||
|
Poco::AutoPtr<Poco::Channel> fatal_file_channel_ptr;
|
||||||
|
Poco::Thread signal_listener_thread;
|
||||||
|
std::unique_ptr<Poco::Runnable> signal_listener;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
}
|
@ -5,7 +5,6 @@
|
|||||||
#include <Client/InternalTextLogs.h>
|
#include <Client/InternalTextLogs.h>
|
||||||
#include <Client/TestTags.h>
|
#include <Client/TestTags.h>
|
||||||
|
|
||||||
#include <base/argsToConfig.h>
|
|
||||||
#include <base/safeExit.h>
|
#include <base/safeExit.h>
|
||||||
#include <Core/Block.h>
|
#include <Core/Block.h>
|
||||||
#include <Core/BaseSettingsProgramOptions.h>
|
#include <Core/BaseSettingsProgramOptions.h>
|
||||||
@ -17,7 +16,6 @@
|
|||||||
#include <Common/getNumberOfPhysicalCPUCores.h>
|
#include <Common/getNumberOfPhysicalCPUCores.h>
|
||||||
#include <Common/typeid_cast.h>
|
#include <Common/typeid_cast.h>
|
||||||
#include <Common/TerminalSize.h>
|
#include <Common/TerminalSize.h>
|
||||||
#include <Common/clearPasswordFromCommandLine.h>
|
|
||||||
#include <Common/StringUtils.h>
|
#include <Common/StringUtils.h>
|
||||||
#include <Common/filesystemHelpers.h>
|
#include <Common/filesystemHelpers.h>
|
||||||
#include <Common/NetException.h>
|
#include <Common/NetException.h>
|
||||||
@ -90,12 +88,6 @@
|
|||||||
namespace fs = std::filesystem;
|
namespace fs = std::filesystem;
|
||||||
using namespace std::literals;
|
using namespace std::literals;
|
||||||
|
|
||||||
|
|
||||||
namespace CurrentMetrics
|
|
||||||
{
|
|
||||||
extern const Metric MemoryTracking;
|
|
||||||
}
|
|
||||||
|
|
||||||
namespace DB
|
namespace DB
|
||||||
{
|
{
|
||||||
|
|
||||||
@ -158,17 +150,6 @@ std::istream& operator>> (std::istream & in, ProgressOption & progress)
|
|||||||
return in;
|
return in;
|
||||||
}
|
}
|
||||||
|
|
||||||
static ClientInfo::QueryKind parseQueryKind(const String & query_kind)
|
|
||||||
{
|
|
||||||
if (query_kind == "initial_query")
|
|
||||||
return ClientInfo::QueryKind::INITIAL_QUERY;
|
|
||||||
if (query_kind == "secondary_query")
|
|
||||||
return ClientInfo::QueryKind::SECONDARY_QUERY;
|
|
||||||
if (query_kind == "no_query")
|
|
||||||
return ClientInfo::QueryKind::NO_QUERY;
|
|
||||||
throw Exception(ErrorCodes::BAD_ARGUMENTS, "Unknown query kind {}", query_kind);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void incrementProfileEventsBlock(Block & dst, const Block & src)
|
static void incrementProfileEventsBlock(Block & dst, const Block & src)
|
||||||
{
|
{
|
||||||
if (!dst)
|
if (!dst)
|
||||||
@ -269,36 +250,6 @@ static void incrementProfileEventsBlock(Block & dst, const Block & src)
|
|||||||
dst.setColumns(std::move(mutable_columns));
|
dst.setColumns(std::move(mutable_columns));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
std::atomic<Int32> exit_after_signals = 0;
|
|
||||||
|
|
||||||
class QueryInterruptHandler : private boost::noncopyable
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
/// Store how much interrupt signals can be before stopping the query
|
|
||||||
/// by default stop after the first interrupt signal.
|
|
||||||
static void start(Int32 signals_before_stop = 1) { exit_after_signals.store(signals_before_stop); }
|
|
||||||
|
|
||||||
/// Set value not greater then 0 to mark the query as stopped.
|
|
||||||
static void stop() { exit_after_signals.store(0); }
|
|
||||||
|
|
||||||
/// Return true if the query was stopped.
|
|
||||||
/// Query was stopped if it received at least "signals_before_stop" interrupt signals.
|
|
||||||
static bool try_stop() { return exit_after_signals.fetch_sub(1) <= 0; }
|
|
||||||
static bool cancelled() { return exit_after_signals.load() <= 0; }
|
|
||||||
|
|
||||||
/// Return how much interrupt signals remain before stop.
|
|
||||||
static Int32 cancelled_status() { return exit_after_signals.load(); }
|
|
||||||
};
|
|
||||||
|
|
||||||
/// This signal handler is set for SIGINT and SIGQUIT.
|
|
||||||
void interruptSignalHandler(int signum)
|
|
||||||
{
|
|
||||||
if (QueryInterruptHandler::try_stop())
|
|
||||||
safeExit(128 + signum);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/// To cancel the query on local format error.
|
/// To cancel the query on local format error.
|
||||||
class LocalFormatError : public DB::Exception
|
class LocalFormatError : public DB::Exception
|
||||||
{
|
{
|
||||||
@ -307,19 +258,7 @@ public:
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
ClientBase::~ClientBase()
|
ClientBase::~ClientBase() = default;
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
writeSignalIDtoSignalPipe(SignalListener::StopThread);
|
|
||||||
signal_listener_thread.join();
|
|
||||||
HandledSignals::instance().reset();
|
|
||||||
}
|
|
||||||
catch (...)
|
|
||||||
{
|
|
||||||
tryLogCurrentException(__PRETTY_FUNCTION__);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
ClientBase::ClientBase(
|
ClientBase::ClientBase(
|
||||||
int in_fd_,
|
int in_fd_,
|
||||||
@ -345,31 +284,6 @@ ClientBase::ClientBase(
|
|||||||
terminal_width = getTerminalWidth(in_fd, err_fd);
|
terminal_width = getTerminalWidth(in_fd, err_fd);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ClientBase::setupSignalHandler()
|
|
||||||
{
|
|
||||||
QueryInterruptHandler::stop();
|
|
||||||
|
|
||||||
struct sigaction new_act;
|
|
||||||
memset(&new_act, 0, sizeof(new_act));
|
|
||||||
|
|
||||||
new_act.sa_handler = interruptSignalHandler;
|
|
||||||
new_act.sa_flags = 0;
|
|
||||||
|
|
||||||
#if defined(OS_DARWIN)
|
|
||||||
sigemptyset(&new_act.sa_mask);
|
|
||||||
#else
|
|
||||||
if (sigemptyset(&new_act.sa_mask))
|
|
||||||
throw ErrnoException(ErrorCodes::CANNOT_SET_SIGNAL_HANDLER, "Cannot set signal handler");
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (sigaction(SIGINT, &new_act, nullptr))
|
|
||||||
throw ErrnoException(ErrorCodes::CANNOT_SET_SIGNAL_HANDLER, "Cannot set signal handler");
|
|
||||||
|
|
||||||
if (sigaction(SIGQUIT, &new_act, nullptr))
|
|
||||||
throw ErrnoException(ErrorCodes::CANNOT_SET_SIGNAL_HANDLER, "Cannot set signal handler");
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
ASTPtr ClientBase::parseQuery(const char *& pos, const char * end, const Settings & settings, bool allow_multi_statements)
|
ASTPtr ClientBase::parseQuery(const char *& pos, const char * end, const Settings & settings, bool allow_multi_statements)
|
||||||
{
|
{
|
||||||
std::unique_ptr<IParserBase> parser;
|
std::unique_ptr<IParserBase> parser;
|
||||||
@ -742,7 +656,7 @@ void ClientBase::initLogsOutputStream()
|
|||||||
|
|
||||||
void ClientBase::adjustSettings()
|
void ClientBase::adjustSettings()
|
||||||
{
|
{
|
||||||
Settings settings = global_context->getSettings();
|
Settings settings = global_context->getSettingsCopy();
|
||||||
|
|
||||||
/// NOTE: Do not forget to set changed=false to avoid sending it to the server (to avoid breakage read only profiles)
|
/// NOTE: Do not forget to set changed=false to avoid sending it to the server (to avoid breakage read only profiles)
|
||||||
|
|
||||||
@ -951,7 +865,7 @@ bool ClientBase::isSyncInsertWithData(const ASTInsertQuery & insert_query, const
|
|||||||
if (!insert_query.data)
|
if (!insert_query.data)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
auto settings = context->getSettings();
|
auto settings = context->getSettingsCopy();
|
||||||
if (insert_query.settings_ast)
|
if (insert_query.settings_ast)
|
||||||
settings.applyChanges(insert_query.settings_ast->as<ASTSetQuery>()->changes);
|
settings.applyChanges(insert_query.settings_ast->as<ASTSetQuery>()->changes);
|
||||||
|
|
||||||
@ -1113,8 +1027,8 @@ void ClientBase::processOrdinaryQuery(const String & query_to_execute, ASTPtr pa
|
|||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
QueryInterruptHandler::start(signals_before_stop);
|
query_interrupt_handler.start(signals_before_stop);
|
||||||
SCOPE_EXIT({ QueryInterruptHandler::stop(); });
|
SCOPE_EXIT({ query_interrupt_handler.stop(); });
|
||||||
|
|
||||||
connection->sendQuery(
|
connection->sendQuery(
|
||||||
connection_parameters.timeouts,
|
connection_parameters.timeouts,
|
||||||
@ -1178,13 +1092,13 @@ void ClientBase::receiveResult(ASTPtr parsed_query, Int32 signals_before_stop, b
|
|||||||
/// to avoid losing sync.
|
/// to avoid losing sync.
|
||||||
if (!cancelled)
|
if (!cancelled)
|
||||||
{
|
{
|
||||||
if (partial_result_on_first_cancel && QueryInterruptHandler::cancelled_status() == signals_before_stop - 1)
|
if (partial_result_on_first_cancel && query_interrupt_handler.cancelled_status() == signals_before_stop - 1)
|
||||||
{
|
{
|
||||||
connection->sendCancel();
|
connection->sendCancel();
|
||||||
/// First cancel reading request was sent. Next requests will only be with a full cancel
|
/// First cancel reading request was sent. Next requests will only be with a full cancel
|
||||||
partial_result_on_first_cancel = false;
|
partial_result_on_first_cancel = false;
|
||||||
}
|
}
|
||||||
else if (QueryInterruptHandler::cancelled())
|
else if (query_interrupt_handler.cancelled())
|
||||||
{
|
{
|
||||||
cancelQuery();
|
cancelQuery();
|
||||||
}
|
}
|
||||||
@ -1563,8 +1477,8 @@ void ClientBase::processInsertQuery(const String & query_to_execute, ASTPtr pars
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
QueryInterruptHandler::start();
|
query_interrupt_handler.start();
|
||||||
SCOPE_EXIT({ QueryInterruptHandler::stop(); });
|
SCOPE_EXIT({ query_interrupt_handler.stop(); });
|
||||||
|
|
||||||
connection->sendQuery(
|
connection->sendQuery(
|
||||||
connection_parameters.timeouts,
|
connection_parameters.timeouts,
|
||||||
@ -1775,7 +1689,7 @@ try
|
|||||||
Block block;
|
Block block;
|
||||||
while (executor.pull(block))
|
while (executor.pull(block))
|
||||||
{
|
{
|
||||||
if (!cancelled && QueryInterruptHandler::cancelled())
|
if (!cancelled && query_interrupt_handler.cancelled())
|
||||||
{
|
{
|
||||||
cancelQuery();
|
cancelQuery();
|
||||||
executor.cancel();
|
executor.cancel();
|
||||||
@ -2757,7 +2671,7 @@ bool ClientBase::processMultiQueryFromFile(const String & file_name)
|
|||||||
|
|
||||||
if (!getClientConfiguration().has("log_comment"))
|
if (!getClientConfiguration().has("log_comment"))
|
||||||
{
|
{
|
||||||
Settings settings = client_context->getSettings();
|
Settings settings = client_context->getSettingsCopy();
|
||||||
/// NOTE: cannot use even weakly_canonical() since it fails for /dev/stdin due to resolving of "pipe:[X]"
|
/// NOTE: cannot use even weakly_canonical() since it fails for /dev/stdin due to resolving of "pipe:[X]"
|
||||||
settings.log_comment = fs::absolute(fs::path(file_name));
|
settings.log_comment = fs::absolute(fs::path(file_name));
|
||||||
client_context->setSettings(settings);
|
client_context->setSettings(settings);
|
||||||
@ -2857,7 +2771,6 @@ void ClientBase::runLibFuzzer()
|
|||||||
void ClientBase::runLibFuzzer() {}
|
void ClientBase::runLibFuzzer() {}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
void ClientBase::clearTerminal()
|
void ClientBase::clearTerminal()
|
||||||
{
|
{
|
||||||
/// Clear from cursor until end of screen.
|
/// Clear from cursor until end of screen.
|
||||||
@ -2867,288 +2780,9 @@ void ClientBase::clearTerminal()
|
|||||||
output_stream << "\033[0J" "\033[?25h";
|
output_stream << "\033[0J" "\033[?25h";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void ClientBase::showClientVersion()
|
void ClientBase::showClientVersion()
|
||||||
{
|
{
|
||||||
output_stream << VERSION_NAME << " " + getName() + " version " << VERSION_STRING << VERSION_OFFICIAL << "." << std::endl;
|
output_stream << VERSION_NAME << " " + getName() + " version " << VERSION_STRING << VERSION_OFFICIAL << "." << std::endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
void ClientBase::init(int argc, char ** argv)
|
|
||||||
{
|
|
||||||
namespace po = boost::program_options;
|
|
||||||
|
|
||||||
/// Don't parse options with Poco library, we prefer neat boost::program_options.
|
|
||||||
stopOptionsProcessing();
|
|
||||||
|
|
||||||
stdin_is_a_tty = isatty(STDIN_FILENO);
|
|
||||||
stdout_is_a_tty = isatty(STDOUT_FILENO);
|
|
||||||
stderr_is_a_tty = isatty(STDERR_FILENO);
|
|
||||||
terminal_width = getTerminalWidth();
|
|
||||||
|
|
||||||
std::vector<Arguments> external_tables_arguments;
|
|
||||||
Arguments common_arguments = {""}; /// 0th argument is ignored.
|
|
||||||
std::vector<Arguments> hosts_and_ports_arguments;
|
|
||||||
|
|
||||||
if (argc)
|
|
||||||
argv0 = argv[0];
|
|
||||||
readArguments(argc, argv, common_arguments, external_tables_arguments, hosts_and_ports_arguments);
|
|
||||||
|
|
||||||
/// Support for Unicode dashes
|
|
||||||
/// Interpret Unicode dashes as default double-hyphen
|
|
||||||
for (auto & arg : common_arguments)
|
|
||||||
{
|
|
||||||
// replace em-dash(U+2014)
|
|
||||||
boost::replace_all(arg, "—", "--");
|
|
||||||
// replace en-dash(U+2013)
|
|
||||||
boost::replace_all(arg, "–", "--");
|
|
||||||
// replace mathematical minus(U+2212)
|
|
||||||
boost::replace_all(arg, "−", "--");
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
OptionsDescription options_description;
|
|
||||||
options_description.main_description.emplace(createOptionsDescription("Main options", terminal_width));
|
|
||||||
|
|
||||||
/// Common options for clickhouse-client and clickhouse-local.
|
|
||||||
options_description.main_description->add_options()
|
|
||||||
("help", "print usage summary, combine with --verbose to display all options")
|
|
||||||
("verbose", "print query and other debugging info")
|
|
||||||
("version,V", "print version information and exit")
|
|
||||||
("version-clean", "print version in machine-readable format and exit")
|
|
||||||
|
|
||||||
("config-file,C", po::value<std::string>(), "config-file path")
|
|
||||||
|
|
||||||
("query,q", po::value<std::vector<std::string>>()->multitoken(), R"(Query. Can be specified multiple times (--query "SELECT 1" --query "SELECT 2") or once with multiple comma-separated queries (--query "SELECT 1; SELECT 2;"). In the latter case, INSERT queries with non-VALUE format must be separated by empty lines.)")
|
|
||||||
("queries-file", po::value<std::vector<std::string>>()->multitoken(), "file path with queries to execute; multiple files can be specified (--queries-file file1 file2...)")
|
|
||||||
("multiquery,n", "Obsolete, does nothing")
|
|
||||||
("multiline,m", "If specified, allow multiline queries (do not send the query on Enter)")
|
|
||||||
("database,d", po::value<std::string>(), "database")
|
|
||||||
("query_kind", po::value<std::string>()->default_value("initial_query"), "One of initial_query/secondary_query/no_query")
|
|
||||||
("query_id", po::value<std::string>(), "query_id")
|
|
||||||
|
|
||||||
("history_file", po::value<std::string>(), "path to history file")
|
|
||||||
|
|
||||||
("stage", po::value<std::string>()->default_value("complete"), "Request query processing up to specified stage: complete,fetch_columns,with_mergeable_state,with_mergeable_state_after_aggregation,with_mergeable_state_after_aggregation_and_limit")
|
|
||||||
("progress", po::value<ProgressOption>()->implicit_value(ProgressOption::TTY, "tty")->default_value(ProgressOption::DEFAULT, "default"), "Print progress of queries execution - to TTY: tty|on|1|true|yes; to STDERR non-interactive mode: err; OFF: off|0|false|no; DEFAULT - interactive to TTY, non-interactive is off")
|
|
||||||
|
|
||||||
("disable_suggestion,A", "Disable loading suggestion data. Note that suggestion data is loaded asynchronously through a second connection to ClickHouse server. Also it is reasonable to disable suggestion if you want to paste a query with TAB characters. Shorthand option -A is for those who get used to mysql client.")
|
|
||||||
("wait_for_suggestions_to_load", "Load suggestion data synchonously.")
|
|
||||||
("time,t", "print query execution time to stderr in non-interactive mode (for benchmarks)")
|
|
||||||
("memory-usage", po::value<std::string>()->implicit_value("default")->default_value("none"), "print memory usage to stderr in non-interactive mode (for benchmarks). Values: 'none', 'default', 'readable'")
|
|
||||||
|
|
||||||
("echo", "in batch mode, print query before execution")
|
|
||||||
|
|
||||||
("log-level", po::value<std::string>(), "log level")
|
|
||||||
("server_logs_file", po::value<std::string>(), "put server logs into specified file")
|
|
||||||
|
|
||||||
("suggestion_limit", po::value<int>()->default_value(10000), "Suggestion limit for how many databases, tables and columns to fetch.")
|
|
||||||
|
|
||||||
("format,f", po::value<std::string>(), "default output format (and input format for clickhouse-local)")
|
|
||||||
("output-format", po::value<std::string>(), "default output format (this option has preference over --format)")
|
|
||||||
|
|
||||||
("vertical,E", "vertical output format, same as --format=Vertical or FORMAT Vertical or \\G at end of command")
|
|
||||||
("highlight", po::value<bool>()->default_value(true), "enable or disable basic syntax highlight in interactive command line")
|
|
||||||
|
|
||||||
("ignore-error", "do not stop processing when an error occurs")
|
|
||||||
("stacktrace", "print stack traces of exceptions")
|
|
||||||
("hardware-utilization", "print hardware utilization information in progress bar")
|
|
||||||
("print-profile-events", po::value(&profile_events.print)->zero_tokens(), "Printing ProfileEvents packets")
|
|
||||||
("profile-events-delay-ms", po::value<UInt64>()->default_value(profile_events.delay_ms), "Delay between printing `ProfileEvents` packets (-1 - print only totals, 0 - print every single packet)")
|
|
||||||
("processed-rows", "print the number of locally processed rows")
|
|
||||||
|
|
||||||
("interactive", "Process queries-file or --query query and start interactive mode")
|
|
||||||
("pager", po::value<std::string>(), "Pipe all output into this command (less or similar)")
|
|
||||||
("max_memory_usage_in_client", po::value<std::string>(), "Set memory limit in client/local server")
|
|
||||||
|
|
||||||
("fuzzer-args", po::value<std::string>(), "Command line arguments for the LLVM's libFuzzer driver. Only relevant if the application is compiled with libFuzzer.")
|
|
||||||
|
|
||||||
("client_logs_file", po::value<std::string>(), "Path to a file for writing client logs. Currently we only have fatal logs (when the client crashes)")
|
|
||||||
;
|
|
||||||
|
|
||||||
addOptions(options_description);
|
|
||||||
|
|
||||||
OptionsDescription options_description_non_verbose = options_description;
|
|
||||||
|
|
||||||
auto getter = [](const auto & op)
|
|
||||||
{
|
|
||||||
String op_long_name = op->long_name();
|
|
||||||
return "--" + String(op_long_name);
|
|
||||||
};
|
|
||||||
|
|
||||||
if (options_description.main_description)
|
|
||||||
{
|
|
||||||
const auto & main_options = options_description.main_description->options();
|
|
||||||
std::transform(main_options.begin(), main_options.end(), std::back_inserter(cmd_options), getter);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (options_description.external_description)
|
|
||||||
{
|
|
||||||
const auto & external_options = options_description.external_description->options();
|
|
||||||
std::transform(external_options.begin(), external_options.end(), std::back_inserter(cmd_options), getter);
|
|
||||||
}
|
|
||||||
|
|
||||||
po::variables_map options;
|
|
||||||
parseAndCheckOptions(options_description, options, common_arguments);
|
|
||||||
po::notify(options);
|
|
||||||
|
|
||||||
if (options.count("version") || options.count("V"))
|
|
||||||
{
|
|
||||||
showClientVersion();
|
|
||||||
exit(0); // NOLINT(concurrency-mt-unsafe)
|
|
||||||
}
|
|
||||||
|
|
||||||
if (options.count("version-clean"))
|
|
||||||
{
|
|
||||||
output_stream << VERSION_STRING;
|
|
||||||
exit(0); // NOLINT(concurrency-mt-unsafe)
|
|
||||||
}
|
|
||||||
|
|
||||||
if (options.count("verbose"))
|
|
||||||
getClientConfiguration().setBool("verbose", true);
|
|
||||||
|
|
||||||
/// Output of help message.
|
|
||||||
if (options.count("help")
|
|
||||||
|| (options.count("host") && options["host"].as<std::string>() == "elp")) /// If user writes -help instead of --help.
|
|
||||||
{
|
|
||||||
if (getClientConfiguration().getBool("verbose", false))
|
|
||||||
printHelpMessage(options_description, true);
|
|
||||||
else
|
|
||||||
printHelpMessage(options_description_non_verbose, false);
|
|
||||||
exit(0); // NOLINT(concurrency-mt-unsafe)
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Common options for clickhouse-client and clickhouse-local.
|
|
||||||
|
|
||||||
/// Output execution time to stderr in batch mode.
|
|
||||||
if (options.count("time"))
|
|
||||||
getClientConfiguration().setBool("print-time-to-stderr", true);
|
|
||||||
if (options.count("memory-usage"))
|
|
||||||
{
|
|
||||||
const auto & memory_usage_mode = options["memory-usage"].as<std::string>();
|
|
||||||
if (memory_usage_mode != "none" && memory_usage_mode != "default" && memory_usage_mode != "readable")
|
|
||||||
throw Exception(ErrorCodes::BAD_ARGUMENTS, "Unknown memory-usage mode: {}", memory_usage_mode);
|
|
||||||
getClientConfiguration().setString("print-memory-to-stderr", memory_usage_mode);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (options.count("query"))
|
|
||||||
queries = options["query"].as<std::vector<std::string>>();
|
|
||||||
if (options.count("query_id"))
|
|
||||||
getClientConfiguration().setString("query_id", options["query_id"].as<std::string>());
|
|
||||||
if (options.count("database"))
|
|
||||||
getClientConfiguration().setString("database", options["database"].as<std::string>());
|
|
||||||
if (options.count("config-file"))
|
|
||||||
getClientConfiguration().setString("config-file", options["config-file"].as<std::string>());
|
|
||||||
if (options.count("queries-file"))
|
|
||||||
queries_files = options["queries-file"].as<std::vector<std::string>>();
|
|
||||||
if (options.count("multiline"))
|
|
||||||
getClientConfiguration().setBool("multiline", true);
|
|
||||||
if (options.count("ignore-error"))
|
|
||||||
getClientConfiguration().setBool("ignore-error", true);
|
|
||||||
if (options.count("format"))
|
|
||||||
getClientConfiguration().setString("format", options["format"].as<std::string>());
|
|
||||||
if (options.count("output-format"))
|
|
||||||
getClientConfiguration().setString("output-format", options["output-format"].as<std::string>());
|
|
||||||
if (options.count("vertical"))
|
|
||||||
getClientConfiguration().setBool("vertical", true);
|
|
||||||
if (options.count("stacktrace"))
|
|
||||||
getClientConfiguration().setBool("stacktrace", true);
|
|
||||||
if (options.count("print-profile-events"))
|
|
||||||
getClientConfiguration().setBool("print-profile-events", true);
|
|
||||||
if (options.count("profile-events-delay-ms"))
|
|
||||||
getClientConfiguration().setUInt64("profile-events-delay-ms", options["profile-events-delay-ms"].as<UInt64>());
|
|
||||||
/// Whether to print the number of processed rows at
|
|
||||||
if (options.count("processed-rows"))
|
|
||||||
getClientConfiguration().setBool("print-num-processed-rows", true);
|
|
||||||
if (options.count("progress"))
|
|
||||||
{
|
|
||||||
switch (options["progress"].as<ProgressOption>())
|
|
||||||
{
|
|
||||||
case DEFAULT:
|
|
||||||
getClientConfiguration().setString("progress", "default");
|
|
||||||
break;
|
|
||||||
case OFF:
|
|
||||||
getClientConfiguration().setString("progress", "off");
|
|
||||||
break;
|
|
||||||
case TTY:
|
|
||||||
getClientConfiguration().setString("progress", "tty");
|
|
||||||
break;
|
|
||||||
case ERR:
|
|
||||||
getClientConfiguration().setString("progress", "err");
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (options.count("echo"))
|
|
||||||
getClientConfiguration().setBool("echo", true);
|
|
||||||
if (options.count("disable_suggestion"))
|
|
||||||
getClientConfiguration().setBool("disable_suggestion", true);
|
|
||||||
if (options.count("wait_for_suggestions_to_load"))
|
|
||||||
getClientConfiguration().setBool("wait_for_suggestions_to_load", true);
|
|
||||||
if (options.count("suggestion_limit"))
|
|
||||||
getClientConfiguration().setInt("suggestion_limit", options["suggestion_limit"].as<int>());
|
|
||||||
if (options.count("highlight"))
|
|
||||||
getClientConfiguration().setBool("highlight", options["highlight"].as<bool>());
|
|
||||||
if (options.count("history_file"))
|
|
||||||
getClientConfiguration().setString("history_file", options["history_file"].as<std::string>());
|
|
||||||
if (options.count("interactive"))
|
|
||||||
getClientConfiguration().setBool("interactive", true);
|
|
||||||
if (options.count("pager"))
|
|
||||||
getClientConfiguration().setString("pager", options["pager"].as<std::string>());
|
|
||||||
|
|
||||||
if (options.count("log-level"))
|
|
||||||
Poco::Logger::root().setLevel(options["log-level"].as<std::string>());
|
|
||||||
if (options.count("server_logs_file"))
|
|
||||||
server_logs_file = options["server_logs_file"].as<std::string>();
|
|
||||||
|
|
||||||
query_processing_stage = QueryProcessingStage::fromString(options["stage"].as<std::string>());
|
|
||||||
query_kind = parseQueryKind(options["query_kind"].as<std::string>());
|
|
||||||
profile_events.print = options.count("print-profile-events");
|
|
||||||
profile_events.delay_ms = options["profile-events-delay-ms"].as<UInt64>();
|
|
||||||
|
|
||||||
processOptions(options_description, options, external_tables_arguments, hosts_and_ports_arguments);
|
|
||||||
{
|
|
||||||
std::unordered_set<std::string> alias_names;
|
|
||||||
alias_names.reserve(options_description.main_description->options().size());
|
|
||||||
for (const auto& option : options_description.main_description->options())
|
|
||||||
alias_names.insert(option->long_name());
|
|
||||||
argsToConfig(common_arguments, getClientConfiguration(), 100, &alias_names);
|
|
||||||
}
|
|
||||||
|
|
||||||
clearPasswordFromCommandLine(argc, argv);
|
|
||||||
|
|
||||||
/// Limit on total memory usage
|
|
||||||
std::string max_client_memory_usage = getClientConfiguration().getString("max_memory_usage_in_client", "0" /*default value*/);
|
|
||||||
if (max_client_memory_usage != "0")
|
|
||||||
{
|
|
||||||
UInt64 max_client_memory_usage_int = parseWithSizeSuffix<UInt64>(max_client_memory_usage.c_str(), max_client_memory_usage.length());
|
|
||||||
|
|
||||||
total_memory_tracker.setHardLimit(max_client_memory_usage_int);
|
|
||||||
total_memory_tracker.setDescription("(total)");
|
|
||||||
total_memory_tracker.setMetric(CurrentMetrics::MemoryTracking);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Print stacktrace in case of crash
|
|
||||||
HandledSignals::instance().setupTerminateHandler();
|
|
||||||
HandledSignals::instance().setupCommonDeadlySignalHandlers();
|
|
||||||
/// We don't setup signal handlers for SIGINT, SIGQUIT, SIGTERM because we don't
|
|
||||||
/// have an option for client to shutdown gracefully.
|
|
||||||
|
|
||||||
fatal_channel_ptr = new Poco::SplitterChannel;
|
|
||||||
fatal_console_channel_ptr = new Poco::ConsoleChannel;
|
|
||||||
fatal_channel_ptr->addChannel(fatal_console_channel_ptr);
|
|
||||||
if (options.count("client_logs_file"))
|
|
||||||
{
|
|
||||||
fatal_file_channel_ptr = new Poco::SimpleFileChannel(options["client_logs_file"].as<std::string>());
|
|
||||||
fatal_channel_ptr->addChannel(fatal_file_channel_ptr);
|
|
||||||
}
|
|
||||||
|
|
||||||
fatal_log = createLogger("ClientBase", fatal_channel_ptr.get(), Poco::Message::PRIO_FATAL);
|
|
||||||
signal_listener = std::make_unique<SignalListener>(nullptr, fatal_log);
|
|
||||||
signal_listener_thread.start(*signal_listener);
|
|
||||||
|
|
||||||
#if USE_GWP_ASAN
|
|
||||||
GWPAsan::initFinished();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,26 +1,32 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <string_view>
|
|
||||||
#include "Common/NamePrompter.h"
|
#include <Client/Suggest.h>
|
||||||
#include <Parsers/ASTCreateQuery.h>
|
#include <Client/QueryFuzzer.h>
|
||||||
#include <Common/ProgressIndication.h>
|
#include <Common/DNSResolver.h>
|
||||||
#include <Common/InterruptListener.h>
|
#include <Common/InterruptListener.h>
|
||||||
|
#include <Common/ProgressIndication.h>
|
||||||
#include <Common/ShellCommand.h>
|
#include <Common/ShellCommand.h>
|
||||||
#include <Common/Stopwatch.h>
|
#include <Common/Stopwatch.h>
|
||||||
#include <Common/DNSResolver.h>
|
|
||||||
#include <Core/ExternalTable.h>
|
#include <Core/ExternalTable.h>
|
||||||
#include <Core/Settings.h>
|
#include <Core/Settings.h>
|
||||||
#include <Poco/Util/Application.h>
|
|
||||||
#include <Poco/ConsoleChannel.h>
|
#include <Poco/ConsoleChannel.h>
|
||||||
#include <Poco/SimpleFileChannel.h>
|
#include <Poco/SimpleFileChannel.h>
|
||||||
#include <Poco/SplitterChannel.h>
|
#include <Poco/SplitterChannel.h>
|
||||||
#include <Interpreters/Context.h>
|
#include <Interpreters/Context.h>
|
||||||
#include <Client/Suggest.h>
|
#include <Parsers/ASTCreateQuery.h>
|
||||||
#include <Client/QueryFuzzer.h>
|
#include <Poco/Util/Application.h>
|
||||||
#include <boost/program_options.hpp>
|
|
||||||
#include <Storages/StorageFile.h>
|
|
||||||
#include <Storages/SelectQueryInfo.h>
|
|
||||||
#include <Storages/MergeTree/MergeTreeSettings.h>
|
#include <Storages/MergeTree/MergeTreeSettings.h>
|
||||||
|
#include <Storages/SelectQueryInfo.h>
|
||||||
|
#include <Storages/StorageFile.h>
|
||||||
|
|
||||||
|
#include <boost/program_options.hpp>
|
||||||
|
|
||||||
|
#include <atomic>
|
||||||
|
#include <optional>
|
||||||
|
#include <string_view>
|
||||||
|
#include <string>
|
||||||
|
|
||||||
namespace po = boost::program_options;
|
namespace po = boost::program_options;
|
||||||
|
|
||||||
@ -64,9 +70,16 @@ std::istream& operator>> (std::istream & in, ProgressOption & progress);
|
|||||||
class InternalTextLogs;
|
class InternalTextLogs;
|
||||||
class WriteBufferFromFileDescriptor;
|
class WriteBufferFromFileDescriptor;
|
||||||
|
|
||||||
class ClientBase : public Poco::Util::Application, public IHints<2>
|
/**
|
||||||
|
* The base class which encapsulates the core functionality of a client.
|
||||||
|
* Can be used in a standalone application (clickhouse-client or clickhouse-local),
|
||||||
|
* or be embedded into server.
|
||||||
|
* Always keep in mind that there can be several instances of this class within
|
||||||
|
* a process. Thus, it cannot keep its state in global shared variables or even use them.
|
||||||
|
* The best example - std::cin, std::cout and std::cerr.
|
||||||
|
*/
|
||||||
|
class ClientBase
|
||||||
{
|
{
|
||||||
|
|
||||||
public:
|
public:
|
||||||
using Arguments = std::vector<String>;
|
using Arguments = std::vector<String>;
|
||||||
|
|
||||||
@ -79,12 +92,11 @@ public:
|
|||||||
std::ostream & output_stream_ = std::cout,
|
std::ostream & output_stream_ = std::cout,
|
||||||
std::ostream & error_stream_ = std::cerr
|
std::ostream & error_stream_ = std::cerr
|
||||||
);
|
);
|
||||||
|
virtual ~ClientBase();
|
||||||
|
|
||||||
~ClientBase() override;
|
bool tryStopQuery() { return query_interrupt_handler.tryStop(); }
|
||||||
|
void stopQuery() { query_interrupt_handler.stop(); }
|
||||||
|
|
||||||
void init(int argc, char ** argv);
|
|
||||||
|
|
||||||
std::vector<String> getAllRegisteredNames() const override { return cmd_options; }
|
|
||||||
ASTPtr parseQuery(const char *& pos, const char * end, const Settings & settings, bool allow_multi_statements);
|
ASTPtr parseQuery(const char *& pos, const char * end, const Settings & settings, bool allow_multi_statements);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
@ -114,7 +126,7 @@ protected:
|
|||||||
ASTPtr parsed_query, std::optional<bool> echo_query_ = {}, bool report_error = false);
|
ASTPtr parsed_query, std::optional<bool> echo_query_ = {}, bool report_error = false);
|
||||||
|
|
||||||
static void adjustQueryEnd(const char *& this_query_end, const char * all_queries_end, uint32_t max_parser_depth, uint32_t max_parser_backtracks);
|
static void adjustQueryEnd(const char *& this_query_end, const char * all_queries_end, uint32_t max_parser_depth, uint32_t max_parser_backtracks);
|
||||||
static void setupSignalHandler();
|
virtual void setupSignalHandler() = 0;
|
||||||
|
|
||||||
bool executeMultiQuery(const String & all_queries_text);
|
bool executeMultiQuery(const String & all_queries_text);
|
||||||
MultiQueryProcessingStage analyzeMultiQueryText(
|
MultiQueryProcessingStage analyzeMultiQueryText(
|
||||||
@ -188,7 +200,6 @@ private:
|
|||||||
String prompt() const;
|
String prompt() const;
|
||||||
|
|
||||||
void resetOutput();
|
void resetOutput();
|
||||||
void parseAndCheckOptions(OptionsDescription & options_description, po::variables_map & options, Arguments & arguments);
|
|
||||||
|
|
||||||
void updateSuggest(const ASTPtr & ast);
|
void updateSuggest(const ASTPtr & ast);
|
||||||
|
|
||||||
@ -196,6 +207,31 @@ private:
|
|||||||
bool addMergeTreeSettings(ASTCreateQuery & ast_create);
|
bool addMergeTreeSettings(ASTCreateQuery & ast_create);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
|
class QueryInterruptHandler : private boost::noncopyable
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/// Store how much interrupt signals can be before stopping the query
|
||||||
|
/// by default stop after the first interrupt signal.
|
||||||
|
void start(Int32 signals_before_stop = 1) { exit_after_signals.store(signals_before_stop); }
|
||||||
|
|
||||||
|
/// Set value not greater then 0 to mark the query as stopped.
|
||||||
|
void stop() { exit_after_signals.store(0); }
|
||||||
|
|
||||||
|
/// Return true if the query was stopped.
|
||||||
|
/// Query was stopped if it received at least "signals_before_stop" interrupt signals.
|
||||||
|
bool tryStop() { return exit_after_signals.fetch_sub(1) <= 0; }
|
||||||
|
bool cancelled() { return exit_after_signals.load() <= 0; }
|
||||||
|
|
||||||
|
/// Return how much interrupt signals remain before stop.
|
||||||
|
Int32 cancelled_status() { return exit_after_signals.load(); }
|
||||||
|
|
||||||
|
private:
|
||||||
|
std::atomic<Int32> exit_after_signals = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
QueryInterruptHandler query_interrupt_handler;
|
||||||
|
|
||||||
static bool isSyncInsertWithData(const ASTInsertQuery & insert_query, const ContextPtr & context);
|
static bool isSyncInsertWithData(const ASTInsertQuery & insert_query, const ContextPtr & context);
|
||||||
bool processMultiQueryFromFile(const String & file_name);
|
bool processMultiQueryFromFile(const String & file_name);
|
||||||
|
|
||||||
@ -219,13 +255,6 @@ protected:
|
|||||||
/// Client context is a context used only by the client to parse queries, process query parameters and to connect to clickhouse-server.
|
/// Client context is a context used only by the client to parse queries, process query parameters and to connect to clickhouse-server.
|
||||||
ContextMutablePtr client_context;
|
ContextMutablePtr client_context;
|
||||||
|
|
||||||
LoggerPtr fatal_log;
|
|
||||||
Poco::AutoPtr<Poco::SplitterChannel> fatal_channel_ptr;
|
|
||||||
Poco::AutoPtr<Poco::Channel> fatal_console_channel_ptr;
|
|
||||||
Poco::AutoPtr<Poco::Channel> fatal_file_channel_ptr;
|
|
||||||
Poco::Thread signal_listener_thread;
|
|
||||||
std::unique_ptr<Poco::Runnable> signal_listener;
|
|
||||||
|
|
||||||
bool is_interactive = false; /// Use either interactive line editing interface or batch mode.
|
bool is_interactive = false; /// Use either interactive line editing interface or batch mode.
|
||||||
bool delayed_interactive = false;
|
bool delayed_interactive = false;
|
||||||
|
|
||||||
@ -239,7 +268,6 @@ protected:
|
|||||||
std::vector<String> queries; /// Queries passed via '--query'
|
std::vector<String> queries; /// Queries passed via '--query'
|
||||||
std::vector<String> queries_files; /// If not empty, queries will be read from these files
|
std::vector<String> queries_files; /// If not empty, queries will be read from these files
|
||||||
std::vector<String> interleave_queries_files; /// If not empty, run queries from these files before processing every file from 'queries_files'.
|
std::vector<String> interleave_queries_files; /// If not empty, run queries from these files before processing every file from 'queries_files'.
|
||||||
std::vector<String> cmd_options;
|
|
||||||
|
|
||||||
bool stdin_is_a_tty = false; /// stdin is a terminal.
|
bool stdin_is_a_tty = false; /// stdin is a terminal.
|
||||||
bool stdout_is_a_tty = false; /// stdout is a terminal.
|
bool stdout_is_a_tty = false; /// stdout is a terminal.
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#include <Client/ClientBase.h>
|
#include <Client/ClientApplicationBase.h>
|
||||||
#include <Core/BaseSettingsProgramOptions.h>
|
#include <Core/BaseSettingsProgramOptions.h>
|
||||||
|
|
||||||
namespace DB
|
namespace DB
|
||||||
@ -80,7 +80,7 @@ private:
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ClientBase::parseAndCheckOptions(OptionsDescription & options_description, po::variables_map & options, Arguments & arguments)
|
void ClientApplicationBase::parseAndCheckOptions(OptionsDescription & options_description, po::variables_map & options, Arguments & arguments)
|
||||||
{
|
{
|
||||||
if (allow_repeated_settings)
|
if (allow_repeated_settings)
|
||||||
addProgramOptionsAsMultitokens(cmd_settings, options_description.main_description.value());
|
addProgramOptionsAsMultitokens(cmd_settings, options_description.main_description.value());
|
||||||
|
@ -42,6 +42,7 @@ public:
|
|||||||
size_t max_error_cap = DBMS_CONNECTION_POOL_WITH_FAILOVER_MAX_ERROR_COUNT);
|
size_t max_error_cap = DBMS_CONNECTION_POOL_WITH_FAILOVER_MAX_ERROR_COUNT);
|
||||||
|
|
||||||
using Entry = IConnectionPool::Entry;
|
using Entry = IConnectionPool::Entry;
|
||||||
|
using PoolWithFailoverBase<IConnectionPool>::isTryResultInvalid;
|
||||||
|
|
||||||
/** Allocates connection to work. */
|
/** Allocates connection to work. */
|
||||||
Entry get(const ConnectionTimeouts & timeouts) override;
|
Entry get(const ConnectionTimeouts & timeouts) override;
|
||||||
|
@ -1559,8 +1559,7 @@ bool Dwarf::isAddrInRangeList(const CompilationUnit & cu,
|
|||||||
auto sp_start = addr_.substr(*cu.addr_base + index_start * sizeof(uint64_t));
|
auto sp_start = addr_.substr(*cu.addr_base + index_start * sizeof(uint64_t));
|
||||||
auto start = read<uint64_t>(sp_start);
|
auto start = read<uint64_t>(sp_start);
|
||||||
|
|
||||||
auto sp_end = addr_.substr(*cu.addr_base + index_start * sizeof(uint64_t) + length);
|
auto end = start + length;
|
||||||
auto end = read<uint64_t>(sp_end);
|
|
||||||
if (start != end && address >= start && address < end)
|
if (start != end && address >= start && address < end)
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
|
@ -116,6 +116,12 @@ public:
|
|||||||
const TryGetEntryFunc & try_get_entry,
|
const TryGetEntryFunc & try_get_entry,
|
||||||
const GetPriorityFunc & get_priority);
|
const GetPriorityFunc & get_priority);
|
||||||
|
|
||||||
|
// Returns if the TryResult provided is an invalid one that cannot be used. Used to prevent logical errors.
|
||||||
|
bool isTryResultInvalid(const TryResult & result, bool skip_read_only_replicas) const
|
||||||
|
{
|
||||||
|
return result.entry.isNull() || !result.is_usable || (skip_read_only_replicas && result.is_readonly);
|
||||||
|
}
|
||||||
|
|
||||||
size_t getPoolSize() const { return nested_pools.size(); }
|
size_t getPoolSize() const { return nested_pools.size(); }
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
@ -300,7 +306,7 @@ PoolWithFailoverBase<TNestedPool>::getMany(
|
|||||||
throw DB::NetException(DB::ErrorCodes::ALL_CONNECTION_TRIES_FAILED,
|
throw DB::NetException(DB::ErrorCodes::ALL_CONNECTION_TRIES_FAILED,
|
||||||
"All connection tries failed. Log: \n\n{}\n", fail_messages);
|
"All connection tries failed. Log: \n\n{}\n", fail_messages);
|
||||||
|
|
||||||
std::erase_if(try_results, [&](const TryResult & r) { return r.entry.isNull() || !r.is_usable || (skip_read_only_replicas && r.is_readonly); });
|
std::erase_if(try_results, [&](const TryResult & r) { return isTryResultInvalid(r, skip_read_only_replicas); });
|
||||||
|
|
||||||
/// Sort so that preferred items are near the beginning.
|
/// Sort so that preferred items are near the beginning.
|
||||||
std::stable_sort(
|
std::stable_sort(
|
||||||
@ -321,6 +327,9 @@ PoolWithFailoverBase<TNestedPool>::getMany(
|
|||||||
}
|
}
|
||||||
else if (up_to_date_count >= min_entries)
|
else if (up_to_date_count >= min_entries)
|
||||||
{
|
{
|
||||||
|
if (try_results.size() < up_to_date_count)
|
||||||
|
throw DB::Exception(DB::ErrorCodes::LOGICAL_ERROR, "Could not find enough connections for up-to-date results. Got: {}, needed: {}", try_results.size(), up_to_date_count);
|
||||||
|
|
||||||
/// There is enough up-to-date entries.
|
/// There is enough up-to-date entries.
|
||||||
try_results.resize(up_to_date_count);
|
try_results.resize(up_to_date_count);
|
||||||
}
|
}
|
||||||
|
@ -2,9 +2,11 @@
|
|||||||
|
|
||||||
#include <Common/TimerDescriptor.h>
|
#include <Common/TimerDescriptor.h>
|
||||||
#include <Common/Exception.h>
|
#include <Common/Exception.h>
|
||||||
|
#include <Common/logger_useful.h>
|
||||||
|
|
||||||
#include <sys/timerfd.h>
|
#include <sys/timerfd.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
#include <fmt/format.h>
|
||||||
|
|
||||||
|
|
||||||
namespace DB
|
namespace DB
|
||||||
@ -89,9 +91,29 @@ void TimerDescriptor::drain() const
|
|||||||
|
|
||||||
/// A signal happened, need to retry.
|
/// A signal happened, need to retry.
|
||||||
if (errno == EINTR)
|
if (errno == EINTR)
|
||||||
continue;
|
{
|
||||||
|
/** This is to help with debugging.
|
||||||
|
*
|
||||||
|
* Sometimes reading from timer_fd blocks, which should not happen, because we opened it in a non-blocking mode.
|
||||||
|
* But it could be possible if a rogue 3rd-party library closed our file descriptor by mistake
|
||||||
|
* (for example by double closing due to the lack of exception safety or if it is a crappy code in plain C)
|
||||||
|
* and then another file descriptor is opened in its place.
|
||||||
|
*
|
||||||
|
* Let's try to get a name of this file descriptor and log it.
|
||||||
|
*/
|
||||||
|
LoggerPtr log = getLogger("TimerDescriptor");
|
||||||
|
|
||||||
throw ErrnoException(ErrorCodes::CANNOT_READ_FROM_SOCKET, "Cannot drain timer_fd");
|
static constexpr ssize_t max_link_path_length = 256;
|
||||||
|
char link_path[max_link_path_length];
|
||||||
|
ssize_t link_path_length = readlink(fmt::format("/proc/self/fd/{}", timer_fd).c_str(), link_path, max_link_path_length);
|
||||||
|
if (-1 == link_path_length)
|
||||||
|
throw ErrnoException(ErrorCodes::CANNOT_READ_FROM_SOCKET, "Cannot readlink for a timer_fd {}", timer_fd);
|
||||||
|
|
||||||
|
LOG_TRACE(log, "Received EINTR while trying to drain a TimerDescriptor, fd {}: {}", timer_fd, std::string_view(link_path, link_path_length));
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
throw ErrnoException(ErrorCodes::CANNOT_READ_FROM_SOCKET, "Cannot drain timer_fd {}", timer_fd);
|
||||||
}
|
}
|
||||||
|
|
||||||
chassert(res == sizeof(buf));
|
chassert(res == sizeof(buf));
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#include "ServerSettings.h"
|
#include <Core/ServerSettings.h>
|
||||||
#include <Poco/Util/AbstractConfiguration.h>
|
#include <Poco/Util/AbstractConfiguration.h>
|
||||||
|
|
||||||
namespace DB
|
namespace DB
|
||||||
|
@ -66,6 +66,15 @@ namespace DB
|
|||||||
M(Bool, async_insert_queue_flush_on_shutdown, true, "If true queue of asynchronous inserts is flushed on graceful shutdown", 0) \
|
M(Bool, async_insert_queue_flush_on_shutdown, true, "If true queue of asynchronous inserts is flushed on graceful shutdown", 0) \
|
||||||
M(Bool, ignore_empty_sql_security_in_create_view_query, true, "If true, ClickHouse doesn't write defaults for empty SQL security statement in CREATE VIEW queries. This setting is only necessary for the migration period and will become obsolete in 24.4", 0) \
|
M(Bool, ignore_empty_sql_security_in_create_view_query, true, "If true, ClickHouse doesn't write defaults for empty SQL security statement in CREATE VIEW queries. This setting is only necessary for the migration period and will become obsolete in 24.4", 0) \
|
||||||
\
|
\
|
||||||
|
/* Database Catalog */ \
|
||||||
|
M(UInt64, database_atomic_delay_before_drop_table_sec, 8 * 60, "The delay during which a dropped table can be restored using the UNDROP statement. If DROP TABLE ran with a SYNC modifier, the setting is ignored.", 0) \
|
||||||
|
M(UInt64, database_catalog_unused_dir_hide_timeout_sec, 60 * 60, "Parameter of a task that cleans up garbage from store/ directory. If some subdirectory is not used by clickhouse-server and this directory was not modified for last database_catalog_unused_dir_hide_timeout_sec seconds, the task will 'hide' this directory by removing all access rights. It also works for directories that clickhouse-server does not expect to see inside store/. Zero means 'immediately'.", 0) \
|
||||||
|
M(UInt64, database_catalog_unused_dir_rm_timeout_sec, 30 * 24 * 60 * 60, "Parameter of a task that cleans up garbage from store/ directory. If some subdirectory is not used by clickhouse-server and it was previously 'hidden' (see database_catalog_unused_dir_hide_timeout_sec) and this directory was not modified for last database_catalog_unused_dir_rm_timeout_sec seconds, the task will remove this directory. It also works for directories that clickhouse-server does not expect to see inside store/. Zero means 'never'.", 0) \
|
||||||
|
M(UInt64, database_catalog_unused_dir_cleanup_period_sec, 24 * 60 * 60, "Parameter of a task that cleans up garbage from store/ directory. Sets scheduling period of the task. Zero means 'never'.", 0) \
|
||||||
|
M(UInt64, database_catalog_drop_error_cooldown_sec, 5, "In case if drop table failed, ClickHouse will wait for this timeout before retrying the operation.", 0) \
|
||||||
|
M(UInt64, database_catalog_drop_table_concurrency, 16, "The size of the threadpool used for dropping tables.", 0) \
|
||||||
|
\
|
||||||
|
\
|
||||||
M(UInt64, max_concurrent_queries, 0, "Maximum number of concurrently executed queries. Zero means unlimited.", 0) \
|
M(UInt64, max_concurrent_queries, 0, "Maximum number of concurrently executed queries. Zero means unlimited.", 0) \
|
||||||
M(UInt64, max_concurrent_insert_queries, 0, "Maximum number of concurrently INSERT queries. Zero means unlimited.", 0) \
|
M(UInt64, max_concurrent_insert_queries, 0, "Maximum number of concurrently INSERT queries. Zero means unlimited.", 0) \
|
||||||
M(UInt64, max_concurrent_select_queries, 0, "Maximum number of concurrently SELECT queries. Zero means unlimited.", 0) \
|
M(UInt64, max_concurrent_select_queries, 0, "Maximum number of concurrently SELECT queries. Zero means unlimited.", 0) \
|
||||||
|
@ -80,9 +80,7 @@ static std::initializer_list<std::pair<ClickHouseVersion, SettingsChangesHistory
|
|||||||
{"ignore_on_cluster_for_replicated_named_collections_queries", false, false, "Ignore ON CLUSTER clause for replicated named collections management queries."},
|
{"ignore_on_cluster_for_replicated_named_collections_queries", false, false, "Ignore ON CLUSTER clause for replicated named collections management queries."},
|
||||||
{"backup_restore_s3_retry_attempts", 1000,1000, "Setting for Aws::Client::RetryStrategy, Aws::Client does retries itself, 0 means no retries. It takes place only for backup/restore."},
|
{"backup_restore_s3_retry_attempts", 1000,1000, "Setting for Aws::Client::RetryStrategy, Aws::Client does retries itself, 0 means no retries. It takes place only for backup/restore."},
|
||||||
{"postgresql_connection_attempt_timeout", 2, 2, "Allow to control 'connect_timeout' parameter of PostgreSQL connection."},
|
{"postgresql_connection_attempt_timeout", 2, 2, "Allow to control 'connect_timeout' parameter of PostgreSQL connection."},
|
||||||
{"postgresql_connection_pool_retries", 2, 2, "Allow to control the number of retries in PostgreSQL connection pool."},
|
{"postgresql_connection_pool_retries", 2, 2, "Allow to control the number of retries in PostgreSQL connection pool."}
|
||||||
{"restore_replace_external_table_functions_to_null", false, false, "New setting."},
|
|
||||||
{"restore_replace_external_engines_to_null", false, false, "New setting."}
|
|
||||||
}},
|
}},
|
||||||
{"24.6", {{"materialize_skip_indexes_on_insert", true, true, "Added new setting to allow to disable materialization of skip indexes on insert"},
|
{"24.6", {{"materialize_skip_indexes_on_insert", true, true, "Added new setting to allow to disable materialization of skip indexes on insert"},
|
||||||
{"materialize_statistics_on_insert", true, true, "Added new setting to allow to disable materialization of statistics on insert"},
|
{"materialize_statistics_on_insert", true, true, "Added new setting to allow to disable materialization of statistics on insert"},
|
||||||
|
@ -111,7 +111,7 @@ ASTPtr DatabaseDictionary::getCreateTableQueryImpl(const String & table_name, Co
|
|||||||
buffer << ") Engine = Dictionary(" << backQuoteIfNeed(table_name) << ")";
|
buffer << ") Engine = Dictionary(" << backQuoteIfNeed(table_name) << ")";
|
||||||
}
|
}
|
||||||
|
|
||||||
auto settings = getContext()->getSettingsRef();
|
const auto & settings = getContext()->getSettingsRef();
|
||||||
ParserCreateQuery parser;
|
ParserCreateQuery parser;
|
||||||
const char * pos = query.data();
|
const char * pos = query.data();
|
||||||
std::string error_message;
|
std::string error_message;
|
||||||
@ -133,7 +133,7 @@ ASTPtr DatabaseDictionary::getCreateDatabaseQuery() const
|
|||||||
if (const auto comment_value = getDatabaseComment(); !comment_value.empty())
|
if (const auto comment_value = getDatabaseComment(); !comment_value.empty())
|
||||||
buffer << " COMMENT " << backQuote(comment_value);
|
buffer << " COMMENT " << backQuote(comment_value);
|
||||||
}
|
}
|
||||||
auto settings = getContext()->getSettingsRef();
|
const auto & settings = getContext()->getSettingsRef();
|
||||||
ParserCreateQuery parser;
|
ParserCreateQuery parser;
|
||||||
return parseQuery(parser, query.data(), query.data() + query.size(), "", 0, settings.max_parser_depth, settings.max_parser_backtracks);
|
return parseQuery(parser, query.data(), query.data() + query.size(), "", 0, settings.max_parser_depth, settings.max_parser_backtracks);
|
||||||
}
|
}
|
||||||
|
@ -534,7 +534,7 @@ ASTPtr DatabaseOnDisk::getCreateDatabaseQuery() const
|
|||||||
{
|
{
|
||||||
ASTPtr ast;
|
ASTPtr ast;
|
||||||
|
|
||||||
auto settings = getContext()->getSettingsRef();
|
const auto & settings = getContext()->getSettingsRef();
|
||||||
{
|
{
|
||||||
std::lock_guard lock(mutex);
|
std::lock_guard lock(mutex);
|
||||||
auto database_metadata_path = getContext()->getPath() + "metadata/" + escapeForFileName(database_name) + ".sql";
|
auto database_metadata_path = getContext()->getPath() + "metadata/" + escapeForFileName(database_name) + ".sql";
|
||||||
@ -733,7 +733,7 @@ ASTPtr DatabaseOnDisk::parseQueryFromMetadata(
|
|||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
auto settings = local_context->getSettingsRef();
|
const auto & settings = local_context->getSettingsRef();
|
||||||
ParserCreateQuery parser;
|
ParserCreateQuery parser;
|
||||||
const char * pos = query.data();
|
const char * pos = query.data();
|
||||||
std::string error_message;
|
std::string error_message;
|
||||||
|
@ -89,7 +89,7 @@ static constexpr auto MYSQL_BACKGROUND_THREAD_NAME = "MySQLDBSync";
|
|||||||
|
|
||||||
static ContextMutablePtr createQueryContext(ContextPtr context)
|
static ContextMutablePtr createQueryContext(ContextPtr context)
|
||||||
{
|
{
|
||||||
Settings new_query_settings = context->getSettings();
|
Settings new_query_settings = context->getSettingsCopy();
|
||||||
new_query_settings.insert_allow_materialized_columns = true;
|
new_query_settings.insert_allow_materialized_columns = true;
|
||||||
|
|
||||||
/// To avoid call AST::format
|
/// To avoid call AST::format
|
||||||
|
@ -252,7 +252,7 @@ FormatSettings getFormatSettings(const ContextPtr & context, const Settings & se
|
|||||||
format_settings.msgpack.number_of_columns = settings.input_format_msgpack_number_of_columns;
|
format_settings.msgpack.number_of_columns = settings.input_format_msgpack_number_of_columns;
|
||||||
format_settings.msgpack.output_uuid_representation = settings.output_format_msgpack_uuid_representation;
|
format_settings.msgpack.output_uuid_representation = settings.output_format_msgpack_uuid_representation;
|
||||||
format_settings.max_rows_to_read_for_schema_inference = settings.input_format_max_rows_to_read_for_schema_inference;
|
format_settings.max_rows_to_read_for_schema_inference = settings.input_format_max_rows_to_read_for_schema_inference;
|
||||||
format_settings.max_bytes_to_read_for_schema_inference = settings.input_format_max_rows_to_read_for_schema_inference;
|
format_settings.max_bytes_to_read_for_schema_inference = settings.input_format_max_bytes_to_read_for_schema_inference;
|
||||||
format_settings.column_names_for_schema_inference = settings.column_names_for_schema_inference;
|
format_settings.column_names_for_schema_inference = settings.column_names_for_schema_inference;
|
||||||
format_settings.schema_inference_hints = settings.schema_inference_hints;
|
format_settings.schema_inference_hints = settings.schema_inference_hints;
|
||||||
format_settings.schema_inference_make_columns_nullable = settings.schema_inference_make_columns_nullable;
|
format_settings.schema_inference_make_columns_nullable = settings.schema_inference_make_columns_nullable;
|
||||||
|
@ -39,7 +39,7 @@ public:
|
|||||||
FunctionFormatQuery(ContextPtr context, String name_, OutputFormatting output_formatting_, ErrorHandling error_handling_)
|
FunctionFormatQuery(ContextPtr context, String name_, OutputFormatting output_formatting_, ErrorHandling error_handling_)
|
||||||
: name(name_), output_formatting(output_formatting_), error_handling(error_handling_)
|
: name(name_), output_formatting(output_formatting_), error_handling(error_handling_)
|
||||||
{
|
{
|
||||||
const Settings & settings = context->getSettings();
|
const Settings & settings = context->getSettingsRef();
|
||||||
max_query_size = settings.max_query_size;
|
max_query_size = settings.max_query_size;
|
||||||
max_parser_depth = settings.max_parser_depth;
|
max_parser_depth = settings.max_parser_depth;
|
||||||
max_parser_backtracks = settings.max_parser_backtracks;
|
max_parser_backtracks = settings.max_parser_backtracks;
|
||||||
|
@ -143,7 +143,7 @@ ColumnPtr FunctionHasColumnInTable::executeImpl(const ColumnsWithTypeAndName & a
|
|||||||
/* cluster_name= */ "",
|
/* cluster_name= */ "",
|
||||||
/* password= */ ""
|
/* password= */ ""
|
||||||
};
|
};
|
||||||
auto cluster = std::make_shared<Cluster>(getContext()->getSettings(), host_names, params);
|
auto cluster = std::make_shared<Cluster>(getContext()->getSettingsRef(), host_names, params);
|
||||||
|
|
||||||
// FIXME this (probably) needs a non-constant access to query context,
|
// FIXME this (probably) needs a non-constant access to query context,
|
||||||
// because it might initialized a storage. Ideally, the tables required
|
// because it might initialized a storage. Ideally, the tables required
|
||||||
|
@ -3,8 +3,6 @@
|
|||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
#include <fmt/format.h>
|
|
||||||
|
|
||||||
#include <Common/formatReadable.h>
|
#include <Common/formatReadable.h>
|
||||||
#include <Common/Exception.h>
|
#include <Common/Exception.h>
|
||||||
#include <base/getPageSize.h>
|
#include <base/getPageSize.h>
|
||||||
|
@ -23,6 +23,9 @@ namespace CurrentMetrics
|
|||||||
extern const Metric MergeTreeUnexpectedPartsLoaderThreads;
|
extern const Metric MergeTreeUnexpectedPartsLoaderThreads;
|
||||||
extern const Metric MergeTreeUnexpectedPartsLoaderThreadsActive;
|
extern const Metric MergeTreeUnexpectedPartsLoaderThreadsActive;
|
||||||
extern const Metric MergeTreeUnexpectedPartsLoaderThreadsScheduled;
|
extern const Metric MergeTreeUnexpectedPartsLoaderThreadsScheduled;
|
||||||
|
extern const Metric DatabaseCatalogThreads;
|
||||||
|
extern const Metric DatabaseCatalogThreadsActive;
|
||||||
|
extern const Metric DatabaseCatalogThreadsScheduled;
|
||||||
extern const Metric DatabaseReplicatedCreateTablesThreads;
|
extern const Metric DatabaseReplicatedCreateTablesThreads;
|
||||||
extern const Metric DatabaseReplicatedCreateTablesThreadsActive;
|
extern const Metric DatabaseReplicatedCreateTablesThreadsActive;
|
||||||
extern const Metric DatabaseReplicatedCreateTablesThreadsScheduled;
|
extern const Metric DatabaseReplicatedCreateTablesThreadsScheduled;
|
||||||
@ -166,4 +169,11 @@ StaticThreadPool & getDatabaseReplicatedCreateTablesThreadPool()
|
|||||||
return instance;
|
return instance;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// ThreadPool used for dropping tables.
|
||||||
|
StaticThreadPool & getDatabaseCatalogDropTablesThreadPool()
|
||||||
|
{
|
||||||
|
static StaticThreadPool instance("DropTablesThreadPool", CurrentMetrics::DatabaseCatalogThreads, CurrentMetrics::DatabaseCatalogThreadsActive, CurrentMetrics::DatabaseCatalogThreadsScheduled);
|
||||||
|
return instance;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -69,4 +69,7 @@ StaticThreadPool & getUnexpectedPartsLoadingThreadPool();
|
|||||||
/// ThreadPool used for creating tables in DatabaseReplicated.
|
/// ThreadPool used for creating tables in DatabaseReplicated.
|
||||||
StaticThreadPool & getDatabaseReplicatedCreateTablesThreadPool();
|
StaticThreadPool & getDatabaseReplicatedCreateTablesThreadPool();
|
||||||
|
|
||||||
|
/// ThreadPool used for dropping tables.
|
||||||
|
StaticThreadPool & getDatabaseCatalogDropTablesThreadPool();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -379,6 +379,10 @@ struct ContextSharedPart : boost::noncopyable
|
|||||||
ActionLocksManagerPtr action_locks_manager; /// Set of storages' action lockers
|
ActionLocksManagerPtr action_locks_manager; /// Set of storages' action lockers
|
||||||
OnceFlag system_logs_initialized;
|
OnceFlag system_logs_initialized;
|
||||||
std::unique_ptr<SystemLogs> system_logs TSA_GUARDED_BY(mutex); /// Used to log queries and operations on parts
|
std::unique_ptr<SystemLogs> system_logs TSA_GUARDED_BY(mutex); /// Used to log queries and operations on parts
|
||||||
|
|
||||||
|
mutable std::mutex dashboard_mutex;
|
||||||
|
std::optional<Context::Dashboards> dashboards;
|
||||||
|
|
||||||
std::optional<S3SettingsByEndpoint> storage_s3_settings TSA_GUARDED_BY(mutex); /// Settings of S3 storage
|
std::optional<S3SettingsByEndpoint> storage_s3_settings TSA_GUARDED_BY(mutex); /// Settings of S3 storage
|
||||||
std::vector<String> warnings TSA_GUARDED_BY(mutex); /// Store warning messages about server configuration.
|
std::vector<String> warnings TSA_GUARDED_BY(mutex); /// Store warning messages about server configuration.
|
||||||
|
|
||||||
@ -2266,7 +2270,7 @@ bool Context::displaySecretsInShowAndSelect() const
|
|||||||
return shared->server_settings.display_secrets_in_show_and_select;
|
return shared->server_settings.display_secrets_in_show_and_select;
|
||||||
}
|
}
|
||||||
|
|
||||||
Settings Context::getSettings() const
|
Settings Context::getSettingsCopy() const
|
||||||
{
|
{
|
||||||
SharedLockGuard lock(mutex);
|
SharedLockGuard lock(mutex);
|
||||||
return *settings;
|
return *settings;
|
||||||
@ -4313,6 +4317,51 @@ std::vector<ISystemLog *> Context::getSystemLogs() const
|
|||||||
return shared->system_logs->logs;
|
return shared->system_logs->logs;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::optional<Context::Dashboards> Context::getDashboards() const
|
||||||
|
{
|
||||||
|
std::lock_guard lock(shared->dashboard_mutex);
|
||||||
|
|
||||||
|
if (!shared->dashboards)
|
||||||
|
return {};
|
||||||
|
return shared->dashboards;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace
|
||||||
|
{
|
||||||
|
|
||||||
|
String trim(const String & text)
|
||||||
|
{
|
||||||
|
std::string_view view(text);
|
||||||
|
::trim(view, '\n');
|
||||||
|
return String(view);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void Context::setDashboardsConfig(const ConfigurationPtr & config)
|
||||||
|
{
|
||||||
|
Poco::Util::AbstractConfiguration::Keys keys;
|
||||||
|
config->keys("dashboards", keys);
|
||||||
|
|
||||||
|
Dashboards dashboards;
|
||||||
|
for (const auto & key : keys)
|
||||||
|
{
|
||||||
|
const auto & prefix = "dashboards." + key + ".";
|
||||||
|
dashboards.push_back({
|
||||||
|
{ "dashboard", config->getString(prefix + "dashboard") },
|
||||||
|
{ "title", config->getString(prefix + "title") },
|
||||||
|
{ "query", trim(config->getString(prefix + "query")) },
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
std::lock_guard lock(shared->dashboard_mutex);
|
||||||
|
if (!dashboards.empty())
|
||||||
|
shared->dashboards.emplace(std::move(dashboards));
|
||||||
|
else
|
||||||
|
shared->dashboards.reset();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
CompressionCodecPtr Context::chooseCompressionCodec(size_t part_size, double part_size_ratio) const
|
CompressionCodecPtr Context::chooseCompressionCodec(size_t part_size, double part_size_ratio) const
|
||||||
{
|
{
|
||||||
|
@ -829,7 +829,8 @@ public:
|
|||||||
void setMacros(std::unique_ptr<Macros> && macros);
|
void setMacros(std::unique_ptr<Macros> && macros);
|
||||||
|
|
||||||
bool displaySecretsInShowAndSelect() const;
|
bool displaySecretsInShowAndSelect() const;
|
||||||
Settings getSettings() const;
|
Settings getSettingsCopy() const;
|
||||||
|
const Settings & getSettingsRef() const { return *settings; }
|
||||||
void setSettings(const Settings & settings_);
|
void setSettings(const Settings & settings_);
|
||||||
|
|
||||||
/// Set settings by name.
|
/// Set settings by name.
|
||||||
@ -954,8 +955,6 @@ public:
|
|||||||
void makeSessionContext();
|
void makeSessionContext();
|
||||||
void makeGlobalContext();
|
void makeGlobalContext();
|
||||||
|
|
||||||
const Settings & getSettingsRef() const { return *settings; }
|
|
||||||
|
|
||||||
void setProgressCallback(ProgressCallback callback);
|
void setProgressCallback(ProgressCallback callback);
|
||||||
/// Used in executeQuery() to pass it to the QueryPipeline.
|
/// Used in executeQuery() to pass it to the QueryPipeline.
|
||||||
ProgressCallback getProgressCallback() const;
|
ProgressCallback getProgressCallback() const;
|
||||||
@ -1153,6 +1152,10 @@ public:
|
|||||||
|
|
||||||
std::vector<ISystemLog *> getSystemLogs() const;
|
std::vector<ISystemLog *> getSystemLogs() const;
|
||||||
|
|
||||||
|
using Dashboards = std::vector<std::map<String, String>>;
|
||||||
|
std::optional<Dashboards> getDashboards() const;
|
||||||
|
void setDashboardsConfig(const ConfigurationPtr & config);
|
||||||
|
|
||||||
/// Returns an object used to log operations with parts if it possible.
|
/// Returns an object used to log operations with parts if it possible.
|
||||||
/// Provide table name to make required checks.
|
/// Provide table name to make required checks.
|
||||||
std::shared_ptr<PartLog> getPartLog(const String & part_database) const;
|
std::shared_ptr<PartLog> getPartLog(const String & part_database) const;
|
||||||
|
@ -19,6 +19,8 @@
|
|||||||
#include <IO/ReadHelpers.h>
|
#include <IO/ReadHelpers.h>
|
||||||
#include <Poco/DirectoryIterator.h>
|
#include <Poco/DirectoryIterator.h>
|
||||||
#include <Poco/Util/AbstractConfiguration.h>
|
#include <Poco/Util/AbstractConfiguration.h>
|
||||||
|
#include <Core/ServerSettings.h>
|
||||||
|
#include <IO/SharedThreadPools.h>
|
||||||
#include <Common/Exception.h>
|
#include <Common/Exception.h>
|
||||||
#include <Common/quoteString.h>
|
#include <Common/quoteString.h>
|
||||||
#include <Common/atomicRename.h>
|
#include <Common/atomicRename.h>
|
||||||
@ -48,9 +50,6 @@
|
|||||||
namespace CurrentMetrics
|
namespace CurrentMetrics
|
||||||
{
|
{
|
||||||
extern const Metric TablesToDropQueueSize;
|
extern const Metric TablesToDropQueueSize;
|
||||||
extern const Metric DatabaseCatalogThreads;
|
|
||||||
extern const Metric DatabaseCatalogThreadsActive;
|
|
||||||
extern const Metric DatabaseCatalogThreadsScheduled;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace DB
|
namespace DB
|
||||||
@ -189,13 +188,6 @@ StoragePtr TemporaryTableHolder::getTable() const
|
|||||||
|
|
||||||
void DatabaseCatalog::initializeAndLoadTemporaryDatabase()
|
void DatabaseCatalog::initializeAndLoadTemporaryDatabase()
|
||||||
{
|
{
|
||||||
drop_delay_sec = getContext()->getConfigRef().getInt("database_atomic_delay_before_drop_table_sec", default_drop_delay_sec);
|
|
||||||
unused_dir_hide_timeout_sec = getContext()->getConfigRef().getInt64("database_catalog_unused_dir_hide_timeout_sec", unused_dir_hide_timeout_sec);
|
|
||||||
unused_dir_rm_timeout_sec = getContext()->getConfigRef().getInt64("database_catalog_unused_dir_rm_timeout_sec", unused_dir_rm_timeout_sec);
|
|
||||||
unused_dir_cleanup_period_sec = getContext()->getConfigRef().getInt64("database_catalog_unused_dir_cleanup_period_sec", unused_dir_cleanup_period_sec);
|
|
||||||
drop_error_cooldown_sec = getContext()->getConfigRef().getInt64("database_catalog_drop_error_cooldown_sec", drop_error_cooldown_sec);
|
|
||||||
drop_table_concurrency = getContext()->getConfigRef().getInt64("database_catalog_drop_table_concurrency", drop_table_concurrency);
|
|
||||||
|
|
||||||
auto db_for_temporary_and_external_tables = std::make_shared<DatabaseMemory>(TEMPORARY_DATABASE, getContext());
|
auto db_for_temporary_and_external_tables = std::make_shared<DatabaseMemory>(TEMPORARY_DATABASE, getContext());
|
||||||
attachDatabase(TEMPORARY_DATABASE, db_for_temporary_and_external_tables);
|
attachDatabase(TEMPORARY_DATABASE, db_for_temporary_and_external_tables);
|
||||||
}
|
}
|
||||||
@ -203,7 +195,7 @@ void DatabaseCatalog::initializeAndLoadTemporaryDatabase()
|
|||||||
void DatabaseCatalog::createBackgroundTasks()
|
void DatabaseCatalog::createBackgroundTasks()
|
||||||
{
|
{
|
||||||
/// It has to be done before databases are loaded (to avoid a race condition on initialization)
|
/// It has to be done before databases are loaded (to avoid a race condition on initialization)
|
||||||
if (Context::getGlobalContextInstance()->getApplicationType() == Context::ApplicationType::SERVER && unused_dir_cleanup_period_sec)
|
if (Context::getGlobalContextInstance()->getApplicationType() == Context::ApplicationType::SERVER && getContext()->getServerSettings().database_catalog_unused_dir_cleanup_period_sec)
|
||||||
{
|
{
|
||||||
auto cleanup_task_holder
|
auto cleanup_task_holder
|
||||||
= getContext()->getSchedulePool().createTask("DatabaseCatalogCleanupStoreDirectoryTask", [this]() { this->cleanupStoreDirectoryTask(); });
|
= getContext()->getSchedulePool().createTask("DatabaseCatalogCleanupStoreDirectoryTask", [this]() { this->cleanupStoreDirectoryTask(); });
|
||||||
@ -224,7 +216,7 @@ void DatabaseCatalog::startupBackgroundTasks()
|
|||||||
{
|
{
|
||||||
(*cleanup_task)->activate();
|
(*cleanup_task)->activate();
|
||||||
/// Do not start task immediately on server startup, it's not urgent.
|
/// Do not start task immediately on server startup, it's not urgent.
|
||||||
(*cleanup_task)->scheduleAfter(unused_dir_hide_timeout_sec * 1000);
|
(*cleanup_task)->scheduleAfter(static_cast<time_t>(getContext()->getServerSettings().database_catalog_unused_dir_hide_timeout_sec) * 1000);
|
||||||
}
|
}
|
||||||
|
|
||||||
(*drop_task)->activate();
|
(*drop_task)->activate();
|
||||||
@ -1038,15 +1030,12 @@ void DatabaseCatalog::loadMarkedAsDroppedTables()
|
|||||||
|
|
||||||
LOG_INFO(log, "Found {} partially dropped tables. Will load them and retry removal.", dropped_metadata.size());
|
LOG_INFO(log, "Found {} partially dropped tables. Will load them and retry removal.", dropped_metadata.size());
|
||||||
|
|
||||||
ThreadPool pool(CurrentMetrics::DatabaseCatalogThreads, CurrentMetrics::DatabaseCatalogThreadsActive, CurrentMetrics::DatabaseCatalogThreadsScheduled);
|
ThreadPoolCallbackRunnerLocal<void> runner(getDatabaseCatalogDropTablesThreadPool().get(), "DropTables");
|
||||||
for (const auto & elem : dropped_metadata)
|
for (const auto & elem : dropped_metadata)
|
||||||
{
|
{
|
||||||
pool.scheduleOrThrowOnError([&]()
|
runner([this, &elem](){ this->enqueueDroppedTableCleanup(elem.second, nullptr, elem.first); });
|
||||||
{
|
|
||||||
this->enqueueDroppedTableCleanup(elem.second, nullptr, elem.first);
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
pool.wait();
|
runner.waitForAllToFinishAndRethrowFirstError();
|
||||||
}
|
}
|
||||||
|
|
||||||
String DatabaseCatalog::getPathForDroppedMetadata(const StorageID & table_id) const
|
String DatabaseCatalog::getPathForDroppedMetadata(const StorageID & table_id) const
|
||||||
@ -1135,7 +1124,13 @@ void DatabaseCatalog::enqueueDroppedTableCleanup(StorageID table_id, StoragePtr
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
tables_marked_dropped.push_back({table_id, table, dropped_metadata_path, drop_time + drop_delay_sec});
|
tables_marked_dropped.push_back
|
||||||
|
({
|
||||||
|
table_id,
|
||||||
|
table,
|
||||||
|
dropped_metadata_path,
|
||||||
|
drop_time + static_cast<time_t>(getContext()->getServerSettings().database_atomic_delay_before_drop_table_sec)
|
||||||
|
});
|
||||||
if (first_async_drop_in_queue == tables_marked_dropped.end())
|
if (first_async_drop_in_queue == tables_marked_dropped.end())
|
||||||
--first_async_drop_in_queue;
|
--first_async_drop_in_queue;
|
||||||
}
|
}
|
||||||
@ -1289,13 +1284,7 @@ void DatabaseCatalog::dropTablesParallel(std::vector<DatabaseCatalog::TablesMark
|
|||||||
if (tables_to_drop.empty())
|
if (tables_to_drop.empty())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
ThreadPool pool(
|
ThreadPoolCallbackRunnerLocal<void> runner(getDatabaseCatalogDropTablesThreadPool().get(), "DropTables");
|
||||||
CurrentMetrics::DatabaseCatalogThreads,
|
|
||||||
CurrentMetrics::DatabaseCatalogThreadsActive,
|
|
||||||
CurrentMetrics::DatabaseCatalogThreadsScheduled,
|
|
||||||
/* max_threads */drop_table_concurrency,
|
|
||||||
/* max_free_threads */0,
|
|
||||||
/* queue_size */tables_to_drop.size());
|
|
||||||
|
|
||||||
for (const auto & item : tables_to_drop)
|
for (const auto & item : tables_to_drop)
|
||||||
{
|
{
|
||||||
@ -1332,7 +1321,7 @@ void DatabaseCatalog::dropTablesParallel(std::vector<DatabaseCatalog::TablesMark
|
|||||||
++first_async_drop_in_queue;
|
++first_async_drop_in_queue;
|
||||||
|
|
||||||
tables_marked_dropped.splice(tables_marked_dropped.end(), tables_marked_dropped, table_iterator);
|
tables_marked_dropped.splice(tables_marked_dropped.end(), tables_marked_dropped, table_iterator);
|
||||||
table_iterator->drop_time = std::chrono::system_clock::to_time_t(std::chrono::system_clock::now()) + drop_error_cooldown_sec;
|
table_iterator->drop_time = std::chrono::system_clock::to_time_t(std::chrono::system_clock::now()) + getContext()->getServerSettings().database_catalog_drop_error_cooldown_sec;
|
||||||
|
|
||||||
if (first_async_drop_in_queue == tables_marked_dropped.end())
|
if (first_async_drop_in_queue == tables_marked_dropped.end())
|
||||||
--first_async_drop_in_queue;
|
--first_async_drop_in_queue;
|
||||||
@ -1340,25 +1329,10 @@ void DatabaseCatalog::dropTablesParallel(std::vector<DatabaseCatalog::TablesMark
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
try
|
runner(std::move(job));
|
||||||
{
|
|
||||||
pool.scheduleOrThrowOnError(std::move(job));
|
|
||||||
}
|
|
||||||
catch (...)
|
|
||||||
{
|
|
||||||
tryLogCurrentException(log, "Cannot drop tables. Will retry later.");
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
try
|
runner.waitForAllToFinishAndRethrowFirstError();
|
||||||
{
|
|
||||||
pool.wait();
|
|
||||||
}
|
|
||||||
catch (...)
|
|
||||||
{
|
|
||||||
tryLogCurrentException(log, "Cannot drop tables. Will retry later.");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void DatabaseCatalog::dropTableDataTask()
|
void DatabaseCatalog::dropTableDataTask()
|
||||||
@ -1375,7 +1349,15 @@ void DatabaseCatalog::dropTableDataTask()
|
|||||||
LOG_INFO(log, "Have {} tables in drop queue ({} of them are in use), will try drop {} tables",
|
LOG_INFO(log, "Have {} tables in drop queue ({} of them are in use), will try drop {} tables",
|
||||||
drop_tables_count, drop_tables_in_use_count, tables_to_drop.size());
|
drop_tables_count, drop_tables_in_use_count, tables_to_drop.size());
|
||||||
|
|
||||||
dropTablesParallel(tables_to_drop);
|
try
|
||||||
|
{
|
||||||
|
dropTablesParallel(tables_to_drop);
|
||||||
|
}
|
||||||
|
catch (...)
|
||||||
|
{
|
||||||
|
/// We don't re-throw exception, because we are in a background pool.
|
||||||
|
tryLogCurrentException(log, "Cannot drop tables. Will retry later.");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
rescheduleDropTableTask();
|
rescheduleDropTableTask();
|
||||||
@ -1718,7 +1700,7 @@ void DatabaseCatalog::cleanupStoreDirectoryTask()
|
|||||||
LOG_TEST(log, "Nothing to clean up from store/ on disk {}", disk_name);
|
LOG_TEST(log, "Nothing to clean up from store/ on disk {}", disk_name);
|
||||||
}
|
}
|
||||||
|
|
||||||
(*cleanup_task)->scheduleAfter(unused_dir_cleanup_period_sec * 1000);
|
(*cleanup_task)->scheduleAfter(static_cast<time_t>(getContext()->getServerSettings().database_catalog_unused_dir_cleanup_period_sec) * 1000);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool DatabaseCatalog::maybeRemoveDirectory(const String & disk_name, const DiskPtr & disk, const String & unused_dir)
|
bool DatabaseCatalog::maybeRemoveDirectory(const String & disk_name, const DiskPtr & disk, const String & unused_dir)
|
||||||
@ -1742,7 +1724,7 @@ bool DatabaseCatalog::maybeRemoveDirectory(const String & disk_name, const DiskP
|
|||||||
time_t current_time = time(nullptr);
|
time_t current_time = time(nullptr);
|
||||||
if (st.st_mode & (S_IRWXU | S_IRWXG | S_IRWXO))
|
if (st.st_mode & (S_IRWXU | S_IRWXG | S_IRWXO))
|
||||||
{
|
{
|
||||||
if (current_time <= max_modification_time + unused_dir_hide_timeout_sec)
|
if (current_time <= max_modification_time + static_cast<time_t>(getContext()->getServerSettings().database_catalog_unused_dir_hide_timeout_sec))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
LOG_INFO(log, "Removing access rights for unused directory {} from disk {} (will remove it when timeout exceed)", unused_dir, disk_name);
|
LOG_INFO(log, "Removing access rights for unused directory {} from disk {} (will remove it when timeout exceed)", unused_dir, disk_name);
|
||||||
@ -1758,6 +1740,8 @@ bool DatabaseCatalog::maybeRemoveDirectory(const String & disk_name, const DiskP
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
auto unused_dir_rm_timeout_sec = static_cast<time_t>(getContext()->getServerSettings().database_catalog_unused_dir_rm_timeout_sec);
|
||||||
|
|
||||||
if (!unused_dir_rm_timeout_sec)
|
if (!unused_dir_rm_timeout_sec)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
@ -354,23 +354,8 @@ private:
|
|||||||
mutable std::mutex tables_marked_dropped_mutex;
|
mutable std::mutex tables_marked_dropped_mutex;
|
||||||
|
|
||||||
std::unique_ptr<BackgroundSchedulePoolTaskHolder> drop_task;
|
std::unique_ptr<BackgroundSchedulePoolTaskHolder> drop_task;
|
||||||
static constexpr time_t default_drop_delay_sec = 8 * 60;
|
|
||||||
time_t drop_delay_sec = default_drop_delay_sec;
|
|
||||||
std::condition_variable wait_table_finally_dropped;
|
std::condition_variable wait_table_finally_dropped;
|
||||||
|
|
||||||
std::unique_ptr<BackgroundSchedulePoolTaskHolder> cleanup_task;
|
std::unique_ptr<BackgroundSchedulePoolTaskHolder> cleanup_task;
|
||||||
static constexpr time_t default_unused_dir_hide_timeout_sec = 60 * 60; /// 1 hour
|
|
||||||
time_t unused_dir_hide_timeout_sec = default_unused_dir_hide_timeout_sec;
|
|
||||||
static constexpr time_t default_unused_dir_rm_timeout_sec = 30 * 24 * 60 * 60; /// 30 days
|
|
||||||
time_t unused_dir_rm_timeout_sec = default_unused_dir_rm_timeout_sec;
|
|
||||||
static constexpr time_t default_unused_dir_cleanup_period_sec = 24 * 60 * 60; /// 1 day
|
|
||||||
time_t unused_dir_cleanup_period_sec = default_unused_dir_cleanup_period_sec;
|
|
||||||
|
|
||||||
static constexpr time_t default_drop_error_cooldown_sec = 5;
|
|
||||||
time_t drop_error_cooldown_sec = default_drop_error_cooldown_sec;
|
|
||||||
|
|
||||||
static constexpr size_t default_drop_table_concurrency = 10;
|
|
||||||
size_t drop_table_concurrency = default_drop_table_concurrency;
|
|
||||||
|
|
||||||
std::unique_ptr<BackgroundSchedulePoolTaskHolder> reload_disks_task;
|
std::unique_ptr<BackgroundSchedulePoolTaskHolder> reload_disks_task;
|
||||||
std::mutex reload_disks_mutex;
|
std::mutex reload_disks_mutex;
|
||||||
|
@ -74,7 +74,7 @@ void ExecuteScalarSubqueriesMatcher::visit(ASTPtr & ast, Data & data)
|
|||||||
static auto getQueryInterpreter(const ASTSubquery & subquery, ExecuteScalarSubqueriesMatcher::Data & data)
|
static auto getQueryInterpreter(const ASTSubquery & subquery, ExecuteScalarSubqueriesMatcher::Data & data)
|
||||||
{
|
{
|
||||||
auto subquery_context = Context::createCopy(data.getContext());
|
auto subquery_context = Context::createCopy(data.getContext());
|
||||||
Settings subquery_settings = data.getContext()->getSettings();
|
Settings subquery_settings = data.getContext()->getSettingsCopy();
|
||||||
subquery_settings.max_result_rows = 1;
|
subquery_settings.max_result_rows = 1;
|
||||||
subquery_settings.extremes = false;
|
subquery_settings.extremes = false;
|
||||||
subquery_context->setSettings(subquery_settings);
|
subquery_context->setSettings(subquery_settings);
|
||||||
|
@ -171,7 +171,7 @@ ExpressionAnalyzer::ExpressionAnalyzer(
|
|||||||
PreparedSetsPtr prepared_sets_,
|
PreparedSetsPtr prepared_sets_,
|
||||||
bool is_create_parameterized_view_)
|
bool is_create_parameterized_view_)
|
||||||
: WithContext(context_)
|
: WithContext(context_)
|
||||||
, query(query_), settings(getContext()->getSettings())
|
, query(query_), settings(getContext()->getSettingsRef())
|
||||||
, subquery_depth(subquery_depth_)
|
, subquery_depth(subquery_depth_)
|
||||||
, syntax(syntax_analyzer_result_)
|
, syntax(syntax_analyzer_result_)
|
||||||
, is_create_parameterized_view(is_create_parameterized_view_)
|
, is_create_parameterized_view(is_create_parameterized_view_)
|
||||||
@ -984,7 +984,7 @@ static std::shared_ptr<IJoin> tryCreateJoin(
|
|||||||
algorithm == JoinAlgorithm::PARALLEL_HASH ||
|
algorithm == JoinAlgorithm::PARALLEL_HASH ||
|
||||||
algorithm == JoinAlgorithm::DEFAULT)
|
algorithm == JoinAlgorithm::DEFAULT)
|
||||||
{
|
{
|
||||||
const auto & settings = context->getSettings();
|
const auto & settings = context->getSettingsRef();
|
||||||
|
|
||||||
if (analyzed_join->allowParallelHashJoin())
|
if (analyzed_join->allowParallelHashJoin())
|
||||||
return std::make_shared<ConcurrentHashJoin>(
|
return std::make_shared<ConcurrentHashJoin>(
|
||||||
|
@ -959,40 +959,12 @@ namespace
|
|||||||
engine_ast->no_empty_args = true;
|
engine_ast->no_empty_args = true;
|
||||||
storage.set(storage.engine, engine_ast);
|
storage.set(storage.engine, engine_ast);
|
||||||
}
|
}
|
||||||
|
|
||||||
void setNullTableEngine(ASTStorage & storage)
|
|
||||||
{
|
|
||||||
auto engine_ast = std::make_shared<ASTFunction>();
|
|
||||||
engine_ast->name = "Null";
|
|
||||||
engine_ast->no_empty_args = true;
|
|
||||||
storage.set(storage.engine, engine_ast);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void InterpreterCreateQuery::setEngine(ASTCreateQuery & create) const
|
void InterpreterCreateQuery::setEngine(ASTCreateQuery & create) const
|
||||||
{
|
{
|
||||||
if (create.as_table_function)
|
if (create.as_table_function)
|
||||||
{
|
|
||||||
if (getContext()->getSettingsRef().restore_replace_external_table_functions_to_null)
|
|
||||||
{
|
|
||||||
const auto & factory = TableFunctionFactory::instance();
|
|
||||||
|
|
||||||
auto properties = factory.tryGetProperties(create.as_table_function->as<ASTFunction>()->name);
|
|
||||||
if (properties && properties->allow_readonly)
|
|
||||||
return;
|
|
||||||
if (!create.storage)
|
|
||||||
{
|
|
||||||
auto storage_ast = std::make_shared<ASTStorage>();
|
|
||||||
create.set(create.storage, storage_ast);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
throw Exception(ErrorCodes::LOGICAL_ERROR, "Storage should not be created yet, it's a bug.");
|
|
||||||
create.as_table_function = nullptr;
|
|
||||||
setNullTableEngine(*create.storage);
|
|
||||||
}
|
|
||||||
return;
|
return;
|
||||||
}
|
|
||||||
|
|
||||||
if (create.is_dictionary || create.is_ordinary_view || create.is_live_view || create.is_window_view)
|
if (create.is_dictionary || create.is_ordinary_view || create.is_live_view || create.is_window_view)
|
||||||
return;
|
return;
|
||||||
@ -1043,13 +1015,6 @@ void InterpreterCreateQuery::setEngine(ASTCreateQuery & create) const
|
|||||||
/// Some part of storage definition (such as PARTITION BY) is specified, but ENGINE is not: just set default one.
|
/// Some part of storage definition (such as PARTITION BY) is specified, but ENGINE is not: just set default one.
|
||||||
setDefaultTableEngine(*create.storage, getContext()->getSettingsRef().default_table_engine.value);
|
setDefaultTableEngine(*create.storage, getContext()->getSettingsRef().default_table_engine.value);
|
||||||
}
|
}
|
||||||
/// For external tables with restore_replace_external_engine_to_null setting we replace external engines to
|
|
||||||
/// Null table engine.
|
|
||||||
else if (getContext()->getSettingsRef().restore_replace_external_engines_to_null)
|
|
||||||
{
|
|
||||||
if (StorageFactory::instance().getStorageFeatures(create.storage->engine->name).source_access_type != AccessType::NONE)
|
|
||||||
setNullTableEngine(*create.storage);
|
|
||||||
}
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -6,6 +6,7 @@
|
|||||||
#include <Interpreters/InterpreterDropQuery.h>
|
#include <Interpreters/InterpreterDropQuery.h>
|
||||||
#include <Interpreters/ExternalDictionariesLoader.h>
|
#include <Interpreters/ExternalDictionariesLoader.h>
|
||||||
#include <Interpreters/QueryLog.h>
|
#include <Interpreters/QueryLog.h>
|
||||||
|
#include <IO/SharedThreadPools.h>
|
||||||
#include <Access/Common/AccessRightsElement.h>
|
#include <Access/Common/AccessRightsElement.h>
|
||||||
#include <Parsers/ASTDropQuery.h>
|
#include <Parsers/ASTDropQuery.h>
|
||||||
#include <Parsers/ASTIdentifier.h>
|
#include <Parsers/ASTIdentifier.h>
|
||||||
@ -424,18 +425,29 @@ BlockIO InterpreterDropQuery::executeToDatabaseImpl(const ASTDropQuery & query,
|
|||||||
auto table_context = Context::createCopy(getContext());
|
auto table_context = Context::createCopy(getContext());
|
||||||
table_context->setInternalQuery(true);
|
table_context->setInternalQuery(true);
|
||||||
/// Do not hold extra shared pointers to tables
|
/// Do not hold extra shared pointers to tables
|
||||||
std::vector<std::pair<String, bool>> tables_to_drop;
|
std::vector<std::pair<StorageID, bool>> tables_to_drop;
|
||||||
// NOTE: This means we wait for all tables to be loaded inside getTablesIterator() call in case of `async_load_databases = true`.
|
// NOTE: This means we wait for all tables to be loaded inside getTablesIterator() call in case of `async_load_databases = true`.
|
||||||
for (auto iterator = database->getTablesIterator(table_context); iterator->isValid(); iterator->next())
|
for (auto iterator = database->getTablesIterator(table_context); iterator->isValid(); iterator->next())
|
||||||
{
|
{
|
||||||
auto table_ptr = iterator->table();
|
auto table_ptr = iterator->table();
|
||||||
table_ptr->flushAndPrepareForShutdown();
|
tables_to_drop.push_back({table_ptr->getStorageID(), table_ptr->isDictionary()});
|
||||||
tables_to_drop.push_back({iterator->name(), table_ptr->isDictionary()});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Prepare tables for shutdown in parallel.
|
||||||
|
ThreadPoolCallbackRunnerLocal<void> runner(getDatabaseCatalogDropTablesThreadPool().get(), "DropTables");
|
||||||
|
for (const auto & [name, _] : tables_to_drop)
|
||||||
|
{
|
||||||
|
auto table_ptr = DatabaseCatalog::instance().getTable(name, table_context);
|
||||||
|
runner([my_table_ptr = std::move(table_ptr)]()
|
||||||
|
{
|
||||||
|
my_table_ptr->flushAndPrepareForShutdown();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
runner.waitForAllToFinishAndRethrowFirstError();
|
||||||
|
|
||||||
for (const auto & table : tables_to_drop)
|
for (const auto & table : tables_to_drop)
|
||||||
{
|
{
|
||||||
query_for_table.setTable(table.first);
|
query_for_table.setTable(table.first.getTableName());
|
||||||
query_for_table.is_dictionary = table.second;
|
query_for_table.is_dictionary = table.second;
|
||||||
DatabasePtr db;
|
DatabasePtr db;
|
||||||
UUID table_to_wait = UUIDHelpers::Nil;
|
UUID table_to_wait = UUIDHelpers::Nil;
|
||||||
|
@ -464,7 +464,7 @@ QueryPipeline InterpreterInsertQuery::buildInsertSelectPipeline(ASTInsertQuery &
|
|||||||
* to avoid unnecessary squashing.
|
* to avoid unnecessary squashing.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
Settings new_settings = select_context->getSettings();
|
Settings new_settings = select_context->getSettingsCopy();
|
||||||
|
|
||||||
new_settings.max_threads = std::max<UInt64>(1, settings.max_insert_threads);
|
new_settings.max_threads = std::max<UInt64>(1, settings.max_insert_threads);
|
||||||
|
|
||||||
|
@ -249,7 +249,7 @@ namespace
|
|||||||
ContextPtr getSubqueryContext(const ContextPtr & context)
|
ContextPtr getSubqueryContext(const ContextPtr & context)
|
||||||
{
|
{
|
||||||
auto subquery_context = Context::createCopy(context);
|
auto subquery_context = Context::createCopy(context);
|
||||||
Settings subquery_settings = context->getSettings();
|
Settings subquery_settings = context->getSettingsCopy();
|
||||||
subquery_settings.max_result_rows = 0;
|
subquery_settings.max_result_rows = 0;
|
||||||
subquery_settings.max_result_bytes = 0;
|
subquery_settings.max_result_bytes = 0;
|
||||||
/// The calculation of extremes does not make sense and is not necessary (if you do it, then the extremes of the subquery can be taken for whole query).
|
/// The calculation of extremes does not make sense and is not necessary (if you do it, then the extremes of the subquery can be taken for whole query).
|
||||||
|
@ -308,7 +308,7 @@ std::shared_ptr<TableJoin> JoinedTables::makeTableJoin(const ASTSelectQuery & se
|
|||||||
if (tables_with_columns.size() < 2)
|
if (tables_with_columns.size() < 2)
|
||||||
return {};
|
return {};
|
||||||
|
|
||||||
auto settings = context->getSettingsRef();
|
const auto & settings = context->getSettingsRef();
|
||||||
MultiEnum<JoinAlgorithm> join_algorithm = settings.join_algorithm;
|
MultiEnum<JoinAlgorithm> join_algorithm = settings.join_algorithm;
|
||||||
bool try_use_direct_join = join_algorithm.isSet(JoinAlgorithm::DIRECT) || join_algorithm.isSet(JoinAlgorithm::DEFAULT);
|
bool try_use_direct_join = join_algorithm.isSet(JoinAlgorithm::DIRECT) || join_algorithm.isSet(JoinAlgorithm::DEFAULT);
|
||||||
auto table_join = std::make_shared<TableJoin>(settings, context->getGlobalTemporaryVolume(), context->getTempDataOnDisk());
|
auto table_join = std::make_shared<TableJoin>(settings, context->getGlobalTemporaryVolume(), context->getTempDataOnDisk());
|
||||||
|
@ -657,7 +657,7 @@ QueryStatusInfo QueryStatus::getInfo(bool get_thread_list, bool get_profile_even
|
|||||||
{
|
{
|
||||||
if (auto ctx = context.lock())
|
if (auto ctx = context.lock())
|
||||||
{
|
{
|
||||||
res.query_settings = std::make_shared<Settings>(ctx->getSettings());
|
res.query_settings = std::make_shared<Settings>(ctx->getSettingsRef());
|
||||||
res.current_database = ctx->getCurrentDatabase();
|
res.current_database = ctx->getCurrentDatabase();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -62,7 +62,7 @@ std::shared_ptr<InterpreterSelectWithUnionQuery> interpretSubquery(
|
|||||||
* which are checked separately (in the Set, Join objects).
|
* which are checked separately (in the Set, Join objects).
|
||||||
*/
|
*/
|
||||||
auto subquery_context = Context::createCopy(context);
|
auto subquery_context = Context::createCopy(context);
|
||||||
Settings subquery_settings = context->getSettings();
|
Settings subquery_settings = context->getSettingsCopy();
|
||||||
subquery_settings.max_result_rows = 0;
|
subquery_settings.max_result_rows = 0;
|
||||||
subquery_settings.max_result_bytes = 0;
|
subquery_settings.max_result_bytes = 0;
|
||||||
/// The calculation of `extremes` does not make sense and is not necessary (if you do it, then the `extremes` of the subquery can be taken instead of the whole query).
|
/// The calculation of `extremes` does not make sense and is not necessary (if you do it, then the `extremes` of the subquery can be taken instead of the whole query).
|
||||||
|
@ -286,6 +286,8 @@ static bool formatNamedArgWithHiddenValue(IAST * arg, const IAST::FormatSettings
|
|||||||
void ASTFunction::formatImplWithoutAlias(const FormatSettings & settings, FormatState & state, FormatStateStacked frame) const
|
void ASTFunction::formatImplWithoutAlias(const FormatSettings & settings, FormatState & state, FormatStateStacked frame) const
|
||||||
{
|
{
|
||||||
frame.expression_list_prepend_whitespace = false;
|
frame.expression_list_prepend_whitespace = false;
|
||||||
|
if (kind == Kind::CODEC || kind == Kind::STATISTICS || kind == Kind::BACKUP_NAME)
|
||||||
|
frame.allow_operators = false;
|
||||||
FormatStateStacked nested_need_parens = frame;
|
FormatStateStacked nested_need_parens = frame;
|
||||||
FormatStateStacked nested_dont_need_parens = frame;
|
FormatStateStacked nested_dont_need_parens = frame;
|
||||||
nested_need_parens.need_parens = true;
|
nested_need_parens.need_parens = true;
|
||||||
@ -309,7 +311,7 @@ void ASTFunction::formatImplWithoutAlias(const FormatSettings & settings, Format
|
|||||||
|
|
||||||
/// Should this function to be written as operator?
|
/// Should this function to be written as operator?
|
||||||
bool written = false;
|
bool written = false;
|
||||||
if (arguments && !parameters && nulls_action == NullsAction::EMPTY)
|
if (arguments && !parameters && frame.allow_operators && nulls_action == NullsAction::EMPTY)
|
||||||
{
|
{
|
||||||
/// Unary prefix operators.
|
/// Unary prefix operators.
|
||||||
if (arguments->children.size() == 1)
|
if (arguments->children.size() == 1)
|
||||||
|
@ -58,6 +58,8 @@ public:
|
|||||||
TABLE_ENGINE,
|
TABLE_ENGINE,
|
||||||
DATABASE_ENGINE,
|
DATABASE_ENGINE,
|
||||||
BACKUP_NAME,
|
BACKUP_NAME,
|
||||||
|
CODEC,
|
||||||
|
STATISTICS,
|
||||||
};
|
};
|
||||||
Kind kind = Kind::ORDINARY_FUNCTION;
|
Kind kind = Kind::ORDINARY_FUNCTION;
|
||||||
|
|
||||||
|
@ -696,6 +696,7 @@ bool ParserCodec::parseImpl(Pos & pos, ASTPtr & node, Expected & expected)
|
|||||||
|
|
||||||
auto function_node = std::make_shared<ASTFunction>();
|
auto function_node = std::make_shared<ASTFunction>();
|
||||||
function_node->name = "CODEC";
|
function_node->name = "CODEC";
|
||||||
|
function_node->kind = ASTFunction::Kind::CODEC;
|
||||||
function_node->arguments = expr_list_args;
|
function_node->arguments = expr_list_args;
|
||||||
function_node->children.push_back(function_node->arguments);
|
function_node->children.push_back(function_node->arguments);
|
||||||
|
|
||||||
@ -723,6 +724,7 @@ bool ParserStatisticsType::parseImpl(Pos & pos, ASTPtr & node, Expected & expect
|
|||||||
|
|
||||||
auto function_node = std::make_shared<ASTFunction>();
|
auto function_node = std::make_shared<ASTFunction>();
|
||||||
function_node->name = "STATISTICS";
|
function_node->name = "STATISTICS";
|
||||||
|
function_node->kind = ASTFunction::Kind::STATISTICS;
|
||||||
function_node->arguments = stat_type;
|
function_node->arguments = stat_type;
|
||||||
function_node->children.push_back(function_node->arguments);
|
function_node->children.push_back(function_node->arguments);
|
||||||
node = function_node;
|
node = function_node;
|
||||||
|
@ -33,7 +33,9 @@ public:
|
|||||||
{
|
{
|
||||||
case ASTFunction::Kind::ORDINARY_FUNCTION: findOrdinaryFunctionSecretArguments(); break;
|
case ASTFunction::Kind::ORDINARY_FUNCTION: findOrdinaryFunctionSecretArguments(); break;
|
||||||
case ASTFunction::Kind::WINDOW_FUNCTION: break;
|
case ASTFunction::Kind::WINDOW_FUNCTION: break;
|
||||||
case ASTFunction::Kind::LAMBDA_FUNCTION: break;
|
case ASTFunction::Kind::LAMBDA_FUNCTION: break;
|
||||||
|
case ASTFunction::Kind::CODEC: break;
|
||||||
|
case ASTFunction::Kind::STATISTICS: break;
|
||||||
case ASTFunction::Kind::TABLE_ENGINE: findTableEngineSecretArguments(); break;
|
case ASTFunction::Kind::TABLE_ENGINE: findTableEngineSecretArguments(); break;
|
||||||
case ASTFunction::Kind::DATABASE_ENGINE: findDatabaseEngineSecretArguments(); break;
|
case ASTFunction::Kind::DATABASE_ENGINE: findDatabaseEngineSecretArguments(); break;
|
||||||
case ASTFunction::Kind::BACKUP_NAME: findBackupNameSecretArguments(); break;
|
case ASTFunction::Kind::BACKUP_NAME: findBackupNameSecretArguments(); break;
|
||||||
|
@ -256,6 +256,7 @@ public:
|
|||||||
bool expression_list_always_start_on_new_line = false; /// Line feed and indent before expression list even if it's of single element.
|
bool expression_list_always_start_on_new_line = false; /// Line feed and indent before expression list even if it's of single element.
|
||||||
bool expression_list_prepend_whitespace = false; /// Prepend whitespace (if it is required)
|
bool expression_list_prepend_whitespace = false; /// Prepend whitespace (if it is required)
|
||||||
bool surround_each_list_element_with_parens = false;
|
bool surround_each_list_element_with_parens = false;
|
||||||
|
bool allow_operators = true; /// Format some functions, such as "plus", "in", etc. as operators.
|
||||||
size_t list_element_index = 0;
|
size_t list_element_index = 0;
|
||||||
const IAST * current_select = nullptr;
|
const IAST * current_select = nullptr;
|
||||||
};
|
};
|
||||||
|
@ -204,6 +204,8 @@ void ExecutorTasks::processAsyncTasks()
|
|||||||
while (auto task = async_task_queue.wait(lock))
|
while (auto task = async_task_queue.wait(lock))
|
||||||
{
|
{
|
||||||
auto * node = static_cast<ExecutingGraph::Node *>(task.data);
|
auto * node = static_cast<ExecutingGraph::Node *>(task.data);
|
||||||
|
node->processor->onAsyncJobReady();
|
||||||
|
|
||||||
executor_contexts[task.thread_num]->pushAsyncTask(node);
|
executor_contexts[task.thread_num]->pushAsyncTask(node);
|
||||||
++num_waiting_async_tasks;
|
++num_waiting_async_tasks;
|
||||||
|
|
||||||
|
@ -28,7 +28,7 @@ class ExecutorTasks
|
|||||||
TaskQueue<ExecutingGraph::Node> task_queue;
|
TaskQueue<ExecutingGraph::Node> task_queue;
|
||||||
|
|
||||||
/// Queue which stores tasks where processors returned Async status after prepare.
|
/// Queue which stores tasks where processors returned Async status after prepare.
|
||||||
/// If multiple threads are using, main thread will wait for async tasks.
|
/// If multiple threads are used, main thread will wait for async tasks.
|
||||||
/// For single thread, will wait for async tasks only when task_queue is empty.
|
/// For single thread, will wait for async tasks only when task_queue is empty.
|
||||||
PollingQueue async_task_queue;
|
PollingQueue async_task_queue;
|
||||||
|
|
||||||
|
@ -9,7 +9,6 @@
|
|||||||
|
|
||||||
#include <deque>
|
#include <deque>
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include <mutex>
|
|
||||||
#include <memory>
|
#include <memory>
|
||||||
|
|
||||||
|
|
||||||
|
@ -15,11 +15,8 @@ namespace ErrorCodes
|
|||||||
extern const int ILLEGAL_COLUMN;
|
extern const int ILLEGAL_COLUMN;
|
||||||
}
|
}
|
||||||
|
|
||||||
JSONAsRowInputFormat::JSONAsRowInputFormat(const Block & header_, ReadBuffer & in_, Params params_, const FormatSettings & format_settings_)
|
JSONAsRowInputFormat::JSONAsRowInputFormat(const Block & header_, ReadBuffer & in_, Params params_, const FormatSettings & format_settings_) :
|
||||||
: JSONAsRowInputFormat(header_, std::make_unique<PeekableReadBuffer>(in_), params_, format_settings_) {}
|
JSONEachRowRowInputFormat(in_, header_, std::move(params_), format_settings_, false)
|
||||||
|
|
||||||
JSONAsRowInputFormat::JSONAsRowInputFormat(const Block & header_, std::unique_ptr<PeekableReadBuffer> buf_, Params params_, const FormatSettings & format_settings_) :
|
|
||||||
JSONEachRowRowInputFormat(*buf_, header_, std::move(params_), format_settings_, false), buf(std::move(buf_))
|
|
||||||
{
|
{
|
||||||
if (header_.columns() > 1)
|
if (header_.columns() > 1)
|
||||||
throw Exception(ErrorCodes::BAD_ARGUMENTS,
|
throw Exception(ErrorCodes::BAD_ARGUMENTS,
|
||||||
@ -27,19 +24,6 @@ JSONAsRowInputFormat::JSONAsRowInputFormat(const Block & header_, std::unique_pt
|
|||||||
header_.columns());
|
header_.columns());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void JSONAsRowInputFormat::setReadBuffer(ReadBuffer & in_)
|
|
||||||
{
|
|
||||||
buf = std::make_unique<PeekableReadBuffer>(in_);
|
|
||||||
JSONEachRowRowInputFormat::setReadBuffer(*buf);
|
|
||||||
}
|
|
||||||
|
|
||||||
void JSONAsRowInputFormat::resetReadBuffer()
|
|
||||||
{
|
|
||||||
buf.reset();
|
|
||||||
JSONEachRowRowInputFormat::resetReadBuffer();
|
|
||||||
}
|
|
||||||
|
|
||||||
bool JSONAsRowInputFormat::readRow(MutableColumns & columns, RowReadExtension &)
|
bool JSONAsRowInputFormat::readRow(MutableColumns & columns, RowReadExtension &)
|
||||||
{
|
{
|
||||||
assert(columns.size() == 1);
|
assert(columns.size() == 1);
|
||||||
@ -48,35 +32,41 @@ bool JSONAsRowInputFormat::readRow(MutableColumns & columns, RowReadExtension &)
|
|||||||
if (!allow_new_rows)
|
if (!allow_new_rows)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
skipWhitespaceIfAny(*buf);
|
skipWhitespaceIfAny(*in);
|
||||||
if (!buf->eof())
|
if (!in->eof())
|
||||||
{
|
{
|
||||||
if (!data_in_square_brackets && *buf->position() == ';')
|
if (!data_in_square_brackets && *in->position() == ';')
|
||||||
{
|
{
|
||||||
/// ';' means the end of query, but it cannot be before ']'.
|
/// ';' means the end of query, but it cannot be before ']'.
|
||||||
return allow_new_rows = false;
|
return allow_new_rows = false;
|
||||||
}
|
}
|
||||||
else if (data_in_square_brackets && *buf->position() == ']')
|
else if (data_in_square_brackets && *in->position() == ']')
|
||||||
{
|
{
|
||||||
/// ']' means the end of query.
|
/// ']' means the end of query.
|
||||||
return allow_new_rows = false;
|
return allow_new_rows = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!buf->eof())
|
if (!in->eof())
|
||||||
readJSONObject(*columns[0]);
|
readJSONObject(*columns[0]);
|
||||||
|
|
||||||
skipWhitespaceIfAny(*buf);
|
skipWhitespaceIfAny(*in);
|
||||||
if (!buf->eof() && *buf->position() == ',')
|
if (!in->eof() && *in->position() == ',')
|
||||||
++buf->position();
|
++in->position();
|
||||||
skipWhitespaceIfAny(*buf);
|
skipWhitespaceIfAny(*in);
|
||||||
|
|
||||||
return !buf->eof();
|
return !in->eof();
|
||||||
}
|
}
|
||||||
|
|
||||||
JSONAsStringRowInputFormat::JSONAsStringRowInputFormat(
|
JSONAsStringRowInputFormat::JSONAsStringRowInputFormat(
|
||||||
const Block & header_, ReadBuffer & in_, Params params_, const FormatSettings & format_settings_)
|
const Block & header_, ReadBuffer & in_, IRowInputFormat::Params params_, const FormatSettings & format_settings_)
|
||||||
: JSONAsRowInputFormat(header_, in_, params_, format_settings_)
|
: JSONAsStringRowInputFormat(header_, std::make_unique<PeekableReadBuffer>(in_), params_, format_settings_)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
JSONAsStringRowInputFormat::JSONAsStringRowInputFormat(
|
||||||
|
const Block & header_, std::unique_ptr<PeekableReadBuffer> buf_, Params params_, const FormatSettings & format_settings_)
|
||||||
|
: JSONAsRowInputFormat(header_, *buf_, params_, format_settings_), buf(std::move(buf_))
|
||||||
{
|
{
|
||||||
if (!isString(removeNullable(removeLowCardinality(header_.getByPosition(0).type))))
|
if (!isString(removeNullable(removeLowCardinality(header_.getByPosition(0).type))))
|
||||||
throw Exception(ErrorCodes::BAD_ARGUMENTS,
|
throw Exception(ErrorCodes::BAD_ARGUMENTS,
|
||||||
@ -84,6 +74,18 @@ JSONAsStringRowInputFormat::JSONAsStringRowInputFormat(
|
|||||||
header_.getByPosition(0).type->getName());
|
header_.getByPosition(0).type->getName());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void JSONAsStringRowInputFormat::setReadBuffer(ReadBuffer & in_)
|
||||||
|
{
|
||||||
|
buf = std::make_unique<PeekableReadBuffer>(in_);
|
||||||
|
JSONAsRowInputFormat::setReadBuffer(*buf);
|
||||||
|
}
|
||||||
|
|
||||||
|
void JSONAsStringRowInputFormat::resetReadBuffer()
|
||||||
|
{
|
||||||
|
buf.reset();
|
||||||
|
JSONAsRowInputFormat::resetReadBuffer();
|
||||||
|
}
|
||||||
|
|
||||||
void JSONAsStringRowInputFormat::readJSONObject(IColumn & column)
|
void JSONAsStringRowInputFormat::readJSONObject(IColumn & column)
|
||||||
{
|
{
|
||||||
PeekableReadBufferCheckpoint checkpoint{*buf};
|
PeekableReadBufferCheckpoint checkpoint{*buf};
|
||||||
@ -174,7 +176,7 @@ JSONAsObjectRowInputFormat::JSONAsObjectRowInputFormat(
|
|||||||
|
|
||||||
void JSONAsObjectRowInputFormat::readJSONObject(IColumn & column)
|
void JSONAsObjectRowInputFormat::readJSONObject(IColumn & column)
|
||||||
{
|
{
|
||||||
serializations[0]->deserializeTextJSON(column, *buf, format_settings);
|
serializations[0]->deserializeTextJSON(column, *in, format_settings);
|
||||||
}
|
}
|
||||||
|
|
||||||
Chunk JSONAsObjectRowInputFormat::getChunkForCount(size_t rows)
|
Chunk JSONAsObjectRowInputFormat::getChunkForCount(size_t rows)
|
||||||
|
@ -18,17 +18,11 @@ class JSONAsRowInputFormat : public JSONEachRowRowInputFormat
|
|||||||
public:
|
public:
|
||||||
JSONAsRowInputFormat(const Block & header_, ReadBuffer & in_, Params params_, const FormatSettings & format_settings);
|
JSONAsRowInputFormat(const Block & header_, ReadBuffer & in_, Params params_, const FormatSettings & format_settings);
|
||||||
|
|
||||||
void setReadBuffer(ReadBuffer & in_) override;
|
|
||||||
void resetReadBuffer() override;
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
JSONAsRowInputFormat(const Block & header_, std::unique_ptr<PeekableReadBuffer> buf_, Params params_, const FormatSettings & format_settings);
|
|
||||||
|
|
||||||
bool readRow(MutableColumns & columns, RowReadExtension & ext) override;
|
bool readRow(MutableColumns & columns, RowReadExtension & ext) override;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual void readJSONObject(IColumn & column) = 0;
|
virtual void readJSONObject(IColumn & column) = 0;
|
||||||
std::unique_ptr<PeekableReadBuffer> buf;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
/// Each JSON object is parsed as a whole to string.
|
/// Each JSON object is parsed as a whole to string.
|
||||||
@ -36,11 +30,18 @@ protected:
|
|||||||
class JSONAsStringRowInputFormat final : public JSONAsRowInputFormat
|
class JSONAsStringRowInputFormat final : public JSONAsRowInputFormat
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
JSONAsStringRowInputFormat(const Block & header_, ReadBuffer & in_, Params params_, const FormatSettings & format_settings);
|
JSONAsStringRowInputFormat(const Block & header_, ReadBuffer & in_, Params params_, const FormatSettings & format_settings_);
|
||||||
String getName() const override { return "JSONAsStringRowInputFormat"; }
|
String getName() const override { return "JSONAsStringRowInputFormat"; }
|
||||||
|
|
||||||
|
void setReadBuffer(ReadBuffer & in_) override;
|
||||||
|
void resetReadBuffer() override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
JSONAsStringRowInputFormat(const Block & header_, std::unique_ptr<PeekableReadBuffer> buf_, Params params_, const FormatSettings & format_settings_);
|
||||||
|
|
||||||
void readJSONObject(IColumn & column) override;
|
void readJSONObject(IColumn & column) override;
|
||||||
|
|
||||||
|
std::unique_ptr<PeekableReadBuffer> buf;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -406,7 +406,7 @@ bool ValuesBlockInputFormat::parseExpression(IColumn & column, size_t column_idx
|
|||||||
{
|
{
|
||||||
const Block & header = getPort().getHeader();
|
const Block & header = getPort().getHeader();
|
||||||
const IDataType & type = *header.getByPosition(column_idx).type;
|
const IDataType & type = *header.getByPosition(column_idx).type;
|
||||||
auto settings = context->getSettingsRef();
|
const auto & settings = context->getSettingsRef();
|
||||||
|
|
||||||
/// Advance the token iterator until the start of the column expression
|
/// Advance the token iterator until the start of the column expression
|
||||||
readUntilTheEndOfRowAndReTokenize(column_idx);
|
readUntilTheEndOfRowAndReTokenize(column_idx);
|
||||||
|
@ -221,6 +221,23 @@ public:
|
|||||||
throw Exception(ErrorCodes::NOT_IMPLEMENTED, "Method 'schedule' is not implemented for {} processor", getName());
|
throw Exception(ErrorCodes::NOT_IMPLEMENTED, "Method 'schedule' is not implemented for {} processor", getName());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* The method is called right after asynchronous job is done
|
||||||
|
* i.e. when file descriptor returned by schedule() is readable.
|
||||||
|
* The sequence of method calls:
|
||||||
|
* ... prepare() -> schedule() -> onAsyncJobReady() -> work() ...
|
||||||
|
* See also comment to schedule() method
|
||||||
|
*
|
||||||
|
* It allows doing some preprocessing immediately after asynchronous job is done.
|
||||||
|
* The implementation should return control quickly, to avoid blocking another asynchronous completed jobs
|
||||||
|
* created by the same pipeline.
|
||||||
|
*
|
||||||
|
* Example, scheduling tasks for remote workers (file descriptor in this case is a socket)
|
||||||
|
* When the remote worker asks for the next task, doing it in onAsyncJobReady() we can provide it immediately.
|
||||||
|
* Otherwise, the returning of the next task for the remote worker can be delayed by current work done in the pipeline
|
||||||
|
* (by other processors), which will create unnecessary latency in query processing by remote workers
|
||||||
|
*/
|
||||||
|
virtual void onAsyncJobReady() {}
|
||||||
|
|
||||||
/** You must call this method if 'prepare' returned ExpandPipeline.
|
/** You must call this method if 'prepare' returned ExpandPipeline.
|
||||||
* This method cannot access any port, but it can create new ports for current processor.
|
* This method cannot access any port, but it can create new ports for current processor.
|
||||||
*
|
*
|
||||||
|
@ -134,7 +134,6 @@ AggregatingStep::AggregatingStep(
|
|||||||
{
|
{
|
||||||
output_stream->sort_description = group_by_sort_description;
|
output_stream->sort_description = group_by_sort_description;
|
||||||
output_stream->sort_scope = DataStream::SortScope::Global;
|
output_stream->sort_scope = DataStream::SortScope::Global;
|
||||||
output_stream->has_single_port = true;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -147,7 +146,6 @@ void AggregatingStep::applyOrder(SortDescription sort_description_for_merging_,
|
|||||||
{
|
{
|
||||||
output_stream->sort_description = group_by_sort_description;
|
output_stream->sort_description = group_by_sort_description;
|
||||||
output_stream->sort_scope = DataStream::SortScope::Global;
|
output_stream->sort_scope = DataStream::SortScope::Global;
|
||||||
output_stream->has_single_port = true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
explicit_sorting_required_for_aggregation_in_order = false;
|
explicit_sorting_required_for_aggregation_in_order = false;
|
||||||
|
@ -10,6 +10,11 @@
|
|||||||
namespace DB
|
namespace DB
|
||||||
{
|
{
|
||||||
|
|
||||||
|
namespace ErrorCodes
|
||||||
|
{
|
||||||
|
extern const int LOGICAL_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
static ITransformingStep::Traits getTraits(bool pre_distinct)
|
static ITransformingStep::Traits getTraits(bool pre_distinct)
|
||||||
{
|
{
|
||||||
const bool preserves_number_of_streams = pre_distinct;
|
const bool preserves_number_of_streams = pre_distinct;
|
||||||
@ -90,7 +95,8 @@ void DistinctStep::transformPipeline(QueryPipelineBuilder & pipeline, const Buil
|
|||||||
/// final distinct for sorted stream (sorting inside and among chunks)
|
/// final distinct for sorted stream (sorting inside and among chunks)
|
||||||
if (input_stream.sort_scope == DataStream::SortScope::Global)
|
if (input_stream.sort_scope == DataStream::SortScope::Global)
|
||||||
{
|
{
|
||||||
assert(input_stream.has_single_port);
|
if (pipeline.getNumStreams() != 1)
|
||||||
|
throw Exception(ErrorCodes::LOGICAL_ERROR, "DistinctStep with in-order expects single input");
|
||||||
|
|
||||||
if (distinct_sort_desc.size() < columns.size())
|
if (distinct_sort_desc.size() < columns.size())
|
||||||
{
|
{
|
||||||
|
@ -39,12 +39,13 @@ FillingStep::FillingStep(
|
|||||||
, interpolate_description(interpolate_description_)
|
, interpolate_description(interpolate_description_)
|
||||||
, use_with_fill_by_sorting_prefix(use_with_fill_by_sorting_prefix_)
|
, use_with_fill_by_sorting_prefix(use_with_fill_by_sorting_prefix_)
|
||||||
{
|
{
|
||||||
if (!input_stream_.has_single_port)
|
|
||||||
throw Exception(ErrorCodes::LOGICAL_ERROR, "FillingStep expects single input");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void FillingStep::transformPipeline(QueryPipelineBuilder & pipeline, const BuildQueryPipelineSettings &)
|
void FillingStep::transformPipeline(QueryPipelineBuilder & pipeline, const BuildQueryPipelineSettings &)
|
||||||
{
|
{
|
||||||
|
if (pipeline.getNumStreams() != 1)
|
||||||
|
throw Exception(ErrorCodes::LOGICAL_ERROR, "FillingStep expects single input");
|
||||||
|
|
||||||
pipeline.addSimpleTransform([&](const Block & header, QueryPipelineBuilder::StreamType stream_type) -> ProcessorPtr
|
pipeline.addSimpleTransform([&](const Block & header, QueryPipelineBuilder::StreamType stream_type) -> ProcessorPtr
|
||||||
{
|
{
|
||||||
if (stream_type == QueryPipelineBuilder::StreamType::Totals)
|
if (stream_type == QueryPipelineBuilder::StreamType::Totals)
|
||||||
@ -69,9 +70,6 @@ void FillingStep::describeActions(JSONBuilder::JSONMap & map) const
|
|||||||
|
|
||||||
void FillingStep::updateOutputStream()
|
void FillingStep::updateOutputStream()
|
||||||
{
|
{
|
||||||
if (!input_streams.front().has_single_port)
|
|
||||||
throw Exception(ErrorCodes::LOGICAL_ERROR, "FillingStep expects single input");
|
|
||||||
|
|
||||||
output_stream = createOutputStream(
|
output_stream = createOutputStream(
|
||||||
input_streams.front(), FillingTransform::transformHeader(input_streams.front().header, sort_description), getDataStreamTraits());
|
input_streams.front(), FillingTransform::transformHeader(input_streams.front().header, sort_description), getDataStreamTraits());
|
||||||
}
|
}
|
||||||
|
@ -28,9 +28,6 @@ class DataStream
|
|||||||
public:
|
public:
|
||||||
Block header;
|
Block header;
|
||||||
|
|
||||||
/// QueryPipeline has single port. Totals or extremes ports are not counted.
|
|
||||||
bool has_single_port = false;
|
|
||||||
|
|
||||||
/// Sorting scope. Please keep the mutual order (more strong mode should have greater value).
|
/// Sorting scope. Please keep the mutual order (more strong mode should have greater value).
|
||||||
enum class SortScope : uint8_t
|
enum class SortScope : uint8_t
|
||||||
{
|
{
|
||||||
@ -51,8 +48,7 @@ public:
|
|||||||
|
|
||||||
bool hasEqualPropertiesWith(const DataStream & other) const
|
bool hasEqualPropertiesWith(const DataStream & other) const
|
||||||
{
|
{
|
||||||
return has_single_port == other.has_single_port
|
return sort_description == other.sort_description
|
||||||
&& sort_description == other.sort_description
|
|
||||||
&& (sort_description.empty() || sort_scope == other.sort_scope);
|
&& (sort_description.empty() || sort_scope == other.sort_scope);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -20,9 +20,6 @@ DataStream ITransformingStep::createOutputStream(
|
|||||||
{
|
{
|
||||||
DataStream output_stream{.header = std::move(output_header)};
|
DataStream output_stream{.header = std::move(output_header)};
|
||||||
|
|
||||||
output_stream.has_single_port = stream_traits.returns_single_stream
|
|
||||||
|| (input_stream.has_single_port && stream_traits.preserves_number_of_streams);
|
|
||||||
|
|
||||||
if (stream_traits.preserves_sorting)
|
if (stream_traits.preserves_sorting)
|
||||||
{
|
{
|
||||||
output_stream.sort_description = input_stream.sort_description;
|
output_stream.sort_description = input_stream.sort_description;
|
||||||
|
@ -1055,7 +1055,7 @@ size_t tryReuseStorageOrderingForWindowFunctions(QueryPlan::Node * parent_node,
|
|||||||
}
|
}
|
||||||
|
|
||||||
auto context = read_from_merge_tree->getContext();
|
auto context = read_from_merge_tree->getContext();
|
||||||
const auto & settings = context->getSettings();
|
const auto & settings = context->getSettingsRef();
|
||||||
if (!settings.optimize_read_in_window_order || (settings.optimize_read_in_order && settings.query_plan_read_in_order) || context->getSettingsRef().allow_experimental_analyzer)
|
if (!settings.optimize_read_in_window_order || (settings.optimize_read_in_order && settings.query_plan_read_in_order) || context->getSettingsRef().allow_experimental_analyzer)
|
||||||
{
|
{
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -6,7 +6,7 @@ namespace DB
|
|||||||
{
|
{
|
||||||
|
|
||||||
ReadNothingStep::ReadNothingStep(Block output_header)
|
ReadNothingStep::ReadNothingStep(Block output_header)
|
||||||
: ISourceStep(DataStream{.header = std::move(output_header), .has_single_port = true})
|
: ISourceStep(DataStream{.header = std::move(output_header)})
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -98,9 +98,29 @@ void RemoteSource::work()
|
|||||||
executor_finished = true;
|
executor_finished = true;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (preprocessed_packet)
|
||||||
|
{
|
||||||
|
preprocessed_packet = false;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
ISource::work();
|
ISource::work();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void RemoteSource::onAsyncJobReady()
|
||||||
|
{
|
||||||
|
chassert(async_read);
|
||||||
|
|
||||||
|
if (!was_query_sent)
|
||||||
|
return;
|
||||||
|
|
||||||
|
chassert(!preprocessed_packet);
|
||||||
|
preprocessed_packet = query_executor->processParallelReplicaPacketIfAny();
|
||||||
|
if (preprocessed_packet)
|
||||||
|
is_async_state = false;
|
||||||
|
}
|
||||||
|
|
||||||
std::optional<Chunk> RemoteSource::tryGenerate()
|
std::optional<Chunk> RemoteSource::tryGenerate()
|
||||||
{
|
{
|
||||||
/// onCancel() will do the cancel if the query was sent.
|
/// onCancel() will do the cancel if the query was sent.
|
||||||
|
@ -32,6 +32,8 @@ public:
|
|||||||
|
|
||||||
int schedule() override { return fd; }
|
int schedule() override { return fd; }
|
||||||
|
|
||||||
|
void onAsyncJobReady() override;
|
||||||
|
|
||||||
void setStorageLimits(const std::shared_ptr<const StorageLimitsList> & storage_limits_) override;
|
void setStorageLimits(const std::shared_ptr<const StorageLimitsList> & storage_limits_) override;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
@ -52,6 +54,7 @@ private:
|
|||||||
int fd = -1;
|
int fd = -1;
|
||||||
size_t rows = 0;
|
size_t rows = 0;
|
||||||
bool manually_add_rows_before_limit_counter = false;
|
bool manually_add_rows_before_limit_counter = false;
|
||||||
|
bool preprocessed_packet = false;
|
||||||
};
|
};
|
||||||
|
|
||||||
/// Totals source from RemoteQueryExecutor.
|
/// Totals source from RemoteQueryExecutor.
|
||||||
|
@ -16,6 +16,9 @@
|
|||||||
#include <Common/Arena.h>
|
#include <Common/Arena.h>
|
||||||
#include <Common/FieldVisitorConvertToNumber.h>
|
#include <Common/FieldVisitorConvertToNumber.h>
|
||||||
#include <Common/FieldVisitorsAccurateComparison.h>
|
#include <Common/FieldVisitorsAccurateComparison.h>
|
||||||
|
#include <Functions/CastOverloadResolver.h>
|
||||||
|
#include <Functions/IFunction.h>
|
||||||
|
#include <DataTypes/DataTypeString.h>
|
||||||
|
|
||||||
#include <Poco/Logger.h>
|
#include <Poco/Logger.h>
|
||||||
#include <Common/logger_useful.h>
|
#include <Common/logger_useful.h>
|
||||||
@ -78,6 +81,8 @@ public:
|
|||||||
|
|
||||||
virtual std::optional<WindowFrame> getDefaultFrame() const { return {}; }
|
virtual std::optional<WindowFrame> getDefaultFrame() const { return {}; }
|
||||||
|
|
||||||
|
virtual ColumnPtr castColumn(const Columns &, const std::vector<size_t> &) { return nullptr; }
|
||||||
|
|
||||||
/// Is the frame type supported by this function.
|
/// Is the frame type supported by this function.
|
||||||
virtual bool checkWindowFrameType(const WindowTransform * /*transform*/) const { return true; }
|
virtual bool checkWindowFrameType(const WindowTransform * /*transform*/) const { return true; }
|
||||||
};
|
};
|
||||||
@ -1174,6 +1179,9 @@ void WindowTransform::appendChunk(Chunk & chunk)
|
|||||||
// Initialize output columns.
|
// Initialize output columns.
|
||||||
for (auto & ws : workspaces)
|
for (auto & ws : workspaces)
|
||||||
{
|
{
|
||||||
|
if (ws.window_function_impl)
|
||||||
|
block.casted_columns.push_back(ws.window_function_impl->castColumn(block.input_columns, ws.argument_column_indices));
|
||||||
|
|
||||||
block.output_columns.push_back(ws.aggregate_function->getResultType()
|
block.output_columns.push_back(ws.aggregate_function->getResultType()
|
||||||
->createColumn());
|
->createColumn());
|
||||||
block.output_columns.back()->reserve(block.rows);
|
block.output_columns.back()->reserve(block.rows);
|
||||||
@ -2361,6 +2369,8 @@ public:
|
|||||||
template <bool is_lead>
|
template <bool is_lead>
|
||||||
struct WindowFunctionLagLeadInFrame final : public WindowFunction
|
struct WindowFunctionLagLeadInFrame final : public WindowFunction
|
||||||
{
|
{
|
||||||
|
FunctionBasePtr func_cast = nullptr;
|
||||||
|
|
||||||
WindowFunctionLagLeadInFrame(const std::string & name_,
|
WindowFunctionLagLeadInFrame(const std::string & name_,
|
||||||
const DataTypes & argument_types_, const Array & parameters_)
|
const DataTypes & argument_types_, const Array & parameters_)
|
||||||
: WindowFunction(name_, argument_types_, parameters_, createResultType(argument_types_, name_))
|
: WindowFunction(name_, argument_types_, parameters_, createResultType(argument_types_, name_))
|
||||||
@ -2388,7 +2398,17 @@ struct WindowFunctionLagLeadInFrame final : public WindowFunction
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
const auto supertype = getLeastSupertype(DataTypes{argument_types[0], argument_types[2]});
|
if (argument_types.size() > 3)
|
||||||
|
{
|
||||||
|
throw Exception(ErrorCodes::TOO_MANY_ARGUMENTS_FOR_FUNCTION,
|
||||||
|
"Function '{}' accepts at most 3 arguments, {} given",
|
||||||
|
name, argument_types.size());
|
||||||
|
}
|
||||||
|
|
||||||
|
if (argument_types[0]->equals(*argument_types[2]))
|
||||||
|
return;
|
||||||
|
|
||||||
|
const auto supertype = tryGetLeastSupertype(DataTypes{argument_types[0], argument_types[2]});
|
||||||
if (!supertype)
|
if (!supertype)
|
||||||
{
|
{
|
||||||
throw Exception(ErrorCodes::BAD_ARGUMENTS,
|
throw Exception(ErrorCodes::BAD_ARGUMENTS,
|
||||||
@ -2405,12 +2425,44 @@ struct WindowFunctionLagLeadInFrame final : public WindowFunction
|
|||||||
argument_types[2]->getName());
|
argument_types[2]->getName());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (argument_types.size() > 3)
|
const auto from_name = argument_types[2]->getName();
|
||||||
|
const auto to_name = argument_types[0]->getName();
|
||||||
|
ColumnsWithTypeAndName arguments
|
||||||
{
|
{
|
||||||
throw Exception(ErrorCodes::TOO_MANY_ARGUMENTS_FOR_FUNCTION,
|
{ argument_types[2], "" },
|
||||||
"Function '{}' accepts at most 3 arguments, {} given",
|
{
|
||||||
name, argument_types.size());
|
DataTypeString().createColumnConst(0, to_name),
|
||||||
}
|
std::make_shared<DataTypeString>(),
|
||||||
|
""
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
auto get_cast_func = [&arguments]
|
||||||
|
{
|
||||||
|
FunctionOverloadResolverPtr func_builder_cast = createInternalCastOverloadResolver(CastType::accurate, {});
|
||||||
|
return func_builder_cast->build(arguments);
|
||||||
|
};
|
||||||
|
|
||||||
|
func_cast = get_cast_func();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
ColumnPtr castColumn(const Columns & columns, const std::vector<size_t> & idx) override
|
||||||
|
{
|
||||||
|
if (!func_cast)
|
||||||
|
return nullptr;
|
||||||
|
|
||||||
|
ColumnsWithTypeAndName arguments
|
||||||
|
{
|
||||||
|
{ columns[idx[2]], argument_types[2], "" },
|
||||||
|
{
|
||||||
|
DataTypeString().createColumnConst(columns[idx[2]]->size(), argument_types[0]->getName()),
|
||||||
|
std::make_shared<DataTypeString>(),
|
||||||
|
""
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
return func_cast->execute(arguments, argument_types[0], columns[idx[2]]->size());
|
||||||
}
|
}
|
||||||
|
|
||||||
static DataTypePtr createResultType(const DataTypes & argument_types_, const std::string & name_)
|
static DataTypePtr createResultType(const DataTypes & argument_types_, const std::string & name_)
|
||||||
@ -2460,12 +2512,11 @@ struct WindowFunctionLagLeadInFrame final : public WindowFunction
|
|||||||
if (argument_types.size() > 2)
|
if (argument_types.size() > 2)
|
||||||
{
|
{
|
||||||
// Column with default values is specified.
|
// Column with default values is specified.
|
||||||
// The conversion through Field is inefficient, but we accept
|
const IColumn & default_column =
|
||||||
// subtypes of the argument type as a default value (for convenience),
|
current_block.casted_columns[function_index] ?
|
||||||
// and it's a pain to write conversion that respects ColumnNothing
|
*current_block.casted_columns[function_index].get() :
|
||||||
// and ColumnConst and so on.
|
*current_block.input_columns[workspace.argument_column_indices[2]].get();
|
||||||
const IColumn & default_column = *current_block.input_columns[
|
|
||||||
workspace.argument_column_indices[2]].get();
|
|
||||||
to.insert(default_column[transform->current_row.row]);
|
to.insert(default_column[transform->current_row.row]);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -50,6 +50,7 @@ struct WindowTransformBlock
|
|||||||
{
|
{
|
||||||
Columns original_input_columns;
|
Columns original_input_columns;
|
||||||
Columns input_columns;
|
Columns input_columns;
|
||||||
|
Columns casted_columns;
|
||||||
MutableColumns output_columns;
|
MutableColumns output_columns;
|
||||||
|
|
||||||
size_t rows = 0;
|
size_t rows = 0;
|
||||||
|
@ -488,6 +488,17 @@ RemoteQueryExecutor::ReadResult RemoteQueryExecutor::readAsync()
|
|||||||
if (was_cancelled)
|
if (was_cancelled)
|
||||||
return ReadResult(Block());
|
return ReadResult(Block());
|
||||||
|
|
||||||
|
if (has_postponed_packet)
|
||||||
|
{
|
||||||
|
has_postponed_packet = false;
|
||||||
|
auto read_result = processPacket(read_context->getPacket());
|
||||||
|
if (read_result.getType() == ReadResult::Type::Data || read_result.getType() == ReadResult::Type::ParallelReplicasToken)
|
||||||
|
return read_result;
|
||||||
|
|
||||||
|
if (got_duplicated_part_uuids)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
read_context->resume();
|
read_context->resume();
|
||||||
|
|
||||||
if (isReplicaUnavailable() || needToSkipUnavailableShard())
|
if (isReplicaUnavailable() || needToSkipUnavailableShard())
|
||||||
@ -508,10 +519,9 @@ RemoteQueryExecutor::ReadResult RemoteQueryExecutor::readAsync()
|
|||||||
if (read_context->isInProgress())
|
if (read_context->isInProgress())
|
||||||
return ReadResult(read_context->getFileDescriptor());
|
return ReadResult(read_context->getFileDescriptor());
|
||||||
|
|
||||||
auto anything = processPacket(read_context->getPacket());
|
auto read_result = processPacket(read_context->getPacket());
|
||||||
|
if (read_result.getType() == ReadResult::Type::Data || read_result.getType() == ReadResult::Type::ParallelReplicasToken)
|
||||||
if (anything.getType() == ReadResult::Type::Data || anything.getType() == ReadResult::Type::ParallelReplicasToken)
|
return read_result;
|
||||||
return anything;
|
|
||||||
|
|
||||||
if (got_duplicated_part_uuids)
|
if (got_duplicated_part_uuids)
|
||||||
break;
|
break;
|
||||||
@ -914,4 +924,37 @@ bool RemoteQueryExecutor::needToSkipUnavailableShard() const
|
|||||||
return context->getSettingsRef().skip_unavailable_shards && (0 == connections->size());
|
return context->getSettingsRef().skip_unavailable_shards && (0 == connections->size());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool RemoteQueryExecutor::processParallelReplicaPacketIfAny()
|
||||||
|
{
|
||||||
|
#if defined(OS_LINUX)
|
||||||
|
|
||||||
|
std::lock_guard lock(was_cancelled_mutex);
|
||||||
|
if (was_cancelled)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
if (!read_context || (resent_query && recreate_read_context))
|
||||||
|
{
|
||||||
|
read_context = std::make_unique<ReadContext>(*this);
|
||||||
|
recreate_read_context = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
chassert(!has_postponed_packet);
|
||||||
|
|
||||||
|
read_context->resume();
|
||||||
|
if (read_context->isInProgress()) // <- nothing to process
|
||||||
|
return false;
|
||||||
|
|
||||||
|
const auto packet_type = read_context->getPacketType();
|
||||||
|
if (packet_type == Protocol::Server::MergeTreeReadTaskRequest || packet_type == Protocol::Server::MergeTreeAllRangesAnnouncement)
|
||||||
|
{
|
||||||
|
processPacket(read_context->getPacket());
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
has_postponed_packet = true;
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -221,6 +221,9 @@ public:
|
|||||||
|
|
||||||
bool isReplicaUnavailable() const { return extension && extension->parallel_reading_coordinator && connections->size() == 0; }
|
bool isReplicaUnavailable() const { return extension && extension->parallel_reading_coordinator && connections->size() == 0; }
|
||||||
|
|
||||||
|
/// return true if parallel replica packet was processed
|
||||||
|
bool processParallelReplicaPacketIfAny();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
RemoteQueryExecutor(
|
RemoteQueryExecutor(
|
||||||
const String & query_,
|
const String & query_,
|
||||||
@ -302,6 +305,8 @@ private:
|
|||||||
*/
|
*/
|
||||||
bool got_duplicated_part_uuids = false;
|
bool got_duplicated_part_uuids = false;
|
||||||
|
|
||||||
|
bool has_postponed_packet = false;
|
||||||
|
|
||||||
/// Parts uuids, collected from remote replicas
|
/// Parts uuids, collected from remote replicas
|
||||||
std::vector<UUID> duplicated_part_uuids;
|
std::vector<UUID> duplicated_part_uuids;
|
||||||
|
|
||||||
|
@ -39,6 +39,8 @@ public:
|
|||||||
|
|
||||||
Packet getPacket() { return std::move(packet); }
|
Packet getPacket() { return std::move(packet); }
|
||||||
|
|
||||||
|
UInt64 getPacketType() const { return packet.type; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
bool checkTimeout(bool blocking = false);
|
bool checkTimeout(bool blocking = false);
|
||||||
|
|
||||||
|
@ -473,7 +473,7 @@ void MySQLHandler::comQuery(ReadBuffer & payload, bool binary_protocol)
|
|||||||
query_context->setCurrentQueryId(fmt::format("mysql:{}:{}", connection_id, toString(UUIDHelpers::generateV4())));
|
query_context->setCurrentQueryId(fmt::format("mysql:{}:{}", connection_id, toString(UUIDHelpers::generateV4())));
|
||||||
|
|
||||||
/// --- Workaround for Bug 56173. Can be removed when the analyzer is on by default.
|
/// --- Workaround for Bug 56173. Can be removed when the analyzer is on by default.
|
||||||
auto settings = query_context->getSettings();
|
auto settings = query_context->getSettingsCopy();
|
||||||
settings.prefer_column_name_to_alias = true;
|
settings.prefer_column_name_to_alias = true;
|
||||||
query_context->setSettings(settings);
|
query_context->setSettings(settings);
|
||||||
|
|
||||||
|
@ -28,6 +28,7 @@ namespace ErrorCodes
|
|||||||
extern const int TOO_MANY_PARTITIONS;
|
extern const int TOO_MANY_PARTITIONS;
|
||||||
extern const int DISTRIBUTED_TOO_MANY_PENDING_BYTES;
|
extern const int DISTRIBUTED_TOO_MANY_PENDING_BYTES;
|
||||||
extern const int ARGUMENT_OUT_OF_BOUND;
|
extern const int ARGUMENT_OUT_OF_BOUND;
|
||||||
|
extern const int LOGICAL_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Can the batch be split and send files from batch one-by-one instead?
|
/// Can the batch be split and send files from batch one-by-one instead?
|
||||||
@ -241,8 +242,12 @@ void DistributedAsyncInsertBatch::sendBatch(const SettingsChanges & settings_cha
|
|||||||
insert_settings.applyChanges(settings_changes);
|
insert_settings.applyChanges(settings_changes);
|
||||||
|
|
||||||
auto timeouts = ConnectionTimeouts::getTCPTimeoutsWithFailover(insert_settings);
|
auto timeouts = ConnectionTimeouts::getTCPTimeoutsWithFailover(insert_settings);
|
||||||
auto result = parent.pool->getManyCheckedForInsert(timeouts, insert_settings, PoolMode::GET_ONE, parent.storage.remote_storage.getQualifiedName());
|
auto results = parent.pool->getManyCheckedForInsert(timeouts, insert_settings, PoolMode::GET_ONE, parent.storage.remote_storage.getQualifiedName());
|
||||||
connection = std::move(result.front().entry);
|
auto result = results.front();
|
||||||
|
if (parent.pool->isTryResultInvalid(result, insert_settings.distributed_insert_skip_read_only_replicas))
|
||||||
|
throw Exception(ErrorCodes::LOGICAL_ERROR, "Got an invalid connection result");
|
||||||
|
|
||||||
|
connection = std::move(result.entry);
|
||||||
compression_expected = connection->getCompression() == Protocol::Compression::Enable;
|
compression_expected = connection->getCompression() == Protocol::Compression::Enable;
|
||||||
|
|
||||||
LOG_DEBUG(parent.log, "Sending a batch of {} files to {} ({} rows, {} bytes).",
|
LOG_DEBUG(parent.log, "Sending a batch of {} files to {} ({} rows, {} bytes).",
|
||||||
@ -299,8 +304,12 @@ void DistributedAsyncInsertBatch::sendSeparateFiles(const SettingsChanges & sett
|
|||||||
parent.storage.getContext()->getOpenTelemetrySpanLog());
|
parent.storage.getContext()->getOpenTelemetrySpanLog());
|
||||||
|
|
||||||
auto timeouts = ConnectionTimeouts::getTCPTimeoutsWithFailover(insert_settings);
|
auto timeouts = ConnectionTimeouts::getTCPTimeoutsWithFailover(insert_settings);
|
||||||
auto result = parent.pool->getManyCheckedForInsert(timeouts, insert_settings, PoolMode::GET_ONE, parent.storage.remote_storage.getQualifiedName());
|
auto results = parent.pool->getManyCheckedForInsert(timeouts, insert_settings, PoolMode::GET_ONE, parent.storage.remote_storage.getQualifiedName());
|
||||||
auto connection = std::move(result.front().entry);
|
auto result = results.front();
|
||||||
|
if (parent.pool->isTryResultInvalid(result, insert_settings.distributed_insert_skip_read_only_replicas))
|
||||||
|
throw Exception(ErrorCodes::LOGICAL_ERROR, "Got an invalid connection result");
|
||||||
|
|
||||||
|
auto connection = std::move(result.entry);
|
||||||
bool compression_expected = connection->getCompression() == Protocol::Compression::Enable;
|
bool compression_expected = connection->getCompression() == Protocol::Compression::Enable;
|
||||||
|
|
||||||
RemoteInserter remote(*connection, timeouts,
|
RemoteInserter remote(*connection, timeouts,
|
||||||
|
@ -283,7 +283,7 @@ ConnectionPoolWithFailoverPtr DistributedAsyncInsertDirectoryQueue::createPool(c
|
|||||||
|
|
||||||
auto pools = createPoolsForAddresses(addresses, pool_factory, storage.log);
|
auto pools = createPoolsForAddresses(addresses, pool_factory, storage.log);
|
||||||
|
|
||||||
const auto settings = storage.getContext()->getSettings();
|
const auto & settings = storage.getContext()->getSettingsRef();
|
||||||
return std::make_shared<ConnectionPoolWithFailover>(std::move(pools),
|
return std::make_shared<ConnectionPoolWithFailover>(std::move(pools),
|
||||||
settings.load_balancing,
|
settings.load_balancing,
|
||||||
settings.distributed_replica_error_half_life.totalSeconds(),
|
settings.distributed_replica_error_half_life.totalSeconds(),
|
||||||
@ -412,8 +412,12 @@ void DistributedAsyncInsertDirectoryQueue::processFile(std::string & file_path,
|
|||||||
insert_settings.applyChanges(settings_changes);
|
insert_settings.applyChanges(settings_changes);
|
||||||
|
|
||||||
auto timeouts = ConnectionTimeouts::getTCPTimeoutsWithFailover(insert_settings);
|
auto timeouts = ConnectionTimeouts::getTCPTimeoutsWithFailover(insert_settings);
|
||||||
auto result = pool->getManyCheckedForInsert(timeouts, insert_settings, PoolMode::GET_ONE, storage.remote_storage.getQualifiedName());
|
auto results = pool->getManyCheckedForInsert(timeouts, insert_settings, PoolMode::GET_ONE, storage.remote_storage.getQualifiedName());
|
||||||
auto connection = std::move(result.front().entry);
|
auto result = results.front();
|
||||||
|
if (pool->isTryResultInvalid(result, insert_settings.distributed_insert_skip_read_only_replicas))
|
||||||
|
throw Exception(ErrorCodes::LOGICAL_ERROR, "Got an invalid connection result");
|
||||||
|
|
||||||
|
auto connection = std::move(result.entry);
|
||||||
|
|
||||||
LOG_DEBUG(log, "Sending `{}` to {} ({} rows, {} bytes)",
|
LOG_DEBUG(log, "Sending `{}` to {} ({} rows, {} bytes)",
|
||||||
file_path,
|
file_path,
|
||||||
|
@ -377,7 +377,11 @@ DistributedSink::runWritingJob(JobReplica & job, const Block & current_block, si
|
|||||||
/// NOTE: INSERT will also take into account max_replica_delay_for_distributed_queries
|
/// NOTE: INSERT will also take into account max_replica_delay_for_distributed_queries
|
||||||
/// (anyway fallback_to_stale_replicas_for_distributed_queries=true by default)
|
/// (anyway fallback_to_stale_replicas_for_distributed_queries=true by default)
|
||||||
auto results = shard_info.pool->getManyCheckedForInsert(timeouts, settings, PoolMode::GET_ONE, storage.remote_storage.getQualifiedName());
|
auto results = shard_info.pool->getManyCheckedForInsert(timeouts, settings, PoolMode::GET_ONE, storage.remote_storage.getQualifiedName());
|
||||||
job.connection_entry = std::move(results.front().entry);
|
auto result = results.front();
|
||||||
|
if (shard_info.pool->isTryResultInvalid(result, settings.distributed_insert_skip_read_only_replicas))
|
||||||
|
throw Exception(ErrorCodes::LOGICAL_ERROR, "Got an invalid connection result");
|
||||||
|
|
||||||
|
job.connection_entry = std::move(result.entry);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -34,7 +34,7 @@ MergedBlockOutputStream::MergedBlockOutputStream(
|
|||||||
, write_settings(write_settings_)
|
, write_settings(write_settings_)
|
||||||
{
|
{
|
||||||
MergeTreeWriterSettings writer_settings(
|
MergeTreeWriterSettings writer_settings(
|
||||||
data_part->storage.getContext()->getSettings(),
|
data_part->storage.getContext()->getSettingsRef(),
|
||||||
write_settings,
|
write_settings,
|
||||||
storage_settings,
|
storage_settings,
|
||||||
data_part->index_granularity_info.mark_type.adaptive,
|
data_part->index_granularity_info.mark_type.adaptive,
|
||||||
|
@ -23,7 +23,7 @@ MergedColumnOnlyOutputStream::MergedColumnOnlyOutputStream(
|
|||||||
const MergeTreeIndexGranularityInfo * index_granularity_info)
|
const MergeTreeIndexGranularityInfo * index_granularity_info)
|
||||||
: IMergedBlockOutputStream(data_part->storage.getSettings(), data_part->getDataPartStoragePtr(), metadata_snapshot_, columns_list_, /*reset_columns=*/ true)
|
: IMergedBlockOutputStream(data_part->storage.getSettings(), data_part->getDataPartStoragePtr(), metadata_snapshot_, columns_list_, /*reset_columns=*/ true)
|
||||||
{
|
{
|
||||||
const auto & global_settings = data_part->storage.getContext()->getSettings();
|
const auto & global_settings = data_part->storage.getContext()->getSettingsRef();
|
||||||
|
|
||||||
MergeTreeWriterSettings writer_settings(
|
MergeTreeWriterSettings writer_settings(
|
||||||
global_settings,
|
global_settings,
|
||||||
|
@ -344,7 +344,7 @@ void ReplicatedMergeTreeRestartingThread::partialShutdown(bool part_of_full_shut
|
|||||||
void ReplicatedMergeTreeRestartingThread::shutdown(bool part_of_full_shutdown)
|
void ReplicatedMergeTreeRestartingThread::shutdown(bool part_of_full_shutdown)
|
||||||
{
|
{
|
||||||
/// Stop restarting_thread before stopping other tasks - so that it won't restart them again.
|
/// Stop restarting_thread before stopping other tasks - so that it won't restart them again.
|
||||||
need_stop = true;
|
need_stop = part_of_full_shutdown;
|
||||||
task->deactivate();
|
task->deactivate();
|
||||||
|
|
||||||
/// Explicitly set the event, because the restarting thread will not set it again
|
/// Explicitly set the event, because the restarting thread will not set it again
|
||||||
|
@ -193,6 +193,7 @@ ASTPtr ColumnStatisticsDescription::getAST() const
|
|||||||
{
|
{
|
||||||
auto function_node = std::make_shared<ASTFunction>();
|
auto function_node = std::make_shared<ASTFunction>();
|
||||||
function_node->name = "STATISTICS";
|
function_node->name = "STATISTICS";
|
||||||
|
function_node->kind = ASTFunction::Kind::STATISTICS;
|
||||||
function_node->arguments = std::make_shared<ASTExpressionList>();
|
function_node->arguments = std::make_shared<ASTExpressionList>();
|
||||||
for (const auto & [type, desc] : types_to_desc)
|
for (const auto & [type, desc] : types_to_desc)
|
||||||
{
|
{
|
||||||
|
@ -464,7 +464,7 @@ std::pair<Poco::URI, std::unique_ptr<ReadWriteBufferFromHTTP>> StorageURLSource:
|
|||||||
|
|
||||||
setCredentials(credentials, request_uri);
|
setCredentials(credentials, request_uri);
|
||||||
|
|
||||||
const auto settings = context_->getSettings();
|
const auto & settings = context_->getSettingsRef();
|
||||||
|
|
||||||
auto proxy_config = getProxyConfiguration(request_uri.getScheme());
|
auto proxy_config = getProxyConfiguration(request_uri.getScheme());
|
||||||
|
|
||||||
@ -1328,7 +1328,7 @@ std::optional<time_t> IStorageURLBase::tryGetLastModificationTime(
|
|||||||
const Poco::Net::HTTPBasicCredentials & credentials,
|
const Poco::Net::HTTPBasicCredentials & credentials,
|
||||||
const ContextPtr & context)
|
const ContextPtr & context)
|
||||||
{
|
{
|
||||||
auto settings = context->getSettingsRef();
|
const auto & settings = context->getSettingsRef();
|
||||||
|
|
||||||
auto uri = Poco::URI(url);
|
auto uri = Poco::URI(url);
|
||||||
|
|
||||||
|
@ -228,12 +228,12 @@ private:
|
|||||||
bool need_only_count;
|
bool need_only_count;
|
||||||
size_t total_rows_in_file = 0;
|
size_t total_rows_in_file = 0;
|
||||||
|
|
||||||
|
Poco::Net::HTTPBasicCredentials credentials;
|
||||||
|
|
||||||
std::unique_ptr<ReadBuffer> read_buf;
|
std::unique_ptr<ReadBuffer> read_buf;
|
||||||
std::shared_ptr<IInputFormat> input_format;
|
std::shared_ptr<IInputFormat> input_format;
|
||||||
std::unique_ptr<QueryPipeline> pipeline;
|
std::unique_ptr<QueryPipeline> pipeline;
|
||||||
std::unique_ptr<PullingPipelineExecutor> reader;
|
std::unique_ptr<PullingPipelineExecutor> reader;
|
||||||
|
|
||||||
Poco::Net::HTTPBasicCredentials credentials;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
class StorageURLSink : public SinkToStorage
|
class StorageURLSink : public SinkToStorage
|
||||||
|
@ -97,7 +97,7 @@ bool hasJoin(const ASTSelectWithUnionQuery & ast)
|
|||||||
ContextPtr getViewContext(ContextPtr context, const StorageSnapshotPtr & storage_snapshot)
|
ContextPtr getViewContext(ContextPtr context, const StorageSnapshotPtr & storage_snapshot)
|
||||||
{
|
{
|
||||||
auto view_context = storage_snapshot->metadata->getSQLSecurityOverriddenContext(context);
|
auto view_context = storage_snapshot->metadata->getSQLSecurityOverriddenContext(context);
|
||||||
Settings view_settings = view_context->getSettings();
|
Settings view_settings = view_context->getSettingsCopy();
|
||||||
view_settings.max_result_rows = 0;
|
view_settings.max_result_rows = 0;
|
||||||
view_settings.max_result_bytes = 0;
|
view_settings.max_result_bytes = 0;
|
||||||
view_settings.extremes = false;
|
view_settings.extremes = false;
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
#include <string_view>
|
#include <string_view>
|
||||||
#include <Storages/System/StorageSystemDashboards.h>
|
#include <Storages/System/StorageSystemDashboards.h>
|
||||||
#include <Common/StringUtils.h>
|
#include <Common/StringUtils.h>
|
||||||
|
#include <Interpreters/Context.h>
|
||||||
|
|
||||||
namespace DB
|
namespace DB
|
||||||
{
|
{
|
||||||
@ -22,9 +23,9 @@ String trim(const char * text)
|
|||||||
return String(view);
|
return String(view);
|
||||||
}
|
}
|
||||||
|
|
||||||
void StorageSystemDashboards::fillData(MutableColumns & res_columns, ContextPtr, const ActionsDAG::Node *, std::vector<UInt8>) const
|
void StorageSystemDashboards::fillData(MutableColumns & res_columns, ContextPtr context, const ActionsDAG::Node *, std::vector<UInt8>) const
|
||||||
{
|
{
|
||||||
static const std::vector<std::map<String, String>> dashboards
|
static const std::vector<std::map<String, String>> default_dashboards
|
||||||
{
|
{
|
||||||
/// Default dashboard for self-managed ClickHouse
|
/// Default dashboard for self-managed ClickHouse
|
||||||
{
|
{
|
||||||
@ -371,13 +372,22 @@ ORDER BY t WITH FILL STEP {rounding:UInt32}
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
for (const auto & row : dashboards)
|
auto add_dashboards = [&](const auto & dashboards)
|
||||||
{
|
{
|
||||||
size_t i = 0;
|
for (const auto & row : dashboards)
|
||||||
res_columns[i++]->insert(row.at("dashboard"));
|
{
|
||||||
res_columns[i++]->insert(row.at("title"));
|
size_t i = 0;
|
||||||
res_columns[i++]->insert(row.at("query"));
|
res_columns[i++]->insert(row.at("dashboard"));
|
||||||
}
|
res_columns[i++]->insert(row.at("title"));
|
||||||
|
res_columns[i++]->insert(row.at("query"));
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
const auto & context_dashboards = context->getDashboards();
|
||||||
|
if (context_dashboards.has_value())
|
||||||
|
add_dashboards(*context_dashboards);
|
||||||
|
else
|
||||||
|
add_dashboards(default_dashboards);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -22,7 +22,7 @@ public:
|
|||||||
protected:
|
protected:
|
||||||
using IStorageSystemOneBlock::IStorageSystemOneBlock;
|
using IStorageSystemOneBlock::IStorageSystemOneBlock;
|
||||||
|
|
||||||
void fillData(MutableColumns & res_columns, ContextPtr, const ActionsDAG::Node *, std::vector<UInt8>) const override;
|
void fillData(MutableColumns & res_columns, ContextPtr context, const ActionsDAG::Node *, std::vector<UInt8>) const override;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -65,7 +65,7 @@ ColumnsDescription getStructureOfRemoteTableInShard(
|
|||||||
/// Ignore limit for result number of rows (that could be set during handling CSE/CTE),
|
/// Ignore limit for result number of rows (that could be set during handling CSE/CTE),
|
||||||
/// since this is a service query and should not lead to query failure.
|
/// since this is a service query and should not lead to query failure.
|
||||||
{
|
{
|
||||||
Settings new_settings = new_context->getSettings();
|
Settings new_settings = new_context->getSettingsCopy();
|
||||||
new_settings.max_result_rows = 0;
|
new_settings.max_result_rows = 0;
|
||||||
new_settings.max_result_bytes = 0;
|
new_settings.max_result_bytes = 0;
|
||||||
new_context->setSettings(new_settings);
|
new_context->setSettings(new_settings);
|
||||||
|
@ -93,7 +93,7 @@ StoragePtr TableFunctionHive::executeImpl(
|
|||||||
ColumnsDescription /*cached_columns_*/,
|
ColumnsDescription /*cached_columns_*/,
|
||||||
bool /*is_insert_query*/) const
|
bool /*is_insert_query*/) const
|
||||||
{
|
{
|
||||||
const Settings & settings = context_->getSettings();
|
const Settings & settings = context_->getSettingsRef();
|
||||||
ParserExpression partition_by_parser;
|
ParserExpression partition_by_parser;
|
||||||
ASTPtr partition_by_ast = parseQuery(
|
ASTPtr partition_by_ast = parseQuery(
|
||||||
partition_by_parser,
|
partition_by_parser,
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user