mirror of
https://github.com/EnterpriseDB/repmgr.git
synced 2026-03-23 15:16:29 +00:00
Compare commits
12 Commits
REL5_4_STA
...
dev/FS-704
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
89f1936004 | ||
|
|
d3b1ff45b0 | ||
|
|
450786ec29 | ||
|
|
70b34308cc | ||
|
|
19c92a7092 | ||
|
|
520ff25ef3 | ||
|
|
8e81c04b4a | ||
|
|
aad988c292 | ||
|
|
43b8a5f65f | ||
|
|
26cfb56170 | ||
|
|
f0cc225de0 | ||
|
|
4c95d8d75e |
77
.github/workflows/sonarqube-scan.yml
vendored
Normal file
77
.github/workflows/sonarqube-scan.yml
vendored
Normal file
@@ -0,0 +1,77 @@
|
|||||||
|
###
|
||||||
|
# Foundation-security SonarQube workflow
|
||||||
|
# version: 2.1
|
||||||
|
###
|
||||||
|
name: Foundation-Security/SonarQube Scan
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
tags:
|
||||||
|
- "**"
|
||||||
|
branches:
|
||||||
|
- "*main*"
|
||||||
|
- "*master*"
|
||||||
|
- "*STABLE*"
|
||||||
|
pull_request:
|
||||||
|
types: [opened, synchronize, reopened]
|
||||||
|
branches:
|
||||||
|
- "**"
|
||||||
|
workflow_dispatch:
|
||||||
|
inputs:
|
||||||
|
ref:
|
||||||
|
description: "Branch to scan"
|
||||||
|
required: true
|
||||||
|
default: "main"
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
SonarQube-Scan:
|
||||||
|
name: SonarQube Scan Job
|
||||||
|
if: ${{ github.actor != 'dependabot[bot]' }}
|
||||||
|
permissions:
|
||||||
|
id-token: write
|
||||||
|
contents: read
|
||||||
|
runs-on: ubuntu-22.04
|
||||||
|
steps:
|
||||||
|
- name: Checkout source repository for dispatch runs
|
||||||
|
id: checkout-source-dispatch
|
||||||
|
if: github.event_name == 'workflow_dispatch'
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
repository: ${{ github.repository }}
|
||||||
|
ref: ${{ inputs.ref }}
|
||||||
|
path: source
|
||||||
|
token: ${{ secrets.GH_SLONIK }}
|
||||||
|
|
||||||
|
- name: Checkout source repository for non-dispatch runs
|
||||||
|
id: checkout-source
|
||||||
|
if: github.event_name != 'workflow_dispatch'
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
repository: ${{ github.repository }}
|
||||||
|
ref: ${{ github.ref }}
|
||||||
|
path: source
|
||||||
|
token: ${{ secrets.GH_SLONIK }}
|
||||||
|
|
||||||
|
- name: Checkout foundation-security repository
|
||||||
|
id: checkout-foundation-security
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
repository: EnterpriseDB/foundation-security
|
||||||
|
ref: v2
|
||||||
|
path: foundation-security
|
||||||
|
token: ${{ secrets.GH_SLONIK }}
|
||||||
|
|
||||||
|
- name: SonarQube Scan
|
||||||
|
id: call-sq-composite
|
||||||
|
uses: ./foundation-security/actions/sonarqube
|
||||||
|
with:
|
||||||
|
github-token: ${{ secrets.GH_SLONIK }}
|
||||||
|
github-ref: ${{ github.ref_name }}
|
||||||
|
sonarqube-url: ${{ vars.SQ_URL }}
|
||||||
|
sonarqube-token: ${{ secrets.SONARQUBE_TOKEN }}
|
||||||
|
project-name: ${{ github.event.repository.name }}
|
||||||
|
pull-request-key: ${{ github.event.number }}
|
||||||
|
pull-request-branch: ${{ github.head_ref }}
|
||||||
|
pull-request-base-branch: ${{ github.base_ref }}
|
||||||
|
foundation-security-sonarqube-token: ${{ secrets.FOUNDATION_SECURITY_SONARQUBE_TOKEN }}
|
||||||
|
cloudsmith-token: ${{ secrets.CLOUDSMITH_READ_ALL }}
|
||||||
6
HISTORY
6
HISTORY
@@ -1,3 +1,9 @@
|
|||||||
|
5.4.1 2023-??-??
|
||||||
|
repmgrd: ensure witness node metadata is updated (Ian)
|
||||||
|
|
||||||
|
5.4.0 2023-03-16
|
||||||
|
Support cloning replicas using pg-backup-api
|
||||||
|
|
||||||
5.3.3 2022-10-17
|
5.3.3 2022-10-17
|
||||||
Support for PostgreSQL added
|
Support for PostgreSQL added
|
||||||
repmgrd: ensure event notification script is called for event
|
repmgrd: ensure event notification script is called for event
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ replication, and perform administrative tasks such as failover or switchover
|
|||||||
operations.
|
operations.
|
||||||
|
|
||||||
The most recent `repmgr` version (5.3.2) supports all PostgreSQL versions from
|
The most recent `repmgr` version (5.3.2) supports all PostgreSQL versions from
|
||||||
9.5 to 14. PostgreSQL 9.4 is also supported, with some restrictions.
|
9.5 to 15. PostgreSQL 9.4 is also supported, with some restrictions.
|
||||||
|
|
||||||
`repmgr` is distributed under the GNU GPL 3 and maintained by EnterpriseDB.
|
`repmgr` is distributed under the GNU GPL 3 and maintained by EnterpriseDB.
|
||||||
|
|
||||||
|
|||||||
@@ -16,8 +16,44 @@
|
|||||||
</para>
|
</para>
|
||||||
|
|
||||||
<!-- remember to update the release date in ../repmgr_version.h.in -->
|
<!-- remember to update the release date in ../repmgr_version.h.in -->
|
||||||
|
<sect1 id="release-5.4.1">
|
||||||
|
<title id="release-current">Release 5.4.1</title>
|
||||||
|
<para><emphasis>??? ?? ??????, 202?</emphasis></para>
|
||||||
|
<para>
|
||||||
|
&repmgr; 5.4.1 is a minor release providing ...
|
||||||
|
</para>
|
||||||
|
<sect2>
|
||||||
|
<title>Bug fixes</title>
|
||||||
|
<para>
|
||||||
|
<itemizedlist>
|
||||||
|
<listitem>
|
||||||
|
<para>
|
||||||
|
&repmgrd;: ensure witness node metadata is updated if the primary
|
||||||
|
node changed while the witness &repmgrd; was not running.
|
||||||
|
</para>
|
||||||
|
</listitem>
|
||||||
|
</itemizedlist>
|
||||||
|
</para>
|
||||||
|
</sect2>
|
||||||
|
</sect1>
|
||||||
|
|
||||||
|
<sect1 id="release-5.4.0">
|
||||||
|
<title>Release 5.4.0</title>
|
||||||
|
<para><emphasis>Thu 15 March, 2023</emphasis></para>
|
||||||
|
<para>
|
||||||
|
&repmgr; 5.4.0 is a major release.
|
||||||
|
</para>
|
||||||
|
<para>
|
||||||
|
This release provides support for cloning standbys using backups taken with <ulink url="http://www.pgbarman.org">barman</ulink>
|
||||||
|
with the use of <ulink url="https://github.com/EnterpriseDB/pg-backup-api">pg-backup-api</ulink>.
|
||||||
|
</para>
|
||||||
|
<para>
|
||||||
|
Minor fixes to the documentation.
|
||||||
|
</para>
|
||||||
|
</sect1>
|
||||||
|
|
||||||
<sect1 id="release-5.3.3">
|
<sect1 id="release-5.3.3">
|
||||||
<title id="release-current">Release 5.3.3</title>
|
<title>Release 5.3.3</title>
|
||||||
<para><emphasis>Mon 17 October, 2022</emphasis></para>
|
<para><emphasis>Mon 17 October, 2022</emphasis></para>
|
||||||
<para>
|
<para>
|
||||||
&repmgr; 5.3.3 is a minor release providing support for
|
&repmgr; 5.3.3 is a minor release providing support for
|
||||||
|
|||||||
@@ -225,6 +225,109 @@ description = "Main cluster"
|
|||||||
</note>
|
</note>
|
||||||
|
|
||||||
</sect2>
|
</sect2>
|
||||||
|
|
||||||
|
<sect2 id="cloning-from-barman-pg_backupapi-mode" xreflabel="Using Barman through its API (pg-backup-api)">
|
||||||
|
<title>Using Barman through its API (pg-backup-api)</title>
|
||||||
|
<indexterm>
|
||||||
|
<primary>cloning</primary>
|
||||||
|
<secondary>pg-backup-api</secondary>
|
||||||
|
</indexterm>
|
||||||
|
|
||||||
|
<para>
|
||||||
|
You can find information on how to install and setup pg-backup-api in
|
||||||
|
<ulink url="https://www.enterprisedb.com/docs/supported-open-source/barman/pg-backup-api/">the pg-backup-api
|
||||||
|
documentation</ulink>.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
<para>
|
||||||
|
This mode (`pg-backupapi`) was introduced in v5.4.0 as a way to further integrate with Barman letting Barman
|
||||||
|
handle the restore. This also reduces the ssh keys that need to share between the backup and postgres nodes.
|
||||||
|
As long as you have access to the API service by HTTP calls, you could perform recoveries right away.
|
||||||
|
You just need to instruct Barman through the API which backup you need and on which node the backup needs to
|
||||||
|
to be restored on.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
<para>
|
||||||
|
In order to enable <literal>pg_backupapi mode</literal> support for <command>repmgr standby clone</command>,
|
||||||
|
you need the following lines in repmgr.conf:
|
||||||
|
<itemizedlist spacing="compact" mark="bullet">
|
||||||
|
<listitem><para>pg_backupapi_host: Where pg-backup-api is hosted</para></listitem>
|
||||||
|
<listitem><para>pg_backupapi_node_name: Name of the server as understood by Barman</para></listitem>
|
||||||
|
<listitem><para>pg_backupapi_remote_ssh_command: How Barman will be connecting as to the node</para></listitem>
|
||||||
|
<listitem><para>pg_backupapi_backup_id: ID of the existing backup you need to restore</para></listitem>
|
||||||
|
</itemizedlist>
|
||||||
|
|
||||||
|
This is an example of how repmgr.conf would look like:
|
||||||
|
|
||||||
|
<programlisting>
|
||||||
|
pg_backupapi_host = '192.168.122.154'
|
||||||
|
pg_backupapi_node_name = 'burrito'
|
||||||
|
pg_backupapi_remote_ssh_command = 'ssh john_doe@192.168.122.1'
|
||||||
|
pg_backupapi_backup_id = '20230223T093201'
|
||||||
|
</programlisting>
|
||||||
|
</para>
|
||||||
|
|
||||||
|
<para>
|
||||||
|
<literal>pg_backupapi_host</literal> is the variable name that enables this mode, and when you set it,
|
||||||
|
all the rest of the above variables are required. Also, remember that this service is just an interface
|
||||||
|
between Barman and repmgr, hence if something fails during a recovery, you should check Barman's logs upon
|
||||||
|
why the process couldn't finish properly.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
<note>
|
||||||
|
<simpara>
|
||||||
|
Despite in Barman you can define shortcuts like "lastest" or "oldest", they are not supported for the
|
||||||
|
time being in pg-backup-api. These shortcuts will be supported in a future release.
|
||||||
|
</simpara>
|
||||||
|
</note>
|
||||||
|
|
||||||
|
<para>
|
||||||
|
This is a real example of repmgr's output cloning with the API. Note that during this operation, we stopped
|
||||||
|
the service for a little while and repmgr had to retry but that doesn't affect the final outcome. The primary
|
||||||
|
is listening on localhost's port 6001:
|
||||||
|
|
||||||
|
<programlisting>
|
||||||
|
$ repmgr -f ~/nodes/node_3/repmgr.conf standby clone -U repmgr -p 6001 -h localhost
|
||||||
|
NOTICE: destination directory "/home/mario/nodes/node_3/data" provided
|
||||||
|
INFO: Attempting to use `pg_backupapi` new restore mode
|
||||||
|
INFO: connecting to source node
|
||||||
|
DETAIL: connection string is: user=repmgr port=6001 host=localhost
|
||||||
|
DETAIL: current installation size is 8541 MB
|
||||||
|
DEBUG: 1 node records returned by source node
|
||||||
|
DEBUG: connecting to: "user=repmgr dbname=repmgr host=localhost port=6001 connect_timeout=2 fallback_application_name=repmgr options=-csearch_path="
|
||||||
|
DEBUG: upstream_node_id determined as 1
|
||||||
|
INFO: Attempting to use `pg_backupapi` new restore mode
|
||||||
|
INFO: replication slot usage not requested; no replication slot will be set up for this standby
|
||||||
|
NOTICE: starting backup (using pg_backupapi)...
|
||||||
|
INFO: Success creating the task: operation id '20230309T150647'
|
||||||
|
INFO: status IN_PROGRESS
|
||||||
|
INFO: status IN_PROGRESS
|
||||||
|
Incorrect reply received for that operation ID.
|
||||||
|
INFO: Retrying...
|
||||||
|
INFO: status IN_PROGRESS
|
||||||
|
INFO: status IN_PROGRESS
|
||||||
|
INFO: status IN_PROGRESS
|
||||||
|
INFO: status IN_PROGRESS
|
||||||
|
INFO: status IN_PROGRESS
|
||||||
|
INFO: status IN_PROGRESS
|
||||||
|
INFO: status IN_PROGRESS
|
||||||
|
INFO: status IN_PROGRESS
|
||||||
|
INFO: status IN_PROGRESS
|
||||||
|
INFO: status IN_PROGRESS
|
||||||
|
INFO: status IN_PROGRESS
|
||||||
|
INFO: status IN_PROGRESS
|
||||||
|
INFO: status IN_PROGRESS
|
||||||
|
INFO: status IN_PROGRESS
|
||||||
|
INFO: status IN_PROGRESS
|
||||||
|
INFO: status DONE
|
||||||
|
NOTICE: standby clone (from pg_backupapi) complete
|
||||||
|
NOTICE: you can now start your PostgreSQL server
|
||||||
|
HINT: for example: pg_ctl -D /home/mario/nodes/node_3/data start
|
||||||
|
HINT: after starting the server, you need to register this standby with "repmgr standby register"
|
||||||
|
</programlisting>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
</sect2> <!--END cloning-from-barman-pg_backupapi-mode !-->
|
||||||
</sect1>
|
</sect1>
|
||||||
|
|
||||||
<sect1 id="cloning-replication-slots" xreflabel="Cloning and replication slots">
|
<sect1 id="cloning-replication-slots" xreflabel="Cloning and replication slots">
|
||||||
|
|||||||
@@ -10,8 +10,8 @@
|
|||||||
<note>
|
<note>
|
||||||
<simpara>
|
<simpara>
|
||||||
This section documents a subset of optional configuration settings; for a full
|
This section documents a subset of optional configuration settings; for a full
|
||||||
for a full and annotated view of all configuration options see the
|
and annotated view of all configuration options see the
|
||||||
see the <ulink url="https://raw.githubusercontent.com/EnterpriseDB/repmgr/master/repmgr.conf.sample">sample repmgr.conf file</ulink>
|
<ulink url="https://raw.githubusercontent.com/EnterpriseDB/repmgr/master/repmgr.conf.sample">sample repmgr.conf file</ulink>
|
||||||
</simpara>
|
</simpara>
|
||||||
</note>
|
</note>
|
||||||
|
|
||||||
|
|||||||
@@ -2394,6 +2394,17 @@ monitor_streaming_witness(void)
|
|||||||
terminate(ERR_BAD_CONFIG);
|
terminate(ERR_BAD_CONFIG);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* It's possible that the primary changed while the witness repmgrd was not
|
||||||
|
* running. This does not affect the functionality of the witness repmgrd, but
|
||||||
|
* does mean outdated node metadata will be displayed, so update that.
|
||||||
|
*/
|
||||||
|
if (local_node_info.upstream_node_id != primary_node_id)
|
||||||
|
{
|
||||||
|
update_node_record_set_upstream(primary_conn, local_node_info.node_id, primary_node_id);
|
||||||
|
local_node_info.upstream_node_id = primary_node_id;
|
||||||
|
}
|
||||||
|
|
||||||
initPQExpBuffer(&event_details);
|
initPQExpBuffer(&event_details);
|
||||||
|
|
||||||
appendPQExpBuffer(&event_details,
|
appendPQExpBuffer(&event_details,
|
||||||
|
|||||||
Reference in New Issue
Block a user