-
Notifications
You must be signed in to change notification settings - Fork 684
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Use shard split copy code for blocking shard moves
The new shard copy code that was created for shard splits has some advantages over the old code. This one uses binary copy when possible to make the copy faster. When doing a shard move using `block_writes` it now uses this better copy logic.
- Loading branch information
Showing
19 changed files
with
441 additions
and
231 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
65 changes: 65 additions & 0 deletions
65
src/backend/distributed/operations/worker_copy_table_to_node_udf.c
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,65 @@ | ||
/*------------------------------------------------------------------------- | ||
* | ||
* worker_copy_table_to_node_udf.c | ||
* | ||
* This file implements the worker_copy_table_to_node UDF. This UDF can be | ||
* used to copy the data in a shard (or other table) from one worker node to | ||
* another. | ||
* | ||
* Copyright (c) Citus Data, Inc. | ||
* | ||
*------------------------------------------------------------------------- | ||
*/ | ||
|
||
#include "postgres.h" | ||
|
||
#include "utils/builtins.h" | ||
#include "utils/lsyscache.h" | ||
#include "distributed/citus_ruleutils.h" | ||
#include "distributed/metadata_cache.h" | ||
#include "distributed/multi_executor.h" | ||
#include "distributed/worker_shard_copy.h" | ||
|
||
PG_FUNCTION_INFO_V1(worker_copy_table_to_node); | ||
|
||
/* | ||
* worker_copy_table_to_node copies a shard from this worker to another worker | ||
* | ||
* SQL signature: | ||
* | ||
* worker_copy_table_to_node( | ||
* source_table regclass, | ||
* target_node_id integer | ||
* ) RETURNS VOID | ||
*/ | ||
Datum | ||
worker_copy_table_to_node(PG_FUNCTION_ARGS) | ||
{ | ||
Oid relationId = PG_GETARG_OID(0); | ||
uint32_t targetNodeId = PG_GETARG_INT32(1); | ||
|
||
Oid schemaOid = get_rel_namespace(relationId); | ||
char *relationSchemaName = get_namespace_name(schemaOid); | ||
char *relationName = get_rel_name(relationId); | ||
char *relationQualifiedName = quote_qualified_identifier( | ||
relationSchemaName, | ||
relationName); | ||
|
||
EState *executor = CreateExecutorState(); | ||
DestReceiver *destReceiver = CreateShardCopyDestReceiver( | ||
executor, | ||
list_make2(relationSchemaName, relationName), | ||
targetNodeId); | ||
|
||
StringInfo selectShardQueryForCopy = makeStringInfo(); | ||
appendStringInfo(selectShardQueryForCopy, | ||
"SELECT * FROM %s;", relationQualifiedName); | ||
|
||
ParamListInfo params = NULL; | ||
ExecuteQueryStringIntoDestReceiver(selectShardQueryForCopy->data, params, | ||
destReceiver); | ||
|
||
FreeExecutorState(executor); | ||
|
||
PG_RETURN_VOID(); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
8 changes: 8 additions & 0 deletions
8
src/backend/distributed/sql/udfs/worker_copy_table_to_node/11.1-1.sql
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
8 changes: 8 additions & 0 deletions
8
src/backend/distributed/sql/udfs/worker_copy_table_to_node/latest.sql
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
CREATE OR REPLACE FUNCTION pg_catalog.worker_copy_table_to_node( | ||
source_table regclass, | ||
target_node_id integer) | ||
RETURNS void | ||
LANGUAGE C STRICT | ||
AS 'MODULE_PATHNAME', $$worker_copy_table_to_node$$; | ||
COMMENT ON FUNCTION pg_catalog.worker_copy_table_to_node(regclass, integer) | ||
IS 'Perform copy of a shard'; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.