Commit Graph

5021 Commits (3a9008a79cd0a180b2ea8055ec052ec9cdd4191c)

Author SHA1 Message Date
Burak Velioglu 3a9008a79c
Address reviews and improve tests 2021-08-31 16:10:18 +03:00
Burak Velioglu 47ec669a71
Update tests and comments 2021-08-30 12:36:33 +03:00
Burak Velioglu 868c522d1f
Return partition name from range finder function (without fixing tests) 2021-08-28 22:12:20 +03:00
Burak Velioglu fa3f661421
Address reviews except partition naming related ones 2021-08-27 23:44:54 +03:00
Burak Velioglu 8f179fbb83
Rename drop function to drop_timeseries_table_metadata 2021-08-27 22:33:03 +03:00
Burak Velioglu acc787fac3
Downgrade drop_timeseries_table properly 2021-08-27 22:05:58 +03:00
Burak Velioglu d23b8d3b8b
Add downgrade scripts 2021-08-27 17:12:24 +03:00
Burak Velioglu 22dcc251c3
Fix tests and adress reviews 2021-08-27 13:44:08 +03:00
Burak Velioglu e4fbcfe3cf
EditorConfig 2021-08-27 12:21:45 +03:00
Burak Velioglu ec05df9708
Fix include 2021-08-27 11:15:26 +03:00
Burak Velioglu 7a4293fe37
Update ordering on test and add new one for create_missing_partitions 2021-08-26 13:32:21 +03:00
Burak Velioglu dfdda48cbf
Add get_missing_partition_ranges tests 2021-08-26 02:06:21 +03:00
Burak Velioglu e1299ec72b
Add create_timeseries_table tests 2021-08-26 01:26:41 +03:00
Burak Velioglu aad741a2e2
Fix error checks and messages 2021-08-24 16:02:52 +03:00
Burak Velioglu c6705ebbd1
Address reviews 2021-08-24 13:31:32 +03:00
Burak Velioglu 06dd189c8f
Add start_from parameter to create_timeseries_table 2021-08-24 00:45:34 +03:00
Burak Velioglu 4754a86e31
Introduce drop_timeseries_table UDF to drop metadata 2021-08-23 15:36:33 +03:00
Burak Velioglu 993a2cbce9
Reorder checks to make them more actionable 2021-08-22 22:39:54 +03:00
Burak Velioglu 20471d2a38
Add TODOs 2021-08-22 22:29:37 +03:00
Burak Velioglu e7138bcd4c
Introduce get_missing_partition_ranges and use it as a part of create_missing_partitions 2021-08-22 22:18:53 +03:00
Burak Velioglu 787f76a952
citus_indent 2021-08-20 12:34:28 +03:00
Burak Velioglu ce12ab5570
Introduce timeseries_utils 2021-08-20 12:03:41 +03:00
Burak Velioglu e9bb732b22
Add truncating according to interval and minor fixes 2021-08-20 01:53:26 +03:00
Burak Velioglu ef724edf31
Introduce create_timeseries_table with related checks 2021-08-19 13:18:48 +03:00
Burak Velioglu a8435620c4
Merge pull request #5115 from citusdata/velioglu/partition_fixes
Support for CREATE INDEX ONLY and ALTER INDEX ATTACH PARTITION
2021-08-13 13:18:36 +03:00
Burak Velioglu 4355ba0a38
Add CREATE INDEX ... ON ONLY and ALTER INDEX ... ATTACH PARTITION (#4938 #4980)
- Add support for CRETE INDEX ... ON ONLY: Before that commit we were not sending "ONLY" option to the worker nodes at all. With this commit, "ONLY" parameter will be sent to the worker nodes if it is necessary. (#4938)

- Add support for ALTER INDEX ... ATTACH PARTITION: Attach child_index to parent_index by creating same inheritance on shard level in addition to table level. (#4980)
2021-08-13 13:12:45 +03:00
SaitTalhaNisanci 2ec4e37e45
Fix assert failure in FindReferencedTableColumn (#5175) 2021-08-12 18:21:45 +03:00
Ahmet Gedemenli 9e90894f21
Synchronize hasmetadata flag on mx workers (#5086)
* Synchronize hasmetadata flag on mx workers

* Switch to sequential execution

* Add test

* Use SetWorkerColumn

* Add test for stop_sync

* Remove usage of UpdateHasmetadataOnWorkersWithMetadata

* Remove MarkNodeMetadataSynced

* Fix test for metadatasynced

* Remove MarkNodeMetadataSynced

* Style

* Remove MarkNodeHasMetadata

* Remove UpdateDistNodeBoolAttr

* Refactor SetWorkerColumn

* Use SetWorkerColumnLocalOnly when setting up dependencies

* Use SetWorkerColumnLocalOnly in TriggerSyncMetadataToPrimaryNodes

* Style

* Make update command generator functions static

* Set metadatasynced before syncing

* Call SetWorkerColumn only if the sync is successful

* Try to sync all nodes

* Fix indexno

* Update metadatasynced locally first

* Break if a node fails to sync metadata

* Send worker commands optional

* Style & Rebase

* Add raiseOnError param to SetWorkerColumn

* Style

* Set metadatasynced for all metadata nodes

* Style

* Introduce SetWorkerColumnOptional

* Polish

* Style

* Dont send set command to not synced metadata nodes

* Style

* Polish

* Add test for stop_sync

* Add test for shouldhaveshards

* Add test for isactive flag

* Sort by placementid in the function verify_metadata

* Cover edge cases for failing nodes

* Add comments

* Add nodeport to isactive test

* Add warning if metadata out of sync

* Update warning message
2021-08-12 14:16:18 +03:00
Naisila Puka e5b32b2c3c
Acquire AccessShareLock before updating table statistics (#5155) 2021-08-12 13:58:15 +03:00
Ahmet Gedemenli 6bb4c5e94f
Merge pull request #5173 from citusdata/missing_shouldhave_shards
Make sure that shouldhaveshards is synced to workers
2021-08-11 17:15:14 +03:00
Onder Kalaci d4368ff2b3 Make sure that shouldhaveshards is synced to workers 2021-08-11 15:53:31 +02:00
Hanefi Onaldi dc67dbaa01
Merge pull request #5171 from citusdata/changelog-updates
Add changelog entries for 9.4.6
2021-08-11 11:32:46 +03:00
Hanefi Onaldi c6e428896a
Add changelog entries for 9.4.6 2021-08-11 10:53:31 +03:00
Önder Kalacı 272f4d7ce5
Merge pull request #5158 from citusdata/heap_on_master
Guard against hard WaitEvenSet errors
2021-08-10 09:41:05 +02:00
Onder Kalaci 86bd28b92c Guard against hard WaitEvenSet errors
In short, add wrappers around Postgres' AddWaitEventToSet() and
ModifyWaitEvent().

AddWaitEventToSet()/ModifyWaitEvent*() may throw hard errors. For
example, when the underlying socket for a connection is closed by
the remote server and already reflected by the OS, however
Citus hasn't had a chance to get this information. In that case,
if replication factor is >1, Citus can failover to other nodes
for executing the query. Even if replication factor = 1, Citus
can give much nicer errors.

So CitusAddWaitEventSetToSet()/CitusModifyWaitEvent() simply puts
AddWaitEventToSet()/ModifyWaitEvent() into a PG_TRY/PG_CATCH block
in order to catch any hard errors, and returns this information to
the caller.
2021-08-10 09:35:03 +02:00
Önder Kalacı 2ac3cc07eb
Merge pull request #5144 from citusdata/transactional_start_metadata_node
Make start/stop_metadata_sync_to_node transactional
2021-08-09 10:55:57 +02:00
Onder Kalaci 5f02d18ef8 transactional metadata sync for maintanince daemon
As we use the current user to sync the metadata to the nodes
with #5105 (and many other PRs), there is no reason that
prevents us to use the coordinated transaction for metadata syncing.

This commit also renames few functions to reflect their actual
implementation.
2021-08-09 10:34:55 +02:00
Önder Kalacı 999a236540
Merge pull request #5131 from citusdata/fix_drop_column_part
Dropped columns do not diverge distribution column for partitioned tables
2021-08-06 13:47:50 +02:00
Onder Kalaci 35964c6366 Dropped columns do not diverge distribution column for partitioned tables
Before this commit, creating a partition after a DROP column
on the parent (position before dist. key) was leading to
partition to have the wrong distribution column.
2021-08-06 13:36:12 +02:00
Hanefi Onaldi 0722ec95bc
Merge pull request #5163 from citusdata/changelog-updates 2021-08-05 19:31:10 +03:00
Hanefi Onaldi 998b9ffcaa
Merge branch 'master' into changelog-updates 2021-08-05 19:27:13 +03:00
jeff-davis deb7ec605b
Columnar: fix misleading comments and useless types. (#5162)
CustomScan and CustomPath structures cannot be extended with
additional fields. Fix comments and type structure that implied that
they can.
2021-08-05 09:22:21 -07:00
Hanefi Onaldi bc5553b5d1
Add changelog entries for 10.1.1 2021-08-05 17:32:31 +03:00
Ahmet Gedemenli 07ca8784cd
Merge pull request #5161 from citusdata/add-check-for-gucs-order
Add check for alphabetically sorted gucs
2021-08-05 17:09:38 +03:00
Ahmet Gedemenli 51d410bb7b Add check for alphabetically sorted gucs
Move to a separate script

Add the new script to readme
2021-08-05 16:37:49 +03:00
naisila 798a7902bf Fix master_update_table_statistics scripts for 9.5 2021-08-03 18:15:56 +03:00
naisila f9fa5a3d69 Fix master_update_table_statistics scripts for 9.4 2021-08-03 18:15:56 +03:00
Önder Kalacı 0d2f49fbce
Merge pull request #5130 from citusdata/get_ready_update_dist_table_colocation
Introduce citus_internal_update_relation_colocation
2021-08-03 11:53:30 +02:00
Onder Kalaci 482b8096e9 Introduce citus_internal_update_relation_colocation
update_distributed_table_colocation can be called by the relation
owner, and internally it updates pg_dist_partition. With this
commit, update_distributed_table_colocation uses an internal
UDF to access pg_dist_partition.

As a result, this operation can now be done by regular users
on MX.
2021-08-03 11:44:58 +02:00
Onur Tirtir ef6a8604ba
Merge pull request #5140 from citusdata/col/seq-path-costing
Re-cost columnar table sequential scan paths 

With the changes in this pr, we adjust the cost estimates done by postgres for sequential scan paths for columnar tables.

We want to make better decisions when columnar custom scan is disabled too. That means, there are cases where index scan is more preferable over sequential scan for heapAM but not for columnarAM. 
For this reason, we want to make better decisions regarding whether to choose index scan or sequential scan when columnar custom is scan is **disabled**.
So with this pr, we re-estimate costs for sequential scan paths in a way that is quite similar to what we do for columnar custom scan.

The idea is that columnar custom scan uses projection pushdown so the cost is directly proportional to column selectivity. However, for sequential scan, we re-estimate the cost considering **all** the columns since projection pushdown is not supported for plain sequential scan.
One thing to note here is that we still don't consider chunk group filtering when estimating the cost for columnar custom scan. For this reason, we calculate the same costs for sequential scan & columnar custom scan if query reads all columns, regardless of the filters in the `where` clause.
To avoid mistakenly choosing sequential scan in such cases, we still remove non `IndexPath`s if columnar custom scan is enabled.
That way, even when we calculate the same cost for sequential scan and columnar scan, we will anyway remove sequential one and guarantee that we would choose either columnar custom scan or index scan.
2021-08-02 11:38:11 +03:00