-
Notifications
You must be signed in to change notification settings - Fork 1.1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[YSQL] Extra Secondary Index Writes on Trigger Insert + Foreign Key Check #18822
Comments
Found a simpler reproduction for this issue. Consider a table
The table
Let us insert a sample row into test to ensure that the
Performing an update on non-index column v2 leads to unnecessary writes:
A similar result on change the WHERE clause:
Summary: A table with a FK constrain and a trigger (which are in no way related to each other) causes writes to all secondary indexes in the table. |
… checks when relevant columns not modified Summary: **Background** Prior to this revision, an UPDATE statement specifying a list of target columns X in its SET clause, **always** performed the necessary work to update each of the target columns in the storage layer, irrespective of whether the values of the columns actually changed. The necessary work could include requiring locks, updating indexes, checking of constraints, firing of triggers etc. **The Optimization** This revision introduces an optimization that validates that the values of a column are indeed being modified, before sending (flushing) the updated value of the column to the storage layer. In particular, the set of columns whose values that are compared are those that can cause extra round trips to the storage layer in the form of: - Primary Key Updates - Secondary Index Updates - Foreign Key Constraints - Uniqueness Constraints The matrix of columns that are marked for update and the objects (indexes, constraints) they impact are computed at planning time. This is particularly useful when used in conjunction with prepared statements and ORMs, which tend to specify all columns (both modified and non-modified) as part of the target list. The decision of whether a column is indeed modified is done on a per-tuple basis at execution time. **Example** As a concrete example, consider a table with the following schema and data: ``` yugabyte=# CREATE TABLE foo (h INT PRIMARY KEY, v1 INT, v2 INT, v3 INT); yugabyte=# CREATE INDEX foo_v1_idx ON foo (v1); yugabyte=# CREATE INDEX foo_v2_idx ON foo (v2); yugabyte=# INSERT INTO foo (SELECT i, i, i % 10, i % 100 FROM generate_series(1, 10000) AS i); ``` Performing an UPDATE on the first 1000 rows (without the optimization) yields: ``` yugabyte=# SET yb_explain_hide_non_deterministic_fields TO true; yugabyte=# EXPLAIN (ANALYZE, DIST) UPDATE foo SET h = v1, v1 = v1, v3 = v3 + 1 WHERE v1 <= 1000; QUERY PLAN ------------------------------------------------------------------------------------------ Update on foo (cost=0.00..105.00 rows=1000 width=88) (actual rows=0 loops=1) -> Seq Scan on foo (cost=0.00..105.00 rows=1000 width=88) (actual rows=1000 loops=1) Remote Filter: (v1 <= 1000) Storage Table Read Requests: 1 Storage Table Rows Scanned: 10000 Storage Table Write Requests: 2000 Storage Index Write Requests: 4000 Storage Flush Requests: 2000 Storage Read Requests: 1 Storage Rows Scanned: 10000 Storage Write Requests: 6000 Storage Flush Requests: 2001 (12 rows) ``` The values of `h` and `v1` are not modified by the query, yet result in multiple write requests to both the main table as well as the secondary indices. Since updates to key columns (of a table or an index) is executed as a sequence of a DELETE followed by an INSERT, this query requires a large amount of flushes. This makes the query very expensive in terms of the amount of work to be done. With the proposed optimization the query is executed as follows: ``` yugabyte=# EXPLAIN (ANALYZE, DIST) UPDATE foo SET h = v1, v1 = v1, v3 = v3 + 1 WHERE v1 <= 1000; QUERY PLAN ------------------------------------------------------------------------------------------ Update on foo (cost=0.00..105.00 rows=1000 width=88) (actual rows=0 loops=1) -> Seq Scan on foo (cost=0.00..105.00 rows=1000 width=88) (actual rows=1000 loops=1) Remote Filter: (v1 <= 1000) Storage Table Read Requests: 1 Storage Rows Scanned: 10000 Storage Table Write Requests: 1000 Storage Read Requests: 1 Storage Rows Scanned: 10000 Storage Write Requests: 1000 Storage Flush Requests: 1 (10 rows) ``` **Flags and Feature Status** This revision introduces the following GUCs to control the behavior of this optimization: `yb_update_num_cols_to_compare` - The maximum number of columns to be compared. (default: 0) `yb_update_max_cols_size_to_compare` - The maximum size of an individual column that can be compared. (default: 10240) This feature is currently turned off as a result of setting `yb_update_num_cols_to_compare` to 0. **Debuggability** Turn on postgres debug2 logs via the following command: ``` ./bin/yb-ctl restart --ysql_pg_conf_csv='log_min_messages=debug2' ``` This produces the following debug information: ``` -- At planning time 2024-07-31 10:59:07.124 PDT [76120] DEBUG: Update matrix: rows represent OID of entities, columns represent attnum of cols 2024-07-31 10:59:07.124 PDT [76120] DEBUG: - 10 2024-07-31 10:59:07.124 PDT [76120] DEBUG: 17415 Y -- At execution time, on a per-tuple basis 2024-07-31 10:59:07.143 PDT [76120] DEBUG: Index/constraint with oid 17415 requires an update 2024-07-31 10:59:07.143 PDT [76120] DEBUG: Relation: 17412 Columns that are inspected and modified: 1 (10) 2024-07-31 10:59:07.143 PDT [76120] DEBUG: No cols in category: Columns that are inspected and unmodified 2024-07-31 10:59:07.143 PDT [76120] DEBUG: Relation: 17412 Columns that are marked for update: 1 (10) 2 (11) ``` **Future Work** 1. Introduce auto-flag infrastructure to safely use row-locking. This is in the context of upgrade safety while the cluster is being upgraded. 2. As a part of the flag infrastructure, ensure that flags/GUC values are immutable during the lifetime of a query. 3. #22994: PGSQL_UPDATEs with no column references should acquire row locks. 4. #23348: Add support for partitioned tables with out of order columns. 5. Support for serializing optimization metadata in plans. 6. Enhance randgen grammar to support ModifyTable (INSERT/UPDATE/DELETE ) queries 7. #23350: PG 15 support. jenkins: urgent Jira: DB-7701 Test Plan: Run the associated pg_regress test as follows: ``` # New tests ./yb_build.sh --java-test 'org.yb.pgsql.TestPgRegressUpdateOptimized#schedule' # Existing tests ./yb_build.sh --java-test 'org.yb.pgsql.TestPgUpdatePrimaryKey' ./yb_build.sh --java-test 'org.yb.pgsql.TestPgUniqueConstraint' ./yb_build.sh --java-test 'org.yb.pgsql.TestPgRegressTrigger#testPgRegressTrigger' ./yb_build.sh --java-test 'org.yb.pgsql.TestPgRegressDml#testPgRegressDml' ./yb_build.sh --java-test 'org.yb.pgsql.TestPgRegressPushdown#testPgRegressPushdown' ``` Tested scenarios include (but not limited to): 1. Single row and distributed transactions with and without the feature flag turned on. 2. Relations with a primary key and no secondary indexes or triggers (UPDATEs can take the single row path) 3. Relations with combinations of primary key and secondary indexes. 4. Relations with unconditional before-row triggers. 5. UPDATEs in Colocated databases. 6. UPDATEs covering multiple tuples. 7. Hierarchy of relations with foreign keys 8. Relations with self referential foreign keys 9. Relations with overlapping indexes. 10. Relations having columns with uniqueness constraints. 11. Relations having covering indexes. 12. Relations having partial indexes. 13. Relations having index expressions / predicates. 14. Relations with conditional column triggers. 15. Relations having indexes/constraints out of order (ie. order of columns in relation is different from that of entity) 16. Relations having combination of hash and range indexes. 17. UPDATEs with correlated subqueries. 18. INSERT ON CONFLICT DO UPDATE. 19. UPDATE RETURNING. 20. UPDATEs on temp tables. Reviewers: mihnea, jason, amartsinchyk Reviewed By: amartsinchyk Subscribers: pjain, jason, smishra, yql Tags: #jenkins-ready Differential Revision: https://phorge.dev.yugabyte.com/D34040
Summary: 66890cb [PLAT-14781] Add runtime config for download metrics as pdf b2f24f2 [#9797] YSQL: Stubs for ysql major version upgrade RPCs 5891faa [#23332] Docdb: Fix yb-admin to handle snapshot_retention correctly 0614c52 [PLAT-14756] Releases API RBAC cleanup 2cfb999 [docs] Release notes for 2024.1.1.0-b137 (#23185) d868a03 [PLAT-13495] Do not run dual nic steps on systemd upgrade 10bc447 [PLAT-14798] Adding internal load balancer to devspace 7296df8 [docs] [2.23] Add pg_cron extension docs (#22546) 79902ae [PLAT-14678] - feat : Export All Metrics to pdf 8a0b95c [#23322] YSQL: pg_partman: fix logic of checking existing table Excluded: 63f471a [#18822] YSQL: Framework to skip redundant sec index updates and fkey checks when relevant columns not modified 3040472 [PLAT-14783] [PGParity] After Edit RR cores scale up on PG Parity enabled cluster, the RR node does not have PGP gflags e052089 [PLAT-14774] Per process tserver metrics is not working if YSQL is disabled 0c664a1 [#22370] docdb: Cost Based Optimizer changes to take into account backward scans improvement a060877 [PLAT-13712]fix plan info for Azure VMs 291dd40 Remove 6sense domains from CSP headers (#23354) 75cb273 [#23330] docdb: fixed static columns handling for CQL operations Test Plan: Jenkins: rebase: pg15-cherrypicks Reviewers: jason, tfoucher Tags: #jenkins-ready Differential Revision: https://phorge.dev.yugabyte.com/D36984
… sec index updates and fkey checks when relevant columns not modified Summary: **Conflict Resolution for PG15 cherrypick** - src/postgres/src/include/nodes/plannodes.h: - Location: struct ModifyTable definition: - My master commit adds two new fields (`yb_update_affected_entities`, `yb_skip_entities`) and subsumes (`no_update_index_list`) - YB-PG 15 has added new fields (`ybUseScanTupleInUpdate`, `ybHasWholeRowAttribute`) - Merge resolution: Keep newly added fields from both, remove `no_update_index_list` - Location: imports - My master commit adds the import `nodes/ybbitmatrix.h` - YB-PG 15 changes `nodes/relation.h` to `access/relation.h` and adds `nodes/parsenodes.h`, `nodes/pathnodes.h` - Merge resolution: Add nodes/ybbitmatrix.h, nodes/parsenodes.h, nodes/pathnodes.h and change nodes/relation.h to access/relation.h - src/postgres/src/include/executor/executor.h - Location: “prototypes from functions in execIndexing.c” - My master commit removes the `no_update_index_list` arg from ExecInsertIndexTuples and ExecDeleteIndexTuplesOptimized and removes the function `ContainsIndexRelation` - YB-PG 15 has rearranged the location of function definitions, added a `ResultRelInfo` field to the *IndexTuple functions - Merge resolution: Keep functions in rearranged locations, add `ResultRelInfo` and remove `no_update_index_list` to ExecInsertIndexTuples, remove ExecDeleteIndexTuplesOptimized altogether, remove `ContainsIndexRelation` - src/postgres/src/backend/utils/misc/guc.c: - Location: integer GUCs - My master commit adds new GUCs (`yb_update_num_cols_to_compare`, `yb_update_max_cols_size_to_compare`) - This caused an adjacency conflict with YB-PG 15 (41c091a) that changed QUERY_TUNING to QUERY_TUNING_OTHER for `yb_parallel_range_rows`. - Merge resolution: Add my new GUCs and change QUERY_TUNING_OTHER for `yb_parallel_range_rows`. - src/postgres/src/include/utils/relcache.h: - Location: “Routines to compute/retrieve additional cached information” - My master commit adds a new function `YbComputeIndexExprOrPredicateAttrs`. - YB-PG 15 adds new functions `RelationGetIdentityKeyBitmap` (upstream PG commit: e7eea52b2d61917fbbdac7f3f895e4ef636e935b), `RelationGetIndexPredicate` and `RelationGetIndexRawAttOptions` (upstream PG commit: 911e70207703799605f5a0e8aad9f06cff067c63) causing adjacency conflicts. Further, 55782d5 moves down `CheckIndexForUpdate` declaration. - Merge resolution: Add all new functions, move down `CheckIndexForUpdate` declaration - src/postgres/src/backend/utils/cache/relcache.c: - Location: IsProjectionFunctionalIndex - My master commit adds a new function `YbComputeIndexExprOrPredicateAttrs` - YB-PG 15 removed a function in the same area: `IsProjectionFunctionalIndex` - Merge resolution: Add `YbComputeIndexExprOrPredicateAttrs`, remove `IsProjectionFunctionalIndex` - Location: YbRelationGetFKeyReferencedByList - Not a merge conflict. In YB-PG 15, `DeconstructFkConstraintRow` has additional outparams to retrieve ON DELETE SET NULL/DEFAULT cols. This info is not needed, hence the params are set to NULL. - Not a merge conflict. Fetch the constraint oid from `Form_pg_constraint` instead of fetching it from the HeapTuple directly. - src/postgres/src/include/commands/trigger.h: - Location: “in utils/adt/ri_triggers.c” - My master commit adds a new param `yb_skip_entities` to `RI_FKey_pk_upd_check_required` and `RI_FKey_fk_upd_check_required` - YB-PG 15 uses TupleTableSlots instead of HAeapTuples in the function definition + lint changes - Resolution: Added new param and replaced HeapTuples with TupleTableSlots - src/postgres/src/backend/utils/adt/ri_triggers.c: - Same as above - src/postgres/src/backend/commands/trigger.c: - Location: AfterTriggerSaveEvent - Same context as above - Additionally, YB-PG 15 skips foreign key update checks on partitioned tables (upstream PG commit: ba9a7e392171c83eb3332a757279e7088487f9a2). This behavior is retained in the conflict resolution. - src/postgres/src/backend/optimizer/util/ybcplan.c: - Location: imports - My master commit moved around the location of `yb/yql/pggate/ybc_pggate.h` (albeit accidentally) - YB-PG 15 (55782d5) moves `ybcplan.h` out of the "YB includes" section to under "postgres.h" - Merge resolution: Retain locations of “ybc_pggate.h” and “ybcplan.h” that are already present YB-PG 15 - src/postgres/src/backend/optimizer/plan/createplan.c: - Location: “create_modifytable_plan” - My master commit adds a local variable `yb_is_single_row_update_or_delete` - YB-PG 15 has rearranged the location of the variable declarations - Merge resolution: Retain PG 15’s rearrangement, add my local variable - src/postgres/src/backend/executor/execIndexing.c: - Location: ExecInsertIndexTuples - My master commit updated function definition as per `executor/executor.h` - In YB-PG 15, YB introduced function `ExecInsertIndexTuplesOptimized` was deleted during the pg15 initial merge 55782d5, causing a conflict. - Merge resolution: Remove `no_update_index_list` arg from ExecInsertIndexTuples and remove `ExecInsertIndexTuplesOptimized`. - Location: ExecInsertIndexTuples - PG 15 introduced the notion of hints to the storage in case an index is not modified. Yugabyte does not require this as this computation is already being done (and enforced). - Merge resolution: The indexUnchanged hint will always evaluate to false for Yugabyte relations. Added a comment explaining this decision. - Location: ExecDeleteIndexTuples - My master commit updated function definition as per `executor/executor.h` - In YB-PG 15, an extra parameter `resultRelInfo` is added. - Merge resolution: Removed `ExecDeleteIndexTuplesOptimized` and subsumed functionality into `ExecDeleteIndexTuples` as there is no longer a difference between the two implementations from a function signature point of view. Added parameter `resultRelInfo` to ExecDeleteIndexTuples - src/postgres/src/backend/commands/copyfrom.c - Location: CopyFrom, CopyMultiInsertBufferFlush - Same context as above. - Merge resolution: Remove `no_update_index_list` from all invocations of `ExecInsertIndexTuples`. - src/postgres/src/backend/executor/execReplication.c - Location: ExecSimpleRelationInsert, ExecSimpleRelationUpdate - Same context as above. - Merge resolution: Remove `no_update_index_list` from all invocations of `ExecInsertIndexTuples`. - src/postgres/src/backend/executor/nodeModifyTable.c - Location: imports - My master commit adds `executor/ybOptimizeModifyTable.h` - YB-PG 15 moved imports from “YB includes” to “Yugabyte includes” and removed extra/unused imports - Merge resolution: Imports moved to “Yugabyte includes” and added `executor/ybOptimizeModifyTable.h` - Location: YBEqualDatums and YBBuildExtraUpdatedCols - Removed these functions as their functionality has moved to `executor/ybOptimizeModifyTable.h` - Location: ExecUpdate - My master commit introduces changes to compute a list of columns modified by the query for a given tuple - In YB-PG 15, ExecUpdate functionality has been broken into ExecUpdatePrologue, ExecUpdateAct, ExecUpdate and ExecUpdateEpilogue. - Merge resolution: Moved my changes into ExecUpdateAct and ExecUpdateEpilogue. - Location: ExecModifyTable - My master commit introduces a function to compute if a tuple in an UPDATE or a DELETE query has the “wholerow” junk attribute. - In YB-PG 15, this logic is propagated from planning time via `plan->ybHasWholeRowAttribute`. - Merge resolution: Use the logic in YB-PG 15. - Location: YBCHasWholeRowJunkAttr - Same context as above. - Merge resolution: Remove this function - Location: ExecInsert - Merge resolution: Remove `no_update_index_list` from four invocations of `ExecInsertIndexTuples`. - Location: YBExecUpdateAct - Not a conflict, but use of`ExecMaterializeSlot` has been changed to `ExecFetchSlotHeapTuple`. It is needed to copy the slot out to a HeapTuple in order to if columns are modified by the update query. - src/postgres/src/backend/rewrite/rewriteHandler.c - Location: YbAddWholeRowAttrIfNeeded - My master commit adds a new function `YbAddWholeRowAttrIfNeeded` - Conflict on PG side is upstream PG 41531e42d34f4aca117d343b5e40f3f757dec5fe and ed4653db8ca7a70ba7a4d329a44812893f8e59c2 adding code at end of rewriteValuesRTE. - Merge resolution: Remove all changes from YB master, retain YB-PG 15 changes. This removes functionality which will be re-evaluated and added back in a future diff. - src/include/executor/ybOptimizeModifyTable.h - Location: imports - Not a merge conflict, added a new include `nodes/execnodes.h` - Location: YbComputeModifiedColumnsAndSkippableEntities - Added a new arg `ResultRelInfo *` to specify the relation whose modified columns are to be computed. Previously, this info was fetched from EState which contained a single relation. - In YB-PG 15, Estate has been modified to include a list of relations. - src/postgres/src/backend/executor/ybOptimizeModifyTable.c - Location: YBEqualDatums - Not a merge conflict, but initialization of `FunctionCallInfoData` changed in YB-PG 15 for call information to be variable length (reference upstream PG commit `a9c35cf85ca1ff72f16f0f10d7ddee6e582b62b8`). - Changed this function to use new initialization. - Location: YbComputeModifiedColumnsAndSkippableEntities - Added a new arg `ResultRelInfo *` to specify the relation whose modified columns are to be computed. Previously, this info was fetched from EState which contained a single relation. - In YB-PG 15, Estate has been modified to include a list of relations. - src/postgres/src/backend/nodes/Makefile - Location: OBJS - My master commit adds `ybbitmatrix.o` object file. - In YB-PG 15, the list of objects was reformatted to have one object/file per line - Merge resolution: Added `ybbitmatrix.o` to the head of the list, retaining the new format - src/postgres/src/backend/executor/Makefile - Location: OBJS - Resolve as in ad2fedc for ybOptimizeModifyTable.o added by YB master **Background** Prior to this revision, an UPDATE statement specifying a list of target columns X in its SET clause, **always** performed the necessary work to update each of the target columns in the storage layer, irrespective of whether the values of the columns actually changed. The necessary work could include requiring locks, updating indexes, checking of constraints, firing of triggers etc. **The Optimization** This revision introduces an optimization that validates that the values of a column are indeed being modified, before sending (flushing) the updated value of the column to the storage layer. In particular, the set of columns whose values that are compared are those that can cause extra round trips to the storage layer in the form of: - Primary Key Updates - Secondary Index Updates - Foreign Key Constraints - Uniqueness Constraints The matrix of columns that are marked for update and the objects (indexes, constraints) they impact are computed at planning time. This is particularly useful when used in conjunction with prepared statements and ORMs, which tend to specify all columns (both modified and non-modified) as part of the target list. The decision of whether a column is indeed modified is done on a per-tuple basis at execution time. **Example** As a concrete example, consider a table with the following schema and data: ``` yugabyte=# CREATE TABLE foo (h INT PRIMARY KEY, v1 INT, v2 INT, v3 INT); yugabyte=# CREATE INDEX foo_v1_idx ON foo (v1); yugabyte=# CREATE INDEX foo_v2_idx ON foo (v2); yugabyte=# INSERT INTO foo (SELECT i, i, i % 10, i % 100 FROM generate_series(1, 10000) AS i); ``` Performing an UPDATE on the first 1000 rows (without the optimization) yields: ``` yugabyte=# SET yb_explain_hide_non_deterministic_fields TO true; yugabyte=# EXPLAIN (ANALYZE, DIST) UPDATE foo SET h = v1, v1 = v1, v3 = v3 + 1 WHERE v1 <= 1000; QUERY PLAN ------------------------------------------------------------------------------------------ Update on foo (cost=0.00..105.00 rows=1000 width=88) (actual rows=0 loops=1) -> Seq Scan on foo (cost=0.00..105.00 rows=1000 width=88) (actual rows=1000 loops=1) Remote Filter: (v1 <= 1000) Storage Table Read Requests: 1 Storage Table Rows Scanned: 10000 Storage Table Write Requests: 2000 Storage Index Write Requests: 4000 Storage Flush Requests: 2000 Storage Read Requests: 1 Storage Rows Scanned: 10000 Storage Write Requests: 6000 Storage Flush Requests: 2001 (12 rows) ``` The values of `h` and `v1` are not modified by the query, yet result in multiple write requests to both the main table as well as the secondary indices. Since updates to key columns (of a table or an index) is executed as a sequence of a DELETE followed by an INSERT, this query requires a large amount of flushes. This makes the query very expensive in terms of the amount of work to be done. With the proposed optimization the query is executed as follows: ``` yugabyte=# EXPLAIN (ANALYZE, DIST) UPDATE foo SET h = v1, v1 = v1, v3 = v3 + 1 WHERE v1 <= 1000; QUERY PLAN ------------------------------------------------------------------------------------------ Update on foo (cost=0.00..105.00 rows=1000 width=88) (actual rows=0 loops=1) -> Seq Scan on foo (cost=0.00..105.00 rows=1000 width=88) (actual rows=1000 loops=1) Remote Filter: (v1 <= 1000) Storage Table Read Requests: 1 Storage Rows Scanned: 10000 Storage Table Write Requests: 1000 Storage Read Requests: 1 Storage Rows Scanned: 10000 Storage Write Requests: 1000 Storage Flush Requests: 1 (10 rows) ``` **Flags and Feature Status** This revision introduces the following GUCs to control the behavior of this optimization: `yb_update_num_cols_to_compare` - The maximum number of columns to be compared. (default: 0) `yb_update_max_cols_size_to_compare` - The maximum size of an individual column that can be compared. (default: 10240) This feature is currently turned off as a result of setting `yb_update_num_cols_to_compare` to 0. **Debuggability** Turn on postgres debug2 logs via the following command: ``` ./bin/yb-ctl restart --ysql_pg_conf_csv='log_min_messages=debug2' ``` This produces the following debug information: ``` -- At planning time 2024-07-31 10:59:07.124 PDT [76120] DEBUG: Update matrix: rows represent OID of entities, columns represent attnum of cols 2024-07-31 10:59:07.124 PDT [76120] DEBUG: - 10 2024-07-31 10:59:07.124 PDT [76120] DEBUG: 17415 Y -- At execution time, on a per-tuple basis 2024-07-31 10:59:07.143 PDT [76120] DEBUG: Index/constraint with oid 17415 requires an update 2024-07-31 10:59:07.143 PDT [76120] DEBUG: Relation: 17412 Columns that are inspected and modified: 1 (10) 2024-07-31 10:59:07.143 PDT [76120] DEBUG: No cols in category: Columns that are inspected and unmodified 2024-07-31 10:59:07.143 PDT [76120] DEBUG: Relation: 17412 Columns that are marked for update: 1 (10) 2 (11) ``` **Future Work** 1. Introduce auto-flag infrastructure to safely use row-locking. This is in the context of upgrade safety while the cluster is being upgraded. 2. As a part of the flag infrastructure, ensure that flags/GUC values are immutable during the lifetime of a query. 3. #22994: PGSQL_UPDATEs with no column references should acquire row locks. 4. #23348: Add support for partitioned tables with out of order columns. 5. Support for serializing optimization metadata in plans. 6. Enhance randgen grammar to support ModifyTable (INSERT/UPDATE/DELETE ) queries 7. #23350: PG 15 support. jenkins: urgent Jira: DB-7701 Original commit: 63f471a / D34040 Test Plan: Run the associated pg_regress test as follows: ``` ./yb_build.sh --java-test 'org.yb.pgsql.TestPgRegressUpdateOptimized#schedule' ./yb_build.sh --java-test 'org.yb.pgsql.TestPgUpdatePrimaryKey' ./yb_build.sh --java-test 'org.yb.pgsql.TestPgUniqueConstraint' ./yb_build.sh --java-test 'org.yb.pgsql.TestPgRegressTrigger#testPgRegressTrigger' ./yb_build.sh --java-test 'org.yb.pgsql.TestPgRegressDml#testPgRegressDml' ./yb_build.sh --java-test 'org.yb.pgsql.TestPgRegressPushdown#testPgRegressPushdown' ``` Tested scenarios include (but not limited to): 1. Single row and distributed transactions with and without the feature flag turned on. 2. Relations with a primary key and no secondary indexes or triggers (UPDATEs can take the single row path) 3. Relations with combinations of primary key and secondary indexes. 4. Relations with unconditional before-row triggers. 5. UPDATEs in Colocated databases. 6. UPDATEs covering multiple tuples. 7. Hierarchy of relations with foreign keys 8. Relations with self referential foreign keys 9. Relations with overlapping indexes. 10. Relations having columns with uniqueness constraints. 11. Relations having covering indexes. 12. Relations having partial indexes. 13. Relations having index expressions / predicates. 14. Relations with conditional column triggers. 15. Relations having indexes/constraints out of order (ie. order of columns in relation is different from that of entity) 16. Relations having combination of hash and range indexes. 17. UPDATEs with correlated subqueries. 18. INSERT ON CONFLICT DO UPDATE. 19. UPDATE RETURNING. 20. UPDATEs on temp tables. Reviewers: jason, tfoucher Reviewed By: jason Subscribers: yql, smishra, jason, pjain Tags: #jenkins-ready Differential Revision: https://phorge.dev.yugabyte.com/D37350
…timizations are enabled Summary: D34040 introduced a framework to skip redundant secondary index updates and foreign key checks. As a part of the implementation, this revision skipped writing out unmodified columns to the main table. For correctness reasons, skipping writes of specific columns to the main table requires the acquisition of row-level locks. (In the event that no columns are modified, one is still required to acquire a row lock on the affected row) This created a dependency between the update optimization and the row locking feature. The latter is controlled by the autoflag `ysql_skip_row_lock_for_update`. This revision seeks to remove this dependency by continuing to write out unmodified columns to the main table. There is one notable exception to this behavior: unmodified columns that are a part of the primary key. If the value of the primary key remains unmodified, its columns are not written out to the main table as this would require an extra round trip to the storage layer. Jira: DB-7701 Test Plan: Run the following tests and ensure that there are no regressions: ``` ./yb_build.sh --java-test 'org.yb.pgsql.TestPgRegressUpdateOptimized#schedule' ``` Reviewers: amartsinchyk Reviewed By: amartsinchyk Subscribers: smishra, yql Tags: #jenkins-ready Differential Revision: https://phorge.dev.yugabyte.com/D37545
Summary: f8049b8 [doc][xcluster][2024.1.2] Semi-automatic transactional xCluster (#23710) f2c8470 [docs][yugabyted][2024.1.2] Add Read Replica and xCluster examples (#23289) ea3157c [doc][yba][2024.1.2] Export database audit logs (#23605) Excluded: 8bae488 [#18822] YSQL: Write out unmodified cols to main table when update optimizations are enabled 5012632 [PLAT-15152] Upgrade YBC client and server version to 2.2.0.0-b5 cccb1e1 Fix YCQL index table workflow in docs (#23774) 9a3f5f7 [PLAT-15028] yba installer simplify postgres initdb a2b5e72 [docs] Release notes for 2024.1.2.0 (#23679) 9a9690d Fix 2024.1.2 build number (#23779) aec361b [doc] Voyager 1.8 (#23764) a2540e0 [DEVOPS-3185, DEVOPS-3114] Bump up frozen pip modules to latest versions compatible with py3.8 88f23dd [docs] [xcluster] Add min version for semi-automatic mode (#23776) 1d61e67 Revise the entire assessment page (#23784) 142c04a [PLAT-15089] HA sync immediately after promotion 315110f [PLAT-15132][PLAT-15153] Allow users to configure logging level for YNP, also minor bug fixes 82ff8d1 [PLAT-6779] Handle relative paths in yb_platform_backup.sh Excluded: 45c9cf8 [#23263] YSQL, ASH: Instrument more wait states Excluded: 9f8acff [#22148] YSQL, QueryDiagnostics: Adding support for Ash data. 39670e8 download links (#23790) 2674a79 [#23780] YSQL: Modify catalog version mismatch test assertions with Connection Manager enabled 3eb31b8 [#23777] yugabyted: update the gflags of pg parity to remove sized based fetching and add bitmap scans. fc5accd [docs] Enclose `allowed_preview_flags_csv` CSV parameters in brackets (#23758) Test Plan: Jenkins: rebase: pg15-cherrypicks Reviewers: jason, tfoucher Differential Revision: https://phorge.dev.yugabyte.com/D37772
…o main table when update optimizations are enabled Summary: **Conflict resolution for PG 15 cherrypick** - src/postgres/src/backend/executor/nodeModifyTable.c - Location: ExecUpdate —> around `else if (IsYBRelation(resultRelationDesc))` - YB master 8bae4881dc89205c53ee3c62668c41347394af37 updates the comment explaining what `cols_marked_for_update` does. - In YB pg15 be8504df264aff0472e7e91264b095a30d068bf2, this code has moved into the function YBExecUpdateAct. - Merge resolution: Keep changes from YB pg15, manually update the comment in YBExecUpdateAct. - Location: ExecUpdate —> around `if (updateCxt.crossPartUpdate)` - YB master 8bae4881dc89205c53ee3c62668c41347394af37 frees the bitmapset `cols_marked_for_update`. - In YB pg15 be8504df264aff0472e7e91264b095a30d068bf2, this code has moved into the function YBExecUpdateAct. - Merge resolution: Keep changes from YB pg15, manually free the bitmapset in YBExecUpdateAct. D34040 introduced a framework to skip redundant secondary index updates and foreign key checks. As a part of the implementation, this revision skipped writing out unmodified columns to the main table. For correctness reasons, skipping writes of specific columns to the main table requires the acquisition of row-level locks. (In the event that no columns are modified, one is still required to acquire a row lock on the affected row) This created a dependency between the update optimization and the row locking feature. The latter is controlled by the autoflag `ysql_skip_row_lock_for_update`. This revision seeks to remove this dependency by continuing to write out unmodified columns to the main table. There is one notable exception to this behavior: unmodified columns that are a part of the primary key. If the value of the primary key remains unmodified, its columns are not written out to the main table as this would require an extra round trip to the storage layer. Jira: DB-7701 Original commit: 8bae488 / D37545 Test Plan: Run the following tests and ensure that there are no regressions: ``` ./yb_build.sh --java-test 'org.yb.pgsql.TestPgRegressUpdateOptimized#schedule' ``` Reviewers: jason, tfoucher Reviewed By: jason Subscribers: yql, smishra Tags: #jenkins-ready Differential Revision: https://phorge.dev.yugabyte.com/D37812
… optimization metadata Summary: D34040 introduced a framework to skip redundant secondary index updates and foreign key checks. As a part of this framework, metadata on skippable columns is computed at planning time and cached within the ModifyTable node. This carries the implication that the metadata may be cached as part of prepared statements and may be subject to serialization/deserialization. Consequently, this revision: - Adds a serialization/deserialization mechanism for update optimization metadata (specifically `YbUpdateAffectedEntities`; `YbSkippableEntities` was already implemented) - Adds a mechanism for determining equality for update optimization metadata (both `YbUpdateAffectedEntities`, `YbSkippableEntities`) - Adds tests around prepared statements with update optimizations enabled Jira: DB-7701 Test Plan: Run the following tests: ``` ./yb_build.sh --java-test 'org.yb.pgsql.TestPgRegressUpdateOptimized#schedule' ``` Additionally, the above test was run manually after adding the following line to test end-to-end serializability/deserializability: ```lang=diff --- a/src/postgres/src/backend/optimizer/plan/createplan.c +++ b/src/postgres/src/backend/optimizer/plan/createplan.c if (YbIsUpdateOptimizationEnabled() && ((!yb_is_single_row_update_or_delete && plan->operation == CMD_UPDATE) || (plan->operation == CMD_INSERT && plan->onConflictAction == ONCONFLICT_UPDATE))) { @@ -3491,6 +3492,7 @@ create_modifytable_plan(PlannerInfo *root, ModifyTablePath *best_path) RelationClose(rel); } + plan = stringToNode(nodeToString(plan)); return plan; } ``` Reviewers: amartsinchyk, telgersma Reviewed By: telgersma Subscribers: smishra, yql Tags: #jenkins-ready Differential Revision: https://phorge.dev.yugabyte.com/D37601
Summary: aec9a66 [doc][xcluster] Truncate limitation (#23833) fe8890d [PLAT-13984] Change default metric graph points count from 100 to 250 + make runtime configurable. 7d9b57b [#23869] YSQL: Fix one type of ddl atomicity stress test flakiness 7c1bca8 [PLAT-14052][PLAT-15237] :Add advanced date-time option,Restrict CP for K8s afce6ad [PLAT-14158] Support multiple transactional xCluster configs per universe on YBA UI 33342b3 [PLAT-15101] Add runtime config to turn on/off rollN for k8s 361a99a [#23809] CDCSDK: Filter out records corresponding to index tables in colocated DBs 8bbdf66 [docs] changed date (#23885) ee639f4 [#22104,#23506] YSQL: auto analyze service collects mutation counts from DDL and skips indexes 3dbf6da Delete architecture/design/multi-region-xcluster-async-replication.md e013578 [#23864] DocDB: Move cluster_uuid to server common flags 2b6a2d3 [PLAT-15062][PLAT-15071] Support DB scoped on UI and display schema change mode information 8260075 [PLAT-15079] Treat dropped on target tables as unconfigured but preselected f5169ca DocDB: Follow redirects for callhome, and fix URL eb61ef6 [PLAT-15228] Update package installation command for YBA e791c40 [#18822] YSQL: Add serialization/deserialization mechanism for update optimization metadata e69d8cb [doc] Backups and DDLs (#23840) e72ae64 [PLAT-14552]filter support bundle core files by date 8796c83 [PLAT-15274]: BackFill Pitr params for DR config and add not-null constraints in DB. dc9cc67 Fixed NPM test:ci build error 2e5ebef [PLAT-15287]: Add PITR Column and Restore Window Information to Backup List d053e45 [#238989]yugabyted: Node doesn't join using `--join` flag da4da45 [#23399] DocDB: Fix StopActiveTxnsPriorTo from using local variables in the call back Test Plan: Jenkins: rebase: pg15-cherrypicks Reviewers: jason, tfoucher Differential Revision: https://phorge.dev.yugabyte.com/D38008
Summary: D34040 introduced a framework to skip redundant secondary index updates and foreign key checks. This revision adds a PG preview flag `ysql_yb_update_optimization_infra` that keeps the feature turned OFF by default. Additionally, this revision restricts lookup to this flag to the following locations:. - Once, during query rewriting to determine to set the wholerow junk attribute - Once, at planning time to determine if optimization metadata needs to be computed - Once, at the beginning of query execution (`ExecInitModifyTable`) to determine if we should go ahead with the optimization. This has three possibilities: - The feature was enabled at planning time and disabled now (during query execution). In this case optimization is not performed. - The feature was disabled at planning time and enabled now. In this case, there is no metadata to perform the optimization and so the optimization is skipped. - The features was enabled at planning time and enabled now. In this case, metadata is available and the optimization is performed. To turn on the update optimization feature, do the following: - Append `ysql_yb_update_optimization_infra` to the list of flags in `allowed_preview_flags_csv` - Set the tserver gflag `ysql_yb_update_optimization_infra` to true. Jira: DB-7701 Test Plan: Run the following tests: ``` ./yb_build.sh --java-test 'org.yb.pgsql.TestPgRegressUpdateOptimized#schedule' ``` Reviewers: amartsinchyk Reviewed By: amartsinchyk Subscribers: ybase, smishra, yql Tags: #jenkins-ready Differential Revision: https://phorge.dev.yugabyte.com/D37746
Summary: 5d3e83e [PLAT-15199] Change TP API URLs according to latest refactoring a50a730 [doc][yba] YBDB compatibility (#23984) 0c84dbe [#24029] Update the callhome diagnostics not to send gflags details. b53ed3a [PLAT-15379][Fix PLAT-12510] Option to use UTC when dealing with cron exp. in backup schedule f0eab8f [PLAT-15278]: Fix DB Scoped XCluster replication restart 344bc76 Revert "[PLAT-15379][Fix PLAT-12510] Option to use UTC when dealing with cron exp. in backup schedule" 3628ba7 [PLAT-14459] Swagger fix bb93ebe [#24021] YSQL: Add --TEST_check_catalog_version_overflow 9ab7806 [#23927] docdb: Add gflag for minimum thread stack size Excluded: 8c8adc0 [#18822] YSQL: Gate update optimizations behind preview flag 5e86515 [#23768] YSQL: Fix table rewrite DDL before slot creation 123d496 [PLAT-14682] Universe task should only unlock itself and make unlock aware of the lock config de9d4ad [doc][yba] CIS hardened OS support (#23789) e131b20 [#23998] DocDB: Update usearch and other header-only third-party dependencies 1665662 Automatic commit by thirdparty_tool: update usearch to commit 240fe9c298100f9e37a2d7377b1595be6ba1f412. 3adbdae Automatic commit by thirdparty_tool: update fp16 to commit 98b0a46bce017382a6351a19577ec43a715b6835. 9a819f7 Automatic commit by thirdparty_tool: update hnswlib to commit 2142dc6f4dd08e64ab727a7bbd93be7f732e80b0. 2dc58f4 Automatic commit by thirdparty_tool: update simsimd to tag v5.1.0. 9a03432 [doc][ybm] Azure private link host (#24086) 039c9a2 [#17378] YSQL: Testing for histogram_bounds in pg_stats 09f7a0f [#24085] DocDB: Refactor HNSW wrappers 555af7d [#24000] DocDB: Shutting down shared exchange could cause TServer to hang 5743a03 [PLAT-15317]Alert emails are not in the correct format. 8642555 [PLAT-15379][Fix PLAT-12510] Option to use UTC when dealing with cron exp. in backup schedule 253ab07 [PLAT-15400][PLAT-15401][PLAT-13051] - Connection pooling ui issues and other ui issues 57576ae [#16487] YSQL: Fix flakey TestPostgresPid test bc8ae45 Update ports for CIS hardened (#24098) 6fa33e6 [#18152, #18729] Docdb: Fix test TestPgIndexSelectiveUpdate cc6d2d1 [docs] added and updated cves (#24046) Excluded: ed153dc [#24055] YSQL: fix pg_hint_plan regression with executing prepared statement Test Plan: Jenkins: rebase: pg15-cherrypicks Reviewers: jason, jenkins-bot Differential Revision: https://phorge.dev.yugabyte.com/D38322
…ehind preview flag Summary: **Conflict Resolution for PG15 cherrypick** - src/postgres/src/include/executor/ybOptimizeModifyTable.h: - Location: declaration of function`YbComputeModifiedColumnsAndSkippableEntities` - My master commit removes the param `ModifyTable *plan`, and adds the param `ModifyTableState *mtstate` - YB-PG 15 (commit df51270) adds the param `ResultRelInfo *` - Merge resolution: Remove param `ModifyTable *plan`, add params `ModifyTableState *mtstate`, `ResultRelInfo *`. Lint appropriately. - src/postgres/src/backend/executor/ybOptimizeModifyTable.c: - Location: definition of function function`YbComputeModifiedColumnsAndSkippableEntities` - Same conflict, resolution as above. - src/postgres/src/backend/executor/nodeModifyTable.c: - Location: ExecInitModifyTable - My master commit adds logic to compute the field `mtstate->yb_is_update_optimization_enabled` - This causes an adjacency conflict with YB-PG 15 (55782d5**)** - Merge resolution: Keep YB-PG 15 side of changes, add a newline, add logic + comment to compute the field `mtstate->yb_is_update_optimization_enabled` from master commit, remove the rest of the master commit hunk. - Location: ExecModifyTable around `else if (relkind == RELKIND_RELATION ...` - My master commit changes the params to function `YBCHasWholeRowJunkAttr`. - This causes a conflict with YB-PG 15 because this function call no longer exists. Refer resolution notes in df51270 - Merge resolution: Keep YB-PG 15 side of changes. - Location: declaration of YBCHasWholeRowJunkAttr - Same context as above. - Merge resolution: Keep YB-PG 15 side of changes. - Location: ExecUpdate - My master commit has changed the params to function`YbComputeModifiedColumnsAndSkippableEntities`. Refer above. - In YB-PG 15, this function call has moved to function `YBExecUpdateAct`. - Merge resolution: - Keep YB-PG 15 side of changes. - In `YBExecUpdateAct`, change param `plan` to `context->mtstate` in function call to `YbComputeModifiedColumnsAndSkippableEntities`. D34040 introduced a framework to skip redundant secondary index updates and foreign key checks. This revision adds a PG preview flag `ysql_yb_update_optimization_infra` that keeps the feature turned OFF by default. Additionally, this revision restricts lookup to this flag to the following locations:. - Once, during query rewriting to determine to set the wholerow junk attribute - Once, at planning time to determine if optimization metadata needs to be computed - Once, at the beginning of query execution (`ExecInitModifyTable`) to determine if we should go ahead with the optimization. This has three possibilities: - The feature was enabled at planning time and disabled now (during query execution). In this case optimization is not performed. - The feature was disabled at planning time and enabled now. In this case, there is no metadata to perform the optimization and so the optimization is skipped. - The features was enabled at planning time and enabled now. In this case, metadata is available and the optimization is performed. To turn on the update optimization feature, do the following: - Append `ysql_yb_update_optimization_infra` to the list of flags in `allowed_preview_flags_csv` - Set the tserver gflag `ysql_yb_update_optimization_infra` to true. Jira: DB-7701 Original commit: 8c8adc0 / D37746 Test Plan: Run the following tests: ``` ./yb_build.sh --java-test 'org.yb.pgsql.TestPgRegressUpdateOptimized#schedule' ``` Reviewers: jason, tfoucher, telgersma Reviewed By: telgersma Subscribers: yql, smishra, ybase Tags: #jenkins-ready Differential Revision: https://phorge.dev.yugabyte.com/D38388
…iew flag Summary: D34040 introduced a framework to skip redundant secondary index updates and foreign key checks. This revision adds a PG preview flag `ysql_yb_update_optimization_infra` that keeps the feature turned OFF by default. Additionally, this revision restricts lookup to this flag to the following locations:. - Once, during query rewriting to determine to set the wholerow junk attribute - Once, at planning time to determine if optimization metadata needs to be computed - Once, at the beginning of query execution (`ExecInitModifyTable`) to determine if we should go ahead with the optimization. This has three possibilities: - The feature was enabled at planning time and disabled now (during query execution). In this case optimization is not performed. - The feature was disabled at planning time and enabled now. In this case, there is no metadata to perform the optimization and so the optimization is skipped. - The features was enabled at planning time and enabled now. In this case, metadata is available and the optimization is performed. To turn on the update optimization feature, do the following: - Append `ysql_yb_update_optimization_infra` to the list of flags in `allowed_preview_flags_csv` - Set the tserver gflag `ysql_yb_update_optimization_infra` to true. Jira: DB-7701 Original commit: 8c8adc0 / D37746 Test Plan: Run the following tests: ``` ./yb_build.sh --java-test 'org.yb.pgsql.TestPgRegressUpdateOptimized#schedule' ``` Reviewers: amartsinchyk Reviewed By: amartsinchyk Subscribers: yql, smishra, ybase Tags: #jenkins-ready Differential Revision: https://phorge.dev.yugabyte.com/D38289
Summary: D34040 introduced an optimization to skip redundant index updates and foreign key checks. D37746 gated this feature behind a preview flag (feature is OFF by default) named `yb_update_optimization_infra`. This revision: - Promotes the preview flag to an auto flag of the same name. The auto flag is tagged as kLocalVolatile (has no impact on on-disk data). - Introduces an additional gflag `ysql_yb_skip_redundant_update_ops` to allow the feature to be enabled/disabled. The feature will be enabled by default when: - (brownfield) The cluster is upgraded to a version that has the above autoflag promoted. - (greenfield) The cluster is of a version that has this change. The feature can be disabled: - Clusterwide by setting the gflag `ysql_yb_skip_redundant_update_ops` to false. - On a per-session basis by the setting postgres GUC `yb_skip_redundant_update_ops` to false. Jira: DB-7701 Test Plan: Run Jenkins Reviewers: smishra, amartsinchyk Reviewed By: smishra Subscribers: ybase, yql Tags: #jenkins-ready Differential Revision: https://phorge.dev.yugabyte.com/D37749
Summary: 79a00fd [PLAT-15307]fix sensitive info leaks via Gflags cd26c93 [DOC-487] Voyager 1.8.2 changes (#24177) fa91de7 [docs] Apache Hudi integration with YSQL (#23888) 586d337 Updating DynamoDB comparison (#24216) aad5695 [#18822] YSQL: Promote autoflag to skip redundant update operations fa38152 Fix UBI image: Add -y option to install of hostname 6baf188 [#23998] Update third-party dependencies and enable SimSIMD in Usearch d57db29 Automatic commit by thirdparty_tool: update usearch to commit 191d9bb46fe5e2a44d1505ce7563ed51c7e55868. aab1a8b Automatic commit by thirdparty_tool: update simsimd to tag v5.4.3-yb-1. 161c0c8 [PLAT-15279] Adding unix timestamp to the core dump 17c45ff [#24217] YSQL: fill definition of a shell type requires catalog version increment 037fac0 [DB-13062] yugabyted: added banner and get started component 2eedabd [doc] Read replica connection load balancing support in JDBC Smart driver (#24006) 62a6a32 [#21467, #24153] Docdb: Add Read sequences as of time - sequences support for clone part 2 12de78e [PLAT-14954] added support for systemd-timesyncd 4a07eb8 [#23988] YSQL: Skip a table for schema comparison if its schema does not change d3fd39f [doc][ybm] Add reasoning behind no access to yugabyte user #21105 (#23930) 556ba8a [PLAT-15074] Install node agents on nodes for the marked universes for on-prem providers 9beb6dc [#22710][#22707] yugabyted: Update voyager migrations list landing page. (#22834) 6128137 [PLAT-15545] Simplify the frozen universe message for end user in YBA 4e36b78 JDBC Driver version update to 42.3.5-yb-8 (#24241) 254c979 [PLAT-15519]: Update xCluster sync to remove tables from YBA DB Test Plan: Jenkins: rebase: pg15-cherrypicks Reviewers: tfoucher, fizaa, telgersma Differential Revision: https://phorge.dev.yugabyte.com/D38624
…date operations Summary: **Note for 2024.2: The optimization to skip redundant index updates and foreign key checks is turned OFF by default is 2024.2.** This has been accomplished by setting the gflag `ysql_yb_skip_redundant_update_ops` to false. To enable this optimization, set the gflag to true. **Original Summary** D34040 introduced an optimization to skip redundant index updates and foreign key checks. D37746 gated this feature behind a preview flag (feature is OFF by default) named `yb_update_optimization_infra`. This revision: - Promotes the preview flag to an auto flag of the same name. The auto flag is tagged as kLocalVolatile (has no impact on on-disk data). - Introduces an additional gflag `ysql_yb_skip_redundant_update_ops` to allow the feature to be enabled/disabled. The feature will be enabled by default when: - (brownfield) The cluster is upgraded to a version that has the above autoflag promoted. - (greenfield) The cluster is of a version that has this change. The feature can be disabled: - Clusterwide by setting the gflag `ysql_yb_skip_redundant_update_ops` to false. - On a per-session basis by the setting postgres GUC `yb_skip_redundant_update_ops` to false. Jira: DB-7701 Original commit: aad5695 / D37749 Test Plan: Run Jenkins Reviewers: smishra, amartsinchyk Reviewed By: smishra Subscribers: yql, ybase Tags: #jenkins-ready Differential Revision: https://phorge.dev.yugabyte.com/D38598
…s in 2024.2 by default Summary: Timeline: - D34040 introduced an optimization to skip redundant index updates and foreign key checks. - D37746 gated this feature behind a preview flag (feature is OFF by default) named `yb_update_optimization_infra`. - D37749 introduced a feature enablement flag `ysql_yb_skip_redundant_update_ops`, and promoted the above preview flag to an auto flag. - D38598 backported the changes of D37749 to 2024.2, while keeping the feature enablement flag turned OFF (the flag is on in master, by default) This revision turns on the feature by default in 2024.2 by turning ON the feature enablement flag `ysql_yb_skip_redundant_update_ops`. Jira: DB-7701 Test Plan: Run Jenkins Reviewers: smishra, amartsinchyk Reviewed By: smishra Subscribers: yql, ybase Tags: #jenkins-ready Differential Revision: https://phorge.dev.yugabyte.com/D38936
Summary: We figured out that INSERT .. ON CONFLICT UPDATE failed to properly update a secondary index. It looks like the problem is because of index update optimization, which is enabled by default. To mitigate the problem we disable the optimization by default. Revert "[#18822] YSQL: Enable optimization to skip redundant update operations in 2024.2 by default" This reverts commit 92e026f. Jira: DB-14205 Test Plan: Jenkins: urgent Reviewers: kramanathan, smishra Reviewed By: smishra Subscribers: ybase, yql Differential Revision: https://phorge.dev.yugabyte.com/D40300
…index Summary: Original commit: 0529391 / D40300 We figured out that INSERT .. ON CONFLICT UPDATE failed to properly update a secondary index. It looks like the problem is because of index update optimization, which is enabled by default. To mitigate the problem we disable the optimization by default. Revert "[#18822] YSQL: Enable optimization to skip redundant update operations in 2024.2 by default" This reverts commit 92e026f. Jira: DB-14205 Test Plan: Jenkins: urgent Reviewers: kramanathan, smishra Reviewed By: smishra Subscribers: yql, ybase Tags: #jenkins-ready Differential Revision: https://phorge.dev.yugabyte.com/D40304
…e index Summary: Original commit: 0529391 / D40300 We figured out that INSERT .. ON CONFLICT UPDATE failed to properly update a secondary index. It looks like the problem is because of index update optimization, which is enabled by default. To mitigate the problem we disable the optimization by default. Revert "[#18822] YSQL: Enable optimization to skip redundant update operations in 2024.2 by default" This reverts commit 92e026f. Jira: DB-14205 Test Plan: Jenkins: urgent Reviewers: kramanathan, smishra Reviewed By: smishra Subscribers: yql, ybase Tags: #jenkins-ready Differential Revision: https://phorge.dev.yugabyte.com/D40305
Summary: We figured out that INSERT .. ON CONFLICT UPDATE failed to properly update a secondary index. It looks like the problem is because of index update optimization, which is enabled by default. To mitigate the problem we disable the optimization by default. Revert "[yugabyte#18822] YSQL: Enable optimization to skip redundant update operations in 2024.2 by default" This reverts commit 92e026f. Jira: DB-14205 Test Plan: Jenkins: urgent Reviewers: kramanathan, smishra Reviewed By: smishra Subscribers: ybase, yql Differential Revision: https://phorge.dev.yugabyte.com/D40300
…#25112) * changes to add transaction ordering deprecation * doc update for CDC * add missing content * added note * addressed review comments * addressed review comments * changed note type to warning * made edits and removed 2024.2 changes * reverted change for 2024.2 * Apply suggestions from code review Co-authored-by: Dwight Hodge <[email protected]> * [PLAT-16160]Add runtime conf flag for Off-cluster PITR AcceptedPublic Summary: Converted the feature flag to runtime flag. Show New scheduled Policy UI when 'yb.ui.feature_flags.off_cluster_pitr_enabled' is enabled and hide the old one. Show PITR column in backup list when 'yb.ui.feature_flags.off_cluster_pitr_enabled' is enabled and hide the old one. Test Plan: Tested manually Reviewers: lsangappa Reviewed By: lsangappa Subscribers: yugaware Differential Revision: https://phorge.dev.yugabyte.com/D40136 * [#24876] CDC: Cleanup metrics for deleted state table entries Summary: Currently we do not remove metrics corresponding to the deleted state table entries, for example, on deleting a CDC stream. These metrics hang around until there's a tserver restart. This might cause any external applications to read false values for metric objects which do not exist. This diff introduces code changes which address the above issue by deleting the metric entity when the corresponding CDC stream is deleted. Jira: DB-13995 Test Plan: The following tests have been introduced: ``` ./yb_build.sh --cxx-test cdcsdk_ysql-test --gtest_filter CDCSDKYsqlTest.TestCDCMetricRemovalUponStreamDeletion ./yb_build.sh --cxx-test cdcsdk_ysql-test --gtest_filter CDCSDKYsqlTest.TestCDCMetricRemovalUponSlotDeletionForLogicalReplication ./yb_build.sh --cxx-test cdcsdk_ysql-test --gtest_filter CDCSDKYsqlTest.TestMetricObjectRemovalAfterStreamExpiration ``` Reviewers: skumar, sumukh.phalgaonkar, siddharth.shah Reviewed By: sumukh.phalgaonkar Subscribers: ycdcxcluster Differential Revision: https://phorge.dev.yugabyte.com/D40055 * [#25057] YSQL,QueryDiagnostics: Fix testYbQueryDiagnosticsStatus Summary: testYbQueryDiagnosticsStatus has been failing due to a bug within pg_mkdir_p function. Current diff handles the bug and formats the test. Jira: DB-14188 Test Plan: ./yb_build.sh --java-tests 'org.yb.pgsql.TestYbQueryDiagnostics#testYbQueryDiagnosticsStatus' Reviewers: asaha Reviewed By: asaha Subscribers: yql Differential Revision: https://phorge.dev.yugabyte.com/D40209 * [#25111] CDC: Fix cleanup tests flakiness Summary: The test utility method CDCSDKYsqlTest::CheckTabletsInCDCStateTable() tries to get all the state table entries with non-max checkpoint and compare their equality with the expected set of entries. However when this method tries to filter out max checkpoint entries it incorrectly handles the optional checkpoint field in state table row entry. Because of this the filtering logic does not work and leads to test flakiness. This diff fixes the incorrect handling of the optional field. Jira: DB-14258 Test Plan: Jenkins: test regex: .*CDC.* Reviewers: skumar, siddharth.shah Reviewed By: siddharth.shah Subscribers: ycdcxcluster Tags: #jenkins-ready Differential Revision: https://phorge.dev.yugabyte.com/D40311 * Fix swaggerGen on master Summary: UTs are broken on master due to missing swagger Gen run. Test Plan: N/A Reviewers: skurapati Reviewed By: skurapati Subscribers: yugaware Differential Revision: https://phorge.dev.yugabyte.com/D40326 * [#24886] YSQL: Fix major catalog upgrade for colocated tables Summary: Upgrade of colocated tables was failing because 1) The OID for the tablegroup for the table wasn't being properly restored. 2) YB properties including the colocation ID weren't being dumped by ysql_dump. Fix both issues, and add a test. Jira: DB-14006 Test Plan: Jenkins ./yb_build.sh release --cxx-test pg15_upgrade-test --gtest_filter Pg15UpgradeTest.ColocatedTables --with_tests Reviewers: telgersma, fizaa Reviewed By: telgersma Subscribers: yql Differential Revision: https://phorge.dev.yugabyte.com/D40260 * [#25075] YSQL: ON CONFLICT fails to properly update index Summary: We figured out that INSERT .. ON CONFLICT UPDATE failed to properly update a secondary index. It looks like the problem is because of index update optimization, which is enabled by default. To mitigate the problem we disable the optimization by default. Revert "[#18822] YSQL: Enable optimization to skip redundant update operations in 2024.2 by default" This reverts commit 92e026f33cd3215d348449d070b1c90f0916d063. Jira: DB-14205 Test Plan: Jenkins: urgent Reviewers: kramanathan, smishra Reviewed By: smishra Subscribers: ybase, yql Differential Revision: https://phorge.dev.yugabyte.com/D40300 * [PLAT-13992] Remove forbidden to override flags (GflagsUtil.java) from gflags UI Summary: Removing gflags that are forbidden to override from UI (The request will fail anyway if the user attempts to set them) Test Plan: check if UI shows flags Reviewers: vbansal Reviewed By: vbansal Subscribers: yugaware Differential Revision: https://phorge.dev.yugabyte.com/D40252 * [#25043] YSQL: Fix flakey YbGinIndex upgrade test Summary: https://github.com/yugabyte/yugabyte-db/issues/20959 describes what is basically an expected race condition for DDLs. The test consistently fails if I increase the number of times we drop / create the indexes: ```lang=diff --- src/yb/integration-tests/upgrade-tests/pg15_upgrade-test.cc +++ src/yb/integration-tests/upgrade-tests/pg15_upgrade-test.cc @@ -1296,12 +1296,14 @@ TEST_F(Pg15UpgradeTest, YbGinIndex) { auto conn = ASSERT_RESULT(cluster_->ConnectToDB()); ASSERT_NO_FATALS(check_and_insert_rows(conn, num_rows)); - // test dropping and recreating the indexes, to validate that these DDLs - // still work as expected in pg15 - for (const auto &index : kGinIndexes) { - ASSERT_OK(conn.ExecuteFormat("DROP INDEX $0", index.first)); + for (int i = 0; i < 10; i++) { + // test dropping and recreating the indexes, to validate that these DDLs + // still work as expected in pg15 + for (const auto &index : kGinIndexes) { + ASSERT_OK(conn.ExecuteFormat("DROP INDEX $0", index.first)); + } + ASSERT_NO_FATALS(create_indexes_with_retry()); } - ASSERT_NO_FATALS(create_indexes_with_retry()); ASSERT_NO_FATALS(check_and_insert_rows(conn, num_rows)); } ``` Randomly, when creating an index, the test would fail with the error ``` [Not found (yb/master/catalog_manager.cc:11601): LookupByIdRpc(tablet: a70099ab24ae47c79b8b41f879536f01, num_attempts: 1) failed: Tablet deleted: Table deleted at 2024-11-25 09:17:36 EST (split child tablet IDs [])] (pgsql error XX000) (aux msg ERROR: ERROR: [Not found (yb/master/catalog_manager.cc:11601): LookupByIdRpc(tablet: a70099ab24ae47c79b8b41f879536f01, num_attempts: 1) failed: Tablet deleted: Table deleted at 2024-11-25 09:17:36 EST (split child tablet IDs [])]) ``` Retrying the `CREATE INDEX` statements when they fail avoids this error. Jira: DB-14177 Test Plan: On mac and my devserver: ``` ./yb_build.sh release --cxx-test pg15_upgrade-test --gtest_filter Pg15UpgradeTest.YbGinIndex -n 60 ``` Jenkins: test regex .*YbGinIndex.* Reviewers: fizaa Reviewed By: fizaa Subscribers: yql Differential Revision: https://phorge.dev.yugabyte.com/D40255 * [#25000] xCluster: Fix xcluster_upgrade-test Summary: When AutoFlags are promoted or demoted, the tservers are notified only on the next heartbeats. The xCluster tets wait for xCluster to receive and process these AutoFlags configs, but do not wait for the source tservers to even receive them. This fix addresses this issue by reducing the heartbeat time, and forcing a sleep after every AutoFlags change. Fixes #25000 Jira: DB-14144 Test Plan: xcluster_upgrade-test Reviewers: jhe, slingam, xCluster Reviewed By: jhe Subscribers: ybase Differential Revision: https://phorge.dev.yugabyte.com/D40189 * [PLAT-16198] Ansible error parsing in shell process handler does not work Summary: It was parsing the wrong input to find the ansible task error. Ansible task errors are in stderr. Python error is in stdout. Test Plan: Manually tested by failing the ansible tasks. Screenshots attached. Also tested by copying the tmp output files locally. Before this fix: {F313328} With this fix: {F313329} Reviewers: amalyshev, cwang, nbhatia, muthu, svarshney Reviewed By: svarshney Subscribers: yugaware Differential Revision: https://phorge.dev.yugabyte.com/D40310 * [#24829] CDC: Fix GetChanges WAL segment reading and computation of safe hybrid time for GetChanges resposne Summary: During a CDC QA run, we encountered a data loss scenario caused by an interaction between transaction commit timing and WAL segment rollover. WAL segment 'X' was active when transaction 'T' was still a running transaction. Due to concurrent segment rollover, the transaction's APPLY operation was appended in the subsequent segment 'X+1'. The following sequence of events led to data loss: 1. Initial GetChanges Request: - Requested opid index present in segment 'X' - No CDC related WAL OPs were found in segment 'X' between [requested op id index, last index in 'X'] - `committed_op_id_index` (pointed to last index of segment 'X') lagged behind `majority_replicated_op_id_index`, hence we did not scan segment 'X+1'. - Finally, we returned empty response with incorrect safe hybrid time (=tablet leader safe time) 2. Subsequent GetChanges Request: - Successfully read segment 'X+1' ( as committed_op_id_index had advanced to segment 'X+1') - UPDATE_TXN_OP of transaction 'T' was read but CDC filtered it out as we do not ship WAL OPs having commit_time < previously returned safe hybrid time - Resulted in transaction 'T' never being shipped. Root Cause: We violated a critical invariant: the tablet leader safe time should only be returned in GetChanges responses after reading the entire WAL. But in the 1st Getchanges call, we returned the tablet leader safe time having only read till segment 'X', leading to improper transaction filtering and subsequent data loss. This diff makes the following changes to fix the above mentioned data loss issue: 1. When reading the WAL segment by segment, we will now wait for the `committed_op_id_index` to be >= last index in the segment. If the deadline is reached while waiting, we will return 0 WAL ops and indicate to wait for WAL update. 2. Identification of active segment in GetConsistentWALRecords has been changed. Earlier, we were inferring active segment by the value of `consistent_stream_safe_time_footer`. If it was kInvalid, then we concluded its an active segment. But because of changes in 1), that conclusion no longer holds true. If we reach the deadline while waiting for `committed_op_id_index` to be >= last index in segment, then the value of `consistent_stream_safe_time_footer` will still be invalid. Hence, we are now using a dedicated variable (`read_entire_wal`) that will notify if we actually read the active segment in `ReadReplicatedMessagesInSegmentForCDC()`. 3. Value of `safe_hybrid_time` returned in GetChanges response. We have the following scenarios which will decide the safe_hybrid_time sent in the response: - **Case-1**: Read the active segment -> return the last record's commit_time if valid records are found. Else, return tablet leader safe time (existing logic). - **Case-2**: Deadline reached while waiting for `committed_op_id_index` to be >= last index in the WAL segment. There are 2 ways in which we can reach deadline. For both these ways, we want to wait for WAL to be updated. - Deadline reached after reading multiple segments -> return request safe hybrid time. - Deadline reached on the 1st segment read in GetChanges call -> return request safe hybrid time. - **Case-3:** requested index (from_op_id_index) >= `committed_op_id_index` - If all RAFT replicated Ops are not yet APPLIED (i.e. `committed_op_id_index` != `majority_replicated_op_id_index`), then we indicate to wait for WAL update and return request safe hybrid time. - If all RAFT replicated OPs are also APPLIED (i.e. `committed_op_id_index` == `majority_replicated_op_id_index`), then we have following scenarios: - If the condition in case-3 was hit after reading multiple segments, then return footer value (`min_start_time_running_txns`) of last read segment. - If the condition in case-3 was hit on the 1st segment read in GetChanges call, then return tablet leader safe time as this particular case implies we have read the entire WAL. Additionally, we have added a WARNING log when the invariant for response safe time is broken. Jira: DB-13935 Test Plan: Jenkins Reviewers: skumar, sumukh.phalgaonkar Reviewed By: skumar Subscribers: ybase, ycdcxcluster Tags: #jenkins-ready Differential Revision: https://phorge.dev.yugabyte.com/D39925 * [PLAT-16194] Adding preflight check for python3.10/3.11 Summary: With recent changes to upgrade Ansible D32451 we now require python 3.10 or 3.11 on the node to run YBA. This diff updates the python check to only accept 3.10 or 3.11. We also can move the openSSL check to its own check as we don't need to conditionally perform it based on the python version, it is part of the base requirements (as it was only relevant for python 3.10+ anyways). Test Plan: run check on node without python3.10 or 3.11, install python3.11 and ensure check passes Reviewers: dshubin, sanketh Reviewed By: dshubin Subscribers: yugaware Differential Revision: https://phorge.dev.yugabyte.com/D40298 * [#25107] xCluster: RemoveNamespaceWhenSourceIsDown: Skip health checks when source is down Summary: When source is down the health check will fail, so disable it during validation. Fix DropAllTables to wait for safe time to be healthy before checking row counts. Fixes #25107 Jira: DB-14253 Test Plan: XClusterDBScopedTest.RemoveNamespaceWhenSourceIsDown XClusterDBScopedTest.DropAllTables Reviewers: jhe, xCluster Reviewed By: jhe Subscribers: ybase Differential Revision: https://phorge.dev.yugabyte.com/D40306 * [#25103] DocDB: Handle multiple splits, PITR restores and drop table correctly Summary: This change fixes one scenario that https://github.com/yugabyte/yugabyte-db/commit/79a69958177d did not handle completely resulting in a FATAL after multiple splits and PITR restores in the following sequence: # t0 - Only tablet T11 exists. # t1 - T11 splits into T12, T13. # t2 - PITR restore is performed to t0 which brings back T11 and hides T12, T13 with hide time - t2. # t3 - T11 again splits into T14, T15 at the same partition key boundaries as T12,T13. T11 is marked as hidden with hide time - t3 # t4 - Table gets dropped hiding - T14, T15 with hide time - t4. # t5 - PITR is performed to t4+ which reloads the syscatalog. # At this point the following tablets exist in hidden state with different hide times: T11(t3), [T12(t2),T13(t2)], [T14(t4),T15(t4)]. Attempts to load [T12(t2),T13(t2)] and [T14(t4),T15(t4)] which have the same key ranges and split depth results in the following fatal: ``` Failed to load sys catalog: Illegal state (yb/master/catalog_entity_info.cc:654): Failed while visiting tablets in sys catalog: System catalog snapshot is corrupted or built using different build type: TabletInfo object freed during load: Two tablets with the same partition key start and split depth: committed_consensus_state ``` Added a unit-test for this and it fails without the fix. **Fix: ** The fix is to avoid adding any tablets that were marked hidden even before the table is dropped to the partitions_ structure. This ensures that on a drop table, only the set of tablets that were active are added to the partitions_ structure. Jira: DB-14249 Test Plan: ybt yb-admin-snapshot-schedule-test YbAdminSnapshotScheduleTest.ReadsWithMultipleSplitsPitrsAndDrop Reviewers: zdrudi, asrivastava Reviewed By: zdrudi Subscribers: tfoucher, ybase Differential Revision: https://phorge.dev.yugabyte.com/D40314 * [#25072] DocDB: Fix false corruption detection during colocated index read Summary: When index is colocated to the indexed table we perform index read using single query. At the first step the index table is read, to fetch row keys from the indexed table. On the second step indexed table is read using those keys. If row key does not exist on the second step, the corruption is being reported. It could happen that transaction apply happens in parallel to read and this row was just removed by recently committed transaction. So read finds this row on the first step, but does not see it on the second step raising the corruption error. Actually read restart mechanism detects that read is not consistent and should be restarted. But this particular corruption detection logic ignores read restart. The failure message looks like this one: ``` ERROR: ybctid DocKey([], [16754]) not found in indexed table. index table id is 00004007000030008000000000000a76 ``` Fixed by checking read restart before reporting such corruption. Updated param naming in PgDdlAtomicityStressTest to be more used friendly. Also fixed the following issues found by this test: 1) Potential crash because of head use after free if AbortTransaction response is received during tablet shutdown. 2) TServer could wait until OpenTable timeout (2min) during shutdown. 3) TServer could wait tablet validation timeout (2min) during shutdown. Jira: DB-14202 Test Plan: ./yb_build.sh fastdebug --gcc11 --gtest_filter PgDdlAtomicityStressTest.Main/colocated -n 20 Reviewers: myang, dmitry Reviewed By: myang Subscribers: dmitry, yql, ybase Tags: #jenkins-ready Differential Revision: https://phorge.dev.yugabyte.com/D40235 * [PLAT-16203]Skip running prechecks if Node2Node certs have expired Summary: We should skip running prechecks if certificates have expired. This will otherwise block rotate certs tasks on a univers e Test Plan: Tested locally by rotating certificates on a universe with expired certs Reviewers: svarshney, nsingh, nbhatia Reviewed By: svarshney, nbhatia Subscribers: yugaware Differential Revision: https://phorge.dev.yugabyte.com/D40331 * [PLAT-16202] Use the tmp_directory configured in ynp config file Summary: Use the tmp_directory configured in ynp config file Test Plan: Manually tested script files are generated at the specified directory Reviewers: nbhatia, skhilar Reviewed By: nbhatia Subscribers: yugaware Differential Revision: https://phorge.dev.yugabyte.com/D40324 * [#23331] yugabyted: Add pg_isready check to start and status command. Summary: * Added the check pg_isready for each node during start and status command. * Added the field `YSQL Status` in the status string displayed during start and status command. * During the restart of a cluster if a node is in Bootstrapping step, yugabyted status will return the same status for `YSQL Status` * Added a new `Output.ANIMATION_STOP` status for Output.update_animation() function. * Giving `Output.ANIMATION_STOP` and empty msg string to Output.update_animation() will remove the spinner that was started with Output.init_animation(). Jira: DB-12256 Test Plan: Manual Testing Reviewers: nikhil Reviewed By: nikhil Subscribers: sgarg-yb Differential Revision: https://phorge.dev.yugabyte.com/D34597 * [PLAT-13112]Block deletion of in use-releases Summary: Adding finalizers in ReleaseReconciller.onAdd() to block deletion of in-use releases. Removing finalizers in ReleaseReconciller.onDelete() and after ybuniverse gets deleted. Test Plan: Tested following scenarios - - Created a release -> check finalizers present in cr -> Delete release - Created a release -> Create universe -> delete release (blocked) -> Delete universe -> Release gets GC'ed - Created a release -> Create universe -> Delete universe -> Release stays active Reviewers: anijhawan, vkumar Reviewed By: vkumar Subscribers: yugaware Differential Revision: https://phorge.dev.yugabyte.com/D37451 * [#24293] YSQL, QueryDiagnostics: Fix PgssReset test Summary: D39523 revision enabled ASH by default, which started raising extra warning messages for `testPgssResetBetweenDiagnostics` test, thereby failing assertions. Current diff disables ASH for certain tests. Jira: DB-13182 Test Plan: ./yb_build.sh --java-test 'org.yb.pgsql.TestYbQueryDiagnostics#testPgssResetBetweenDiagnostics' Reviewers: asaha Reviewed By: asaha Differential Revision: https://phorge.dev.yugabyte.com/D40126 * [#25004] YSQL: Fix the backend type of the physical connection in ysql conn mgr Summary: Post pg15 merge into the master, the type/name of backends created for physical connections in transaction pool are coming to be client backend instead of yb-conn-mgr worker connection. This diff fixes this issue. Fix Based on value of the guc variable `yb_is_client_ysqlconnmgr`, the type of backend is set to yb-conn-mgr worker connection or client backend. While parsing the startup packet of the transactional backend process, the guc variables coming in the startup packet are not yet processed (they are processed in later stage of initialization of the backend). Therefore, in this diff during parsing of the startup packet itself, `yb_is_client_ysqlconnmgr` guc variable is been set and based on it's correct value the type of backend is assigned. This diff also fixes one of implementation gap while making the connections sticky when client executes SET stmt to set "session_authorization" and "role" guc variables. Jira: DB-14148 Test Plan: Jenkins: enable connection manager, all tests Reviewers: skumar, rbarigidad, vpatibandla, stiwary Reviewed By: stiwary Subscribers: svc_phabricator, yql Differential Revision: https://phorge.dev.yugabyte.com/D40323 * [#25094] yugabyted: Fix yugabyted UI slow queries page due to pg15 pg_stat_statements changes Summary: The query used to get slow queries in the yugabyted UI API server queries `pg_stat_statements`. Some of the column names were changed from `total_time, min_time, max_time, mean_time, stddev_time` to `total_exec_time, min_exec_time, max_exec_time, mean_exec_time, stddev_exec_time` in pg15 and need to be changed in the query as well. Jira: DB-14240 Test Plan: manual tests Reviewers: sgarg-yb, nikhil Reviewed By: sgarg-yb Subscribers: yugabyted-dev, djiang Differential Revision: https://phorge.dev.yugabyte.com/D40303 * [#25118] DocDB: Fix org.yb.pgsql.TestPgRegressThirdPartyExtensionsPgvector#schedule Summary: Commit bbf8c1288a87a15be2913fb1a665c0740b9de85c/D40131 contains debug leftover with CHECK, that is causing ybdummyann tests to fail. Fixed by removed this check and adjusting logic in PgsqlReadOperation::ExecuteVectorSearch. Jira: DB-14263 Test Plan: org.yb.pgsql.TestPgRegressThirdPartyExtensionsPgvector#schedule Reviewers: slingam, arybochkin Reviewed By: slingam, arybochkin Subscribers: svc_phabricator, ybase, yql Tags: #jenkins-ready Differential Revision: https://phorge.dev.yugabyte.com/D40336 * [#24647] YSQL: In major catalog upgrade, avoid reading current version catalog before it's valid Summary: During normal operation of a YB universe, the YB master itself sometimes references PG catalog tables. For example, both during CreateTable and as a periodic refresh, it references pg_tablespace, and as a periodic task it reads from pg_database. In the existing code, during a ysql major catalog upgrade, the master will generate table UUIDs for the current ysql major catalog version for these tables, even though they may not exist or be fully populated yet. Modify the YB master code to read from prior ysql major catalog version tables until the current ysql major catalog version tables are valid. Note that as a side effect, this allows us to consolidate and simplify the logic to read from the correct table to retrieve the current per-db catalog versions (not to be confused with "ysql major catalog version," our terminology for PG11 or PG15) during the upgrade. After this commit, you may need to reinitdb, if you haven't done so in a while, to pick up a catalog snapshot that correctly holds the current version in ysql_major_catalog_upgrade_info.catalog_version. Jira: DB-13711 Test Plan: Jenkins On MacOS 14 arm64: ./yb_build.sh release --cxx-test integration-tests_basic_upgrade-test --gtest_filter UpgradeFrom_2_25_0_0/BasicUpgradeTest.TestUpgrade/0 --with_tests ./yb_build.sh fastdebug --cxx-test integration-tests_basic_upgrade-test --gtest_filter UpgradeFrom_2_25_0_0/BasicUpgradeTest.TestUpgrade/0 --with_tests (to test builds.xml builds for Mac debug, primarily, because that build flavor isn't exercised by the automated tests right now) Reviewers: hsunder Reviewed By: hsunder Subscribers: hsunder, smishra, ybase, yql Differential Revision: https://phorge.dev.yugabyte.com/D39813 * [#25129] DocDB: Increase PgPartmanTest test timeout in ASAN mode Summary: PgPartmanTest performs hundreds of table modification tasks, it takes significant amount of time especially in ASAN mode. So those tests does not fit into default timeout: PgPartmanTest.TestIdTimeSubpartNative PgPartmanTest.TestIdTimeSubpartCustomStartNative Increased timeout to 1200 seconds in ASAN mode Jira: DB-14279 Test Plan: ./yb_build.sh asan --gtest_filter PgPartmanTest.TestIdTimeSubpartNative ./yb_build.sh asan --gtest_filter PgPartmanTest.TestIdTimeSubpartCustomStartNative Reviewers: devansh.saxena, skumar Reviewed By: devansh.saxena Subscribers: yql, ybase Tags: #jenkins-ready Differential Revision: https://phorge.dev.yugabyte.com/D40356 * [#23901] YSQL, ASH: Sample background workers Summary: This diff adds support for sampling YSQL background workers. Summary of changes - - Add a new const query id for YSQL background workers - While deciding whether to consider a backend for sampling or not, we now only check for `MyProc->yb_is_ash_metadata_set` - The CPU wait event name in YSQL is changed from `QueryProcessing` to `OnCpu_Active` because now we also have background workers which may not be executing queries - We no longer take locks while setting root_request_id, client_node_ip, pid, more details in code comments - We don't sample the ASH collector itself because it will always show CPU events - kQueryIdForCatalogRequests is renamed to kQueryIdForUncomputedQueryId as this is more accurate name - Two sync RPCs CronGetLastMinute and CronSetLastMinute called from the pg_cron background worker are now also instrumented **Upgrade/Rollback safety:** Safe to upgrade/rollback, if ASH metadata is not found in the PB, then metadata in the threadlocal wait state object is not updated. If ASH metadata is sent, and the other tserver is still on old version, it will simply ignore and continue doing it's work Jira: DB-12805 Test Plan: ./yb_build.sh --cxx-test pg_ash-test --gtest_filter PgBgWorkersTest.ValidateBgWorkers ./yb_build.sh --cxx-test pg_ash-test --gtest_filter PgWaitEventAuxTest.PgCronRPCs Reviewers: hsunder Reviewed By: hsunder Subscribers: smishra, yql, ybase Differential Revision: https://phorge.dev.yugabyte.com/D39062 * [DOCS] python Smart Driver (psycopg2) docs update for RR support (#25074) * [#25119] Revert `yb_amiscoveredbymaintable` related changes Summary: This reverts changes related to `yb_amiscoveredbymaintable` in b4ef0c523359e3572c2bc3f619780cacf6edbbde and .b9b57c6f791cb9f28d8bec9372e9a433a903980c in line with the most up to date requirements for index co-partitioning. In the previous design, co-partitioned indexes were meant to share almost all metadata and storage with the main table. The currently implemented design for co-partitioning in docdb creates such indexes a different way. Co-partitioned indexes on creation create new data storage but get colocated with their respective main tables in a mechanism similar to the existing colocation index creation. This change reverts any remnants of the previous design on the query layer to allow for this redesign. b9b57c6f791cb9f28d8bec9372e9a433a903980c had a few conflicts with this change that modified some call-sites of `YBIsCoveredByMainTable`. Test Plan: Jenkins Reviewers: telgersma, jason, fizaa Reviewed By: telgersma Subscribers: yql, ybase Differential Revision: https://phorge.dev.yugabyte.com/D40340 * Revert "[PLAT-13112]Block deletion of in use-releases" Summary: This reverts commit af1bdd97294f8bda926ae38c1a08186b0d419d24/D37451 since it broke UTs. Will be fixed by @anabaria once he is back from PTO. Test Plan: N/A Reviewers: anabaria Reviewed By: anabaria Subscribers: anabaria, yugaware Differential Revision: https://phorge.dev.yugabyte.com/D40373 * [DOC-566] TA-23476 Update Tech advisory (#25091) * update existing ta-23476 * add shortcode for versions * Apply suggestions from review Co-authored-by: Aishwarya Chakravarthy <[email protected]> * use bullet points * update TA 23476 on TA landing page. * add timestamp example --------- Co-authored-by: Aishwarya Chakravarthy <[email protected]> * [#22518] xCluster: Fix XClusterSafeTimeTest.ConsumerHistoryCutoff Summary: Fixed a couple of bug in VerifyHistoryCutoffTime to make test pass. Jira: DB-11444 Test Plan: ./yb_build.sh fastdebug --gcc11 --cxx-test xcluster_safe_time-itest --gtest_filter XClusterSafeTimeTest.ConsumerHistoryCutoff -n 400 -- -p 8 Reviewers: hsunder, xCluster Reviewed By: hsunder Subscribers: ybase Tags: #jenkins-ready Differential Revision: https://phorge.dev.yugabyte.com/D40375 * [#25130] DocDB: Preventing altering table that is being prepared Summary: Alter table request could arrive while table is being prepared. It could ruin table states transition logic. Fixed by rejecting alter table while table is being prepared. Also removed explicit vmodule setup in tests. If it is necessary to execute test with vmodule settings we could always use `--test-args --vmodule=...` way. Which is blocked by explicit value for vmodule flag. Jira: DB-14280 Test Plan: ./yb_build.sh fastdebug --gcc11 --gtest_filter CDCSDKYsqlTest.TestAddManyColocatedTablesOnNamesapceWithStream -n 40 Reviewers: zdrudi, xCluster, hsunder Reviewed By: zdrudi Subscribers: ybase, yql Tags: #jenkins-ready Differential Revision: https://phorge.dev.yugabyte.com/D40367 * [#17898] DocDB: Fixed bug with retaining DelayedTask during shutdown Summary: DelayedTask::Run checks whether Reactor started shutdown and just exit. Because of this this task does not invoke callback and hangs forever in messenger. Actually we don't need this check, since there are a more robust checks in our code to detect whether task should be aborted. So removed this check. Jira: DB-6980 Test Plan: ./yb_build.sh fastdebug --gcc11 --gtest_filter MasterTest.TestRegisterDistBroadcastDupPrivateUsePrivateIpNeverCheckUsed -n 400 Reviewers: hsunder Reviewed By: hsunder Subscribers: ybase Tags: #jenkins-ready Differential Revision: https://phorge.dev.yugabyte.com/D40364 * [DOC-554][CLOUDGA-24513][ybm] VictoriaMetrics GA (#25056) * YBM VictoriaMetrics GA * edit * review comments * [doc][ybm] Change log for Victoriametrics ga (#25134) * change log for victoriametrics ga * format * [#24324][conn-mgr] Add logical client version matching to select backends Summary: This diff adds the logic of selecting transactional backends based on matching the logical client version of the server to that of the logical client. **This feature is guarded by preview flag** `ysql_conn_mgr_version_matching`. There is one more preview flag is added named `ysql_conn_mgr_version_matching_connect_higher_version` . Use case of this flag is discussed later in algorithm. Algorithm description in chronological order. 1.) When a backend spawns, it reads the current_version from pg_yb_logical_client_version table added as part of D38335 and sends it to frontend as parameter status packet. 2.) At frontend, `od_backend_startup` in backend.c, this parameter status packet is parsed and stored in server->logical_client_version. 3.) When a new logical client comes up, it is authenticated by auth backend. After successful authentication, it stores it's logical_client_version from auth backend's logical client version. 4.) After authentication , during routing of the client for getting transactional backend, we first check the `logical_client_version` of the client to that of route's `max_logical_client_version`. - If former is greater than later, then we - update the route's `max_logical_client_version` - mark all sever's in active and idle pool's `marked_for_close` as true. - If the logical_client_version of client is less than route's max_logical_client_version then we return `OD_ROUTER_ERROR` leading to disconnect of the server. - After that we select a backend from idle pool having these two things: 5.) Now there would be two cases for the server selection algorithm. Either we get a server or we get NULL. - If we get a server , we simply attach - If not, we spawn a new server and check the logical_client_version of that sever to the client's logical client version. There could be a case where attached server's version is greater than client's logical client version. In this case there if `ysql_conn_mgr_version_matching_connect_higher_version` is: - Set to false: return `OD_ESERVER_CONNECT` - Set to true: return `OD_OK`; Test Plan: Jenkins: enable connection manager, all tests ./yb_build.sh release --java-test org.yb.ysqlconnmgr.TestLogicalClientVersion Reviewers: skumar, stiwary, mkumar, rbarigidad Reviewed By: rbarigidad Subscribers: svc_phabricator, yql Differential Revision: https://phorge.dev.yugabyte.com/D38749 * [#25030] YCQL: Replace autoflag ycql_suppress_group_by_error with a regular gFlag Summary: In commit 80def06f8c19ad7cbc52f41b4be48d158157a418, an autoflag `ycql_suppress_group_by_error` was introduced to suppress the error raised when using the `GROUP BY` clause. 1. This should not have been an autoflag because we want users to decide this behavior. - A new regular gFlag, `ycql_ignore_group_by_error`, has been introduced for future use since autoflags cannot be demoted or removed. - When set to true(default), no error is raised, and the `GROUP BY` clause is ignored. When set to false, the error is raised as usual. 2. The autoflag definition was previously in pt_select.cc. Its definition has now been moved to server_common_flags.cc because, due to differences in the linking scheme for various build types, this flag was not available in master flags for certain build types. - The flag does not determine/change any behaviour. Jira: DB-14168 Test Plan: ./yb_build.sh --java-test org.yb.cql.TestCreateTable#testCreateTableWithColumnNamedGroup ./yb_build.sh --java-test org.yb.cql.TestSelect#testGroupBy Reviewers: stiwary, hsunder, skumar Reviewed By: stiwary, hsunder Subscribers: yql, ybase Differential Revision: https://phorge.dev.yugabyte.com/D40327 * [#25136] YSQL: Decrease number of iteration in PgLibPqTest.MasterRestartReadPastGlobalLimit TSAN mode Summary: The test performs 10k iterations, in TSAN mode it takes 0.1s to perform single iteration in TSAN mode. So test just times out because 15 minutes is required to complete such number of iterations. Decreased number of iterations to 1k for sanitizers. Jira: DB-14286 Test Plan: ./yb_build.sh tsan --gtest_filter PgLibPqTest.MasterRestartReadPastGlobalLimit -n 40 Reviewers: jason, patnaik.balivada Reviewed By: patnaik.balivada Subscribers: ybase, yql Tags: #jenkins-ready Differential Revision: https://phorge.dev.yugabyte.com/D40381 * [#23331] yugabyted: Fixing yugabyted tests broken with pg_isready diff D34597. Summary: On Jenkins pipelines `pg_isready` binary is not available in the paths configured in yugabyted. Adding required changes to find the `pg_isready` on Jenkins VMs. Jira: DB-12256 Test Plan: ./yb_build.sh --java-test 'org.yb.yugabyted.TestYugabytedSingleNode' Reviewers: sgarg-yb Reviewed By: sgarg-yb Subscribers: yugabyted-dev Differential Revision: https://phorge.dev.yugabyte.com/D40379 * [DB-13952]yugabyted: Fixing the count of automatic, manual refactoring. Summary: Schema analysis API data usage - - data for `AUTOMATIC DDL IMPORT` `MANUAL REFACTORING` `TOTAL ANALYZED` is being read from `current_analysis_report.recommended_refactoring.refactor_details.manual/automatic` - For the summary table, values are being read from `current_analysis_report.recommended_refactoring.refactor_details` list. - For both UI sections, using `refactor_details.automatic` value requires an API change. Automatic value is being calculated by subtracting the count of conversion issues instead of subtracting the count of `sql_objects.invalidCount`. Jira: DB-13952 Test Plan: Manual Test Reviewers: sgarg-yb Reviewed By: sgarg-yb Differential Revision: https://phorge.dev.yugabyte.com/D40328 * [#24697] Docdb: Table locks - support releasing locks for a session/host Summary: Api to allow releasing locks for a session/host when either a) The session ends, or b) The tserver loses its lease/restarts. The TServer should detect when a session ends, and may call the API to release all locks held by a particular session. Once YSQL lease is implemented, the master may realize that a TServer has lost it's lease, or may discover that the TServer has had a restart when a TServer shows up with a new instance_seqno. A new incarnation-id may be generated, and then a background task clears out the locks held by previous incarnations. Other changes: - Try to make Unlock/Lock apis take a callback instead Jira: DB-13773 Test Plan: yb_build.sh --cxx-test object_lock-test Reviewers: zdrudi, bkolagani Reviewed By: zdrudi Subscribers: ybase Differential Revision: https://phorge.dev.yugabyte.com/D39749 * [PLAT-15959]: Update PDB policy in case of pods change in K8s universe Summary: This diff is in continuation of PDB support: D39864 Added changes to update PDB policy in case of edit universe or edit read-replica cluster. Test Plan: Tested manually by performing actions like pod change and create/delete read-replica. Reviewers: sneelakantan, anijhawan, vkumar Reviewed By: vkumar Subscribers: yugaware Differential Revision: https://phorge.dev.yugabyte.com/D40315 * [DB-13952]yugabyted: Fixing the ui changes after the addition of invalid obj count. Summary: Addition of invalid object count column on assessment and analysis voyager page. Jira: DB-13952 Test Plan: Manual testing Reviewers: nikhil Reviewed By: nikhil Subscribers: yugabyted-dev, krishna.tripathi Differential Revision: https://phorge.dev.yugabyte.com/D40387 * [docs] Release notes for 2.20.8.0-b53 (#25079) * rn for 2.20.8.0 * changed date * [#25089] build: Allow building with artifacts from thirdparty PR Summary: This diff makes the following changes to improve workflow of making thirdparty changes: - Allow specifying GitHub artifact IDs for thirdparty builds and their checksums in thirdparty_archives.yml instead of tags, e.g. ``` - os_type: ubuntu22.04 architecture: x86_64 compiler_type: gcc11 release_artifact_id: 1234567890 checksum_artifact_id: 1234567891 ``` Artifact downloads are structured as a zip file containing archive.tar.gz/archive.tar.gz.sha256. We cache only the extracted archive.tar.gz/archive.tar.gz.sha256, renamed as github-artifact-RELEASE_ARTIFACT_ID.tar.gz/github-artifact-RELEASE_ARTIFACT_ID.tar.gz.sha256. The build is extracted to /opt/yb-build/thirdparty/RELEASE_ARTIFACT_ID, and a symlink is created at /opt/yb-build/thirdparty/yugabyte-db-thirdparty-v.... pointing to /opt/yb-build/thirdparty/RELEASE_ARTIFACT_ID (this is needed because thirdparty binaries used in the build have this path hardcoded in rpath). - Make thirdparty_tool be able to pull thirdparty builds from a thirdparty PR instead of scanning release tags, e.g. ``` ./build-support/thirdparty_tool -u --thirdparty-pr 12345678 ``` will generate thirdparty_archives.yml using artifacts from the latest version of PR #12345678 on the thirdparty repo. Accessing artifacts requires a GitHub token to be set (either via the GITHUB_TOKEN environmental variable, or in a file specified in the YB_GITHUB_TOKEN_FILE_PATH environmental variable); one of the two must be set when building with artifacts from a thirdparty PR. Some old linuxbrew handling code was also removed. Jira: DB-14217 Test Plan: Jenkins: compile only Tested thirdparty_tool with and without the new `--thirdparty-pr` option, and tested local builds in both setups. Reviewers: steve.varnau Reviewed By: steve.varnau Subscribers: ybase Differential Revision: https://phorge.dev.yugabyte.com/D40118 * [#25053] YSQL: Fix TestPgDdlConcurrency for TSAN build Summary: Similar fix already made for ASAN build. The test still used 50 thread for TSAN build. It was reported that 50 threads in TSAN build caused other CPU intensive tests on the same test VM to fail. Reduced to 10 threads for TSAN build as well. The test runs more flaky under TSAN build with this change, I will look into how to get rid of the flakiness separately. Jira: DB-14184 Test Plan: ./yb_build.sh tsan --java-test 'org.yb.pgsql.TestPgDdlConcurrency#testModifiedTableWrite' -n 20 --tp 1 Reviewers: kfranz, mihnea Reviewed By: kfranz Subscribers: yql Differential Revision: https://phorge.dev.yugabyte.com/D40398 * [#24707] YSQL: pg_cron: Kill inflight jobs when leader changes Summary: Kill jobs if we are no longer leader. If there is a long running job when the cron leader moved due to load balance or upgrade activities, this will ensure that there is only one occurrence of the job running at any given time. Fixes #24707 Jira: DB-13784 Test Plan: PgCronTest.CancelJobOnLeaderChange Reviewers: tnayak, fizaa Reviewed By: tnayak Subscribers: ybase, yql Differential Revision: https://phorge.dev.yugabyte.com/D40335 * [#25145] DocDB: Fix MasterTabletServer::GetServingTablet Summary: Missing null check. `CatalogManager` is yb-masters `tserver::TabletPeerLookupIf`, so moving the inheritance to `CatalogManagerIf` and using it in `MasterTabletServer`. The `CatalogManager` performs all the required checks correctly. Fixes #25145 Jira: DB-14305 Test Plan: Jenkins Reviewers: bkolagani Reviewed By: bkolagani Subscribers: ybase Differential Revision: https://phorge.dev.yugabyte.com/D40405 * [PLAT-16129][YBA CLI] RBAC APIs - 1 Summary: Add commands corresponding to RBAC APIs. RBAC Command ``` yba rbac Manage YugabyteDB Anywhere RBAC (Role-Based Access Control) Usage: yba rbac [flags] yba rbac [command] Available Commands: permission Manage YugabyteDB Anywhere RBAC permissions role Manage YugabyteDB Anywhere RBAC roles Flags: -h, --help help for rbac Global Flags: -a, --apiToken string YugabyteDB Anywhere api token. --config string Config file, defaults to $HOME/.yba-cli.yaml --debug Use debug mode, same as --logLevel debug. --disable-color Disable colors in output. (default false) -H, --host string YugabyteDB Anywhere Host (default "http://localhost:9000") -l, --logLevel string Select the desired log level format. Allowed values: debug, info, warn, error, fatal. (default "info") -o, --output string Select the desired output format. Allowed values: table, json, pretty. (default "table") --timeout duration Wait command timeout, example: 5m, 1h. (default 168h0m0s) --wait Wait until the task is completed, otherwise it will exit immediately. (default true) ``` Permission command ``` yba rbac permission Manage YugabyteDB Anywhere RBAC permissions Usage: yba rbac permission [flags] yba rbac permission [command] Available Commands: describe Describe a YugabyteDB Anywhere RBAC permission list List YugabyteDB Anywhere permissions Flags: -h, --help help for permission Global Flags: -a, --apiToken string YugabyteDB Anywhere api token. --config string Config file, defaults to $HOME/.yba-cli.yaml --debug Use debug mode, same as --logLevel debug. --disable-color Disable colors in output. (default false) -H, --host string YugabyteDB Anywhere Host (default "http://localhost:9000") -l, --logLevel string Select the desired log level format. Allowed values: debug, info, warn, error, fatal. (default "info") -o, --output string Select the desired output format. Allowed values: table, json, pretty. (default "table") --timeout duration Wait command timeout, example: 5m, 1h. (default 168h0m0s) --wait Wait until the task is completed, otherwise it will exit immediately. (default true) Use "yba rbac permission [command] --help" for more information about a command. ``` List Permission ``` yba rbac permission list List YugabyteDB Anywhere permissions Usage: yba rbac permission list [flags] Aliases: list, ls Examples: yba rbac permission list Flags: -n, --name string [Optional] Name of the permission. Quote name if it contains space. --resource-type string [Optional] Resource type of the permission. Allowed values: universe, role, user, other. If not specified, all resource types are returned. -h, --help help for list Global Flags: -a, --apiToken string YugabyteDB Anywhere api token. --config string Config file, defaults to $HOME/.yba-cli.yaml --debug Use debug mode, same as --logLevel debug. --disable-color Disable colors in output. (default false) -H, --host string YugabyteDB Anywhere Host (default "http://localhost:9000") -l, --logLevel string Select the desired log level format. Allowed values: debug, info, warn, error, fatal. (default "info") -o, --output string Select the desired output format. Allowed values: table, json, pretty. (default "table") --timeout duration Wait command timeout, example: 5m, 1h. (default 168h0m0s) --wait Wait until the task is completed, otherwise it will exit immediately. (default true) ``` Describe Persmiison ``` yba rbac permission describe -h Describe a RBAC permission in YugabyteDB Anywhere Usage: yba rbac permission describe [flags] Aliases: describe, get Examples: yba rbac permission describe --name <permission-name> Flags: -n, --name string [Required] Name of the permission. Quote name if it contains space. -h, --help help for describe Global Flags: -a, --apiToken string YugabyteDB Anywhere api token. --config string Config file, defaults to $HOME/.yba-cli.yaml --debug Use debug mode, same as --logLevel debug. --disable-color Disable colors in output. (default false) -H, --host string YugabyteDB Anywhere Host (default "http://localhost:9000") -l, --logLevel string Select the desired log level format. Allowed values: debug, info, warn, error, fatal. (default "info") -o, --output string Select the desired output format. Allowed values: table, json, pretty. (default "table") --timeout duration Wait command timeout, example: 5m, 1h. (default 168h0m0s) --wait Wait until the task is completed, otherwise it will exit immediately. (default true) ``` Role command ``` yba rbac role Manage YugabyteDB Anywhere RBAC roles Usage: yba rbac role [flags] yba rbac role [command] Available Commands: create Create YugabyteDB Anywhere RBAC roles delete Delete a YugabyteDB Anywhere role describe Describe a YugabyteDB Anywhere RBAC role list List YugabyteDB Anywhere roles update Update a YugabyteDB Anywhere role Flags: -h, --help help for role Global Flags: -a, --apiToken string YugabyteDB Anywhere api token. --config string Config file, defaults to $HOME/.yba-cli.yaml --debug Use debug mode, same as --logLevel debug. --disable-color Disable colors in output. (default false) -H, --host string YugabyteDB Anywhere Host (default "http://localhost:9000") -l, --logLevel string Select the desired log level format. Allowed values: debug, info, warn, error, fatal. (default "info") -o, --output string Select the desired output format. Allowed values: table, json, pretty. (default "table") --timeout duration Wait command timeout, example: 5m, 1h. (default 168h0m0s) --wait Wait until the task is completed, otherwise it will exit immediately. (default true) ``` List Role command ``` yba rbac role list List YugabyteDB Anywhere roles Usage: yba rbac role list [flags] Aliases: list, ls Examples: yba rbac role list Flags: -n, --name string [Optional] Name of the role. Quote name if it contains space. --type string [Optional] Role type. Allowed values: system, custom. If not specified, all role types are returned. -h, --help help for list Global Flags: -a, --apiToken string YugabyteDB Anywhere api token. --config string Config file, defaults to $HOME/.yba-cli.yaml --debug Use debug mode, same as --logLevel debug. --disable-color Disable colors in output. (default false) -H, --host string YugabyteDB Anywhere Host (default "http://localhost:9000") -l, --logLevel string Select the desired log level format. Allowed values: debug, info, warn, error, fatal. (default "info") -o, --output string Select the desired output format. Allowed values: table, json, pretty. (default "table") --timeout duration Wait command timeout, example: 5m, 1h. (default 168h0m0s) --wait Wait until the task is completed, otherwise it will exit immediately. (default true) ``` Describe role: ``` yba rbac role describe -h Describe a RBAC role in YugabyteDB Anywhere Usage: yba rbac role describe [flags] Aliases: describe, get Examples: yba rbac role describe --name <role-name> Flags: -n, --name string [Required] Name of the role. Quote name if it contains space. -h, --help help for describe Global Flags: -a, --apiToken string YugabyteDB Anywhere api token. --config string Config file, defaults to $HOME/.yba-cli.yaml --debug Use debug mode, same as --logLevel debug. --disable-color Disable colors in output. (default false) -H, --host string YugabyteDB Anywhere Host (default "http://localhost:9000") -l, --logLevel string Select the desired log level format. Allowed values: debug, info, warn, error, fatal. (default "info") -o, --output string Select the desired output format. Allowed values: table, json, pretty. (default "table") --timeout duration Wait command timeout, example: 5m, 1h. (default 168h0m0s) --wait Wait until the task is completed, otherwise it will exit immediately. (default true) ``` Delete role ``` yba rbac role delete -h Delete a role in YugabyteDB Anywhere Usage: yba rbac role delete [flags] Aliases: delete, remove, rm Examples: yba role delete --name <role-name> Flags: -n, --name string [Required] The name of the role to be deleted. -f, --force [Optional] Bypass the prompt for non-interactive usage. -h, --help help for delete Global Flags: -a, --apiToken string YugabyteDB Anywhere api token. --config string Config file, defaults to $HOME/.yba-cli.yaml --debug Use debug mode, same as --logLevel debug. --disable-color Disable colors in output. (default false) -H, --host string YugabyteDB Anywhere Host (default "http://localhost:9000") -l, --logLevel string Select the desired log level format. Allowed values: debug, info, warn, error, fatal. (default "info") -o, --output string Select the desired output format. Allowed values: table, json, pretty. (default "table") --timeout duration Wait command timeout, example: 5m, 1h. (default 168h0m0s) --wait Wait until the task is completed, otherwise it will exit immediately. (default true) Create role ``` yba rbac role create -h Create YugabyteDB Anywhere RBAC roles Usage: yba rbac role create [flags] Aliases: create, add Examples: yba rbac role create --name <role-name> \ --permission resource-type=other::action=read \ --description <description> Flags: -n, --name string [Required] Name of the role. Quote name if it contains space. --description string [Optional] Description of the role. Quote description if it contains space. --permission stringArray [Required] Permissions associated with the role. Minimum number of required permissions = 1. Provide the following double colon (::) separated fields as key-value pairs: "resource-type=<resource-type>::action=<action>". Both are requires key-values. Allowed resource types are universe, role, user, other. Allowed actions are create, read, update, delete, pause_resume, backup_restore, update_role_bindings, update_profile, super_admin_actions, xcluster. Each permission needs to be added using a separate --permission flag. Example: --permission resource-type=other::action=delete --permission resource-type=universe::action=write -h, --help help for create Global Flags: -a, --apiToken string YugabyteDB Anywhere api token. --config string Config file, defaults to $HOME/.yba-cli.yaml --debug Use debug mode, same as --logLevel debug. --disable-color Disable colors in output. (default false) -H, --host string YugabyteDB Anywhere Host (default "http://localhost:9000") -l, --logLevel string Select the desired log level format. Allowed values: debug, info, warn, error, fatal. (default "info") -o, --output string Select the desired output format. Allowed values: table, json, pretty. (default "table") --timeout duration Wait command timeout, example: 5m, 1h. (default 168h0m0s) --wait Wait until the task is completed, otherwise it will exit immediately. (default true) ``` Update role command: ``` yba rbac role update -h Update a role in YugabyteDB Anywhere Usage: yba rbac role update [flags] Aliases: update, edit Examples: yba rbac role update --name <role-name> \ --add-permission resource-type=other::action=create Flags: -n, --name string [Required] Role name to be updated. --add-permission stringArray [Optional] Add permissions to the role. Provide the following double colon (::) separated fields as key-value pairs: "resource-type=<resource-type>::action=<action>". Both are requires key-values. Allowed resource types are: universe, role, user, other. Allowed actions are: create, read, update, delete, pause_resume, backup_restore, update_role_bindings, update_profile, super_admin_actions, xcluster.Quote action if it contains space. Each permission needs to be added using a separate --add-permission flag. --remove-permission stringArray [Optional] Remove permissions from the role. Provide the following double colon (::) separated fields as key-value pairs: "resource-type=<resource-type>::action=<action>". Both are requires key-values. Allowed resource types are: universe, role, user, other. Allowed actions are: create, read, update, delete, pause_resume, backup_restore, update_role_bindings, update_profile, super_admin_actions, xcluster.Quote action if it contains space. Each permission needs to be removed using a separate --remove-permission flag. -h, --help help for update Global Flags: -a, --apiToken string YugabyteDB Anywhere api token. --config string Config file, defaults to $HOME/.yba-cli.yaml --debug Use debug mode, same as --logLevel debug. --disable-color Disable colors in output. (default false) -H, --host string YugabyteDB Anywhere Host (default "http://localhost:9000") -l, --logLevel string Select the desired log level format. Allowed values: debug, info, warn, error, fatal. (default "info") -o, --output string Select the desired output format. Allowed values: table, json, pretty. (default "table") --timeout duration Wait command timeout, example: 5m, 1h. (default 168h0m0s) --wait Wait until the task is completed, otherwise it will exit immediately. (default true) ``` Test Plan: `yba rbac permission list` ``` Name Resource Type Action Permission Valid On Resource Update Role ROLE UPDATE false Create Role ROLE CREATE false View Role ROLE READ false Delete Role ROLE DELETE false Delete User USER DELETE false Update Role Bindings USER UPDATE_ROLE_BINDINGS false Create User USER CREATE false Update User Profile USER UPDATE_PROFILE false View User USER READ false View Universe UNIVERSE READ true Manage XCluster UNIVERSE XCLUSTER true Update Universe UNIVERSE UPDATE true Create Universe UNIVERSE CREATE false Backup/Restore Universe UNIVERSE BACKUP_RESTORE true Pause/Resume Universe UNIVERSE PAUSE_RESUME true Delete Universe UNIVERSE DELETE true View Resource OTHER READ false Create Resource OTHER CREATE false Update Resource OTHER UPDATE false Delete Resource OTHER DELETE false Super Admin Actions OTHER SUPER_ADMIN_ACTIONS false ``` `yba rbac permission describe --name "View Universe"` ``` General Name Resource Type Action Permission Valid On Resource View Universe UNIVERSE READ true Permission Details Description Allows user to view a universe. Prerequisite Permissions Permission 1: Details Action Resource Type READ OTHER ``` `yba rbac role list` ``` Name UUID Role Type ReadOnly a392c6cc-a57d-4a04-acb8-0e1d4d1f1205 System BackupAdmin f201e3fc-845a-4b5f-9f84-052b6c24d1a3 System ConnectOnly 7b10ff16-5ac0-4cfe-b1ee-0a0673a5f86b System Admin 1c4f107e-a2a4-4b45-916b-3ea6a936e85e System SuperAdmin 5853e7a7-0a89-4472-a354-d473de7c21ae System Developer L2 bef2eb73-020a-45f1-a9c2-23a5877714d5 Custom Software L1 019e26b0-0ee2-476c-bb86-b85c20c26412 Custom ``` `yba rbac role get -n "Developer L2"` ``` General Name UUID Role Type Developer L2 bef2eb73-020a-45f1-a9c2-23a5877714d5 Custom Role Details Description Access to selected universes Created On Updated On Thu, 08 Feb 2024 03:12:41 +0000 Mon, 05 Aug 2024 05:49:24 +0000 Permissions Permission 1: Details Action Resource Type BACKUP_RESTORE UNIVERSE Permission 2: Details Action Resource Type READ UNIVERSE Permission 3: Details Action Resource Type PAUSE_RESUME UNIVERSE Permission 4: Details Action Resource Type READ OTHER Permission 5: Details Action Resource Type DELETE UNIVERSE Permission 6: Details Action Resource Type XCLUSTER UNIVERSE Permission 7: Details Action Resource Type UPDATE UNIVERSE ``` `yba rbac role create -n test-cli --permission resource-type=universe::action=delete --permission resource-type=universe::action=read --permission resource-type=other::action=read` ``` Name UUID Role Type test-cli f323efd8-90ea-4090-9b41-00922866aea0 Custom ``` `yba rbac role update -n test-cli --add-permission resource-type=universe::action=read` ``` Name UUID Role Type test-cli f323efd8-90ea-4090-9b41-00922866aea0 Custom ``` Reviewers: skurapati Reviewed By: skurapati Subscribers: yugaware Differential Revision: https://phorge.dev.yugabyte.com/D40222 * [#23331] yugabyted: Update directory location of pg_isready binary in Development Environemnt. Summary: Updating the directory location of pg_isready binary from `build/clang17-dynamic-ninja` to `build/latest`. Jira: DB-12256 Test Plan: Manual Tests Reviewers: sgarg-yb, djiang Reviewed By: djiang Subscribers: yugabyted-dev Differential Revision: https://phorge.dev.yugabyte.com/D40396 * [PLAT-16128]User management commands - update profile, reset password Summary: Password reset for logged in user: ``` yba user reset-password -h Reset password of currently logged in user in YugabyteDB Anywhere Usage: yba user reset-password [flags] Aliases: reset-password, reset Examples: yba user reset-password \ --current-password <current-password> --new-password <new-password> Flags: --current-password string [Required] The current password of the user. --new-password string [Required] The new password of the user. -h, --help help for reset-password Global Flags: -a, --apiToken string YugabyteDB Anywhere api token. --config string Config file, defaults to $HOME/.yba-cli.yaml --debug Use debug mode, same as --logLevel debug. --disable-color Disable colors in output. (default false) -H, --host string YugabyteDB Anywhere Host (default "http://localhost:9000") -l, --logLevel string Select the desired log level format. Allowed values: debug, info, warn, error, fatal. (default "info") -o, --output string Select the desired output format. Allowed values: table, json, pretty. (default "table") --timeout duration Wait command timeout, example: 5m, 1h. (default 168h0m0s) --wait Wait until the task is completed, otherwise it will exit immediately. (default true) ``` Update user ``` yba user update Update a user in YugabyteDB Anywhere Usage: yba user update [flags] Aliases: update, edit Examples: yba user update --email <user-email> --timezone "America/Los_Angeles" Flags: -e, --email string [Required] The email of the user to be updated. --timezone string [Optional] The timezone of the user to be updated. -h, --help help for update Global Flags: -a, --apiToken string YugabyteDB Anywhere api token. --config string Config file, defaults to $HOME/.yba-cli.yaml --debug Use debug mode, same as --logLevel debug. --disable-color Disable colors in output. (default false) -H, --host string YugabyteDB Anywhere Host (default "http://localhost:9000") -l, --logLevel string Select the desired log level format. Allowed values: debug, info, warn, error, fatal. (default "info") -o, --output string Select the desired output format. Allowed values: table, json, pretty. (default "table") --timeout duration Wait command timeout, example: 5m, 1h. (default 168h0m0s) --wait Wait until the task is completed, otherwise it will exit immediately. (default true) ``` Test Plan: `yba user reset-password --current-password Password#123 --new-password Password#1234` ``` Email UUID …
Summary: Timeline: D34040 introduced an optimization to skip redundant index updates and foreign key checks. D37746 gated this feature behind a preview flag (feature is OFF by default) named yb_update_optimization_infra. D37749 introduced a feature enablement flag ysql_yb_skip_redundant_update_ops, and promoted the above preview flag to an auto flag. D40300 turned OFF the feature via the enablement flag ysql_yb_skip_redundant_update_ops due to the bug GH-25075. D40404 fixed the above bug. This revision turns ON the feature by default by turning ON the feature enablement flag ysql_yb_skip_redundant_update_ops. This reverts commit 0529391 (D40300). Jira: DB-7701 Test Plan: Run Jenkins Reviewers: amartsinchyk, smishra Reviewed By: amartsinchyk Subscribers: ybase, yql Tags: #jenkins-ready Differential Revision: https://phorge.dev.yugabyte.com/D40649
…ndex updates Summary: Timeline: D34040 introduced an optimization to skip redundant index updates and foreign key checks. D37746 gated this feature behind a preview flag (feature is OFF by default) named yb_update_optimization_infra. D37749 introduced a feature enablement flag ysql_yb_skip_redundant_update_ops, and promoted the above preview flag to an auto flag. D40300 turned OFF the feature via the enablement flag ysql_yb_skip_redundant_update_ops due to the bug GH-25075. D40404 fixed the above bug. This revision turns ON the feature by default by turning ON the feature enablement flag ysql_yb_skip_redundant_update_ops. This reverts commit 0529391 (D40300). Jira: DB-7701 Original commit: 3c8a0c5 / D40649 Test Plan: Run Jenkins Reviewers: amartsinchyk, smishra Reviewed By: amartsinchyk Subscribers: yql, ybase Tags: #jenkins-ready Differential Revision: https://phorge.dev.yugabyte.com/D40774
…ndex updates Summary: Timeline: D34040 introduced an optimization to skip redundant index updates and foreign key checks. D37746 gated this feature behind a preview flag (feature is OFF by default) named yb_update_optimization_infra. D37749 introduced a feature enablement flag ysql_yb_skip_redundant_update_ops, and promoted the above preview flag to an auto flag. D38598 backported the changes of D37749 to 2024.2, while keeping the feature enablement flag turned OFF (the flag is on in master, by default). D38936 turned ON the feature in 2024.2 via the enablement flag ysql_yb_skip_redundant_update_ops. D40300 (and its backports) turned OFF the feature via the enablement flag ysql_yb_skip_redundant_update_ops due to the bug GH-25075. D40404 (and its backports) fixed the above bug. This revision turns ON the feature by default by turning ON the feature enablement flag ysql_yb_skip_redundant_update_ops. This reverts commit 0529391 (D40300). Jira: DB-7701 Original commit: 3c8a0c5 / D40649 Test Plan: Run Jenkins Reviewers: amartsinchyk, smishra Reviewed By: smishra Subscribers: yql, ybase Tags: #jenkins-ready Differential Revision: https://phorge.dev.yugabyte.com/D40830
Jira Link: DB-7701
Description
Consider the following schema:
This consists of a main table whose primary key has a foreign key constraint on a secondary table.
Additionally, the main table has a trigger, which inserts a new key into the secondary table.
Inserting a new row into the main table:
When an UPDATE is issued to the non-index column column (v3) of the main table, we see write requests corresponding to DELETEs + INSERTs for each of the secondary indexes.
This query should ideally have been executed as a single main table write request in a single flush.
Instead we see 4 secondary index writes + 1 main table write across 2 flushes.
Attached is a gist containing the schema:
https://gist.github.com/karthik-ramanathan-3006/8fa30b3d56829e62e228382ada3ae3b3
Warning: Please confirm that this issue does not contain any sensitive information
The text was updated successfully, but these errors were encountered: