Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
P
Postgres FD Implementation
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Abuhujair Javed
Postgres FD Implementation
Commits
2b22795b
Commit
2b22795b
authored
May 01, 2015
by
Andres Freund
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Copy editing of the replication origins patch.
Michael Paquier and myself.
parent
1db12da8
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
22 additions
and
23 deletions
+22
-23
doc/src/sgml/func.sgml
doc/src/sgml/func.sgml
+2
-3
doc/src/sgml/replication-origins.sgml
doc/src/sgml/replication-origins.sgml
+12
-12
src/backend/replication/logical/origin.c
src/backend/replication/logical/origin.c
+7
-7
src/include/catalog/pg_replication_origin.h
src/include/catalog/pg_replication_origin.h
+1
-1
No files found.
doc/src/sgml/func.sgml
View file @
2b22795b
...
@@ -17086,9 +17086,8 @@ postgres=# SELECT * FROM pg_xlogfile_name_offset(pg_stop_backup());
...
@@ -17086,9 +17086,8 @@ postgres=# SELECT * FROM pg_xlogfile_name_offset(pg_stop_backup());
<parameter>
internal_id
</parameter>
<type>
oid
</type>
<parameter>
internal_id
</parameter>
<type>
oid
</type>
</entry>
</entry>
<entry>
<entry>
Lookup replication origin by name and return the internal
Lookup replication origin by name and return the internal id. If no
oid. If no corresponding replication origin is found a error
corresponding replication origin is found an error is thrown.
is thrown.
</entry>
</entry>
</row>
</row>
...
...
doc/src/sgml/replication-origins.sgml
View file @
2b22795b
...
@@ -22,14 +22,14 @@
...
@@ -22,14 +22,14 @@
</para>
</para>
<para>
<para>
Replication origins consist out of a name and a
oid. The name, which
Replication origins consist out of a name and a
n <type>oid</type>. The name,
is what should be used to refer to the origin across systems, is
which
is what should be used to refer to the origin across systems, is
free-form
text
. It should be used in a way that makes conflicts
free-form
<type>text</type>
. It should be used in a way that makes conflicts
between replication origins created by different replication
between replication origins created by different replication
solutions
solutions unlikely; e.g. by prefixing the replication solution's
unlikely; e.g. by prefixing the replication solution's name to it.
name to it. The oid is used only to avoid having to store the long
The <type>oid</type> is used only to avoid having to store the long version
version in situations where space efficiency is important. It shoul
d
in situations where space efficiency is important. It should never be share
d
never be shared
between systems.
between systems.
</para>
</para>
<para>
<para>
...
@@ -61,11 +61,11 @@
...
@@ -61,11 +61,11 @@
timestamp of every source transaction can be configured on a per
timestamp of every source transaction can be configured on a per
transaction basis using
transaction basis using
<link linkend="pg-replication-origin-xact-setup"><function>pg_replication_origin_xact_setup()</function></link>.
<link linkend="pg-replication-origin-xact-setup"><function>pg_replication_origin_xact_setup()</function></link>.
If that's done replication progress will
be
persist in a crash safe
If that's done replication progress will persist in a crash safe
manner. Replay progress for all replication origins can be seen in the
manner. Replay progress for all replication origins can be seen in the
<link linkend="catalog-pg-replication-origin-status">
<link linkend="catalog-pg-replication-origin-status">
<structname>pg_replication_origin_status</structname>
<structname>pg_replication_origin_status</structname>
</link> view. A individual origin's progress, e.g. when resuming
</link> view. A
n
individual origin's progress, e.g. when resuming
replication, can be acquired using
replication, can be acquired using
<link linkend="pg-replication-origin-progress"><function>pg_replication_origin_progress()</function></link>
<link linkend="pg-replication-origin-progress"><function>pg_replication_origin_progress()</function></link>
for any origin or
for any origin or
...
@@ -75,9 +75,9 @@
...
@@ -75,9 +75,9 @@
<para>
<para>
In more complex replication topologies than replication from exactly one
In more complex replication topologies than replication from exactly one
system to one other, another problem can be that
, that
it is hard to avoid
system to one other, another problem can be that it is hard to avoid
replicating replayed rows again. That can lead both to cycles in the
replicating replayed rows again. That can lead both to cycles in the
replication and inefficiencies. Replication origins provide a optional
replication and inefficiencies. Replication origins provide a
n
optional
mechanism to recognize and prevent that. When configured using the functions
mechanism to recognize and prevent that. When configured using the functions
referenced in the previous paragraph, every change and transaction passed to
referenced in the previous paragraph, every change and transaction passed to
output plugin callbacks (see <xref linkend="logicaldecoding-output-plugin">)
output plugin callbacks (see <xref linkend="logicaldecoding-output-plugin">)
...
...
src/backend/replication/logical/origin.c
View file @
2b22795b
...
@@ -12,7 +12,7 @@
...
@@ -12,7 +12,7 @@
*
*
* This file provides the following:
* This file provides the following:
* * An infrastructure to name nodes in a replication setup
* * An infrastructure to name nodes in a replication setup
* * A facility to efficiently store and persist replication progress in a
* * A facility to efficiently store and persist replication progress in a
n
* efficient and durable manner.
* efficient and durable manner.
*
*
* Replication origin consist out of a descriptive, user defined, external
* Replication origin consist out of a descriptive, user defined, external
...
@@ -44,14 +44,14 @@
...
@@ -44,14 +44,14 @@
*
*
* There are several levels of locking at work:
* There are several levels of locking at work:
*
*
* * To create and drop replication origins a exclusive lock on
* * To create and drop replication origins a
n
exclusive lock on
* pg_replication_slot is required for the duration. That allows us to
* pg_replication_slot is required for the duration. That allows us to
* safely and conflict free assign new origins using a dirty snapshot.
* safely and conflict free assign new origins using a dirty snapshot.
*
*
* * When creating a in-memory replication progress slot the ReplicationOirgin
* * When creating a
n
in-memory replication progress slot the ReplicationOirgin
* LWLock has to be held exclusively; when iterating over the replication
* LWLock has to be held exclusively; when iterating over the replication
* progress a shared lock has to be held, the same when advancing the
* progress a shared lock has to be held, the same when advancing the
* replication progress of a individual backend that has not setup as the
* replication progress of a
n
individual backend that has not setup as the
* session's replication origin.
* session's replication origin.
*
*
* * When manipulating or looking at the remote_lsn and local_lsn fields of a
* * When manipulating or looking at the remote_lsn and local_lsn fields of a
...
@@ -251,7 +251,7 @@ replorigin_create(char *roname)
...
@@ -251,7 +251,7 @@ replorigin_create(char *roname)
* We need the numeric replication origin to be 16bit wide, so we cannot
* We need the numeric replication origin to be 16bit wide, so we cannot
* rely on the normal oid allocation. Instead we simply scan
* rely on the normal oid allocation. Instead we simply scan
* pg_replication_origin for the first unused id. That's not particularly
* pg_replication_origin for the first unused id. That's not particularly
* efficient, but this should be a
n
fairly infrequent operation - we can
* efficient, but this should be a fairly infrequent operation - we can
* easily spend a bit more code on this when it turns out it needs to be
* easily spend a bit more code on this when it turns out it needs to be
* faster.
* faster.
*
*
...
@@ -1078,7 +1078,7 @@ replorigin_session_setup(RepOriginId node)
...
@@ -1078,7 +1078,7 @@ replorigin_session_setup(RepOriginId node)
/*
/*
* Reset replay state previously setup in this session.
* Reset replay state previously setup in this session.
*
*
* This function may only be called if a origin was setup with
* This function may only be called if a
n
origin was setup with
* replorigin_session_setup().
* replorigin_session_setup().
*/
*/
void
void
...
@@ -1121,7 +1121,7 @@ replorigin_session_advance(XLogRecPtr remote_commit, XLogRecPtr local_commit)
...
@@ -1121,7 +1121,7 @@ replorigin_session_advance(XLogRecPtr remote_commit, XLogRecPtr local_commit)
/*
/*
* Ask the machinery about the point up to which we successfully replayed
* Ask the machinery about the point up to which we successfully replayed
* changes from a already setup replication origin.
* changes from a
n
already setup replication origin.
*/
*/
XLogRecPtr
XLogRecPtr
replorigin_session_get_progress
(
bool
flush
)
replorigin_session_get_progress
(
bool
flush
)
...
...
src/include/catalog/pg_replication_origin.h
View file @
2b22795b
...
@@ -34,7 +34,7 @@ CATALOG(pg_replication_origin,6000) BKI_SHARED_RELATION BKI_WITHOUT_OIDS
...
@@ -34,7 +34,7 @@ CATALOG(pg_replication_origin,6000) BKI_SHARED_RELATION BKI_WITHOUT_OIDS
*
*
* This should never leave the system.
* This should never leave the system.
*
*
* Needs to fit into a uint16, so we don't waste too much space in WAL
* Needs to fit into a
n
uint16, so we don't waste too much space in WAL
* records. For this reason we don't use a normal Oid column here, since
* records. For this reason we don't use a normal Oid column here, since
* we need to handle allocation of new values manually.
* we need to handle allocation of new values manually.
*/
*/
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment