Creating PGD nodes v5
Depending on your selected deployment method, you may or may not have to create PGD nodes manually. For example, if you are using TPA or the EDB Postgres Distributed for Kubernetes, the nodes are created automatically. But if you are manually deploying PGD or creating your own deployment method, you need to know how to create and configure a PGD node.
It's just Postgres
A PGD node is just a Postgres instance with the BDR extension installed. The BDR extension enables bidirectional replication between nodes and is the foundation of PGD.
That means, in the most general terms, you can create a PGD node by installing Postgres and the BDR extension, and then configuring the node to connect to the other nodes in the PGD group. But there are some specifics to consider.
Which Postgres version?
PGD is built on top of Postgres, so the distribution and version of Postgres you use for your PGD nodes is important. The version of Postgres you use must be compatible with the version of PGD you are using. You can find the compatibility matrix in the release notes. Features and functionality in PGD may depend on the distribution of Postgres you are using. The EDB Postgres Advanced Server is the recommended distribution for PGD. PGD also supports EDB Postgres Extended Server and Community Postgres. You can find out what features are available in each distribution in the Planning section's Choosing a server page.
Installing Postgres
You must install your selected Postgres distribution on each node you are configuring. You can find installation instructions for each distribution in the EDB Postgres Advanced Server documentation, EDB Postgres Extended Server documentation, and the Postgres installation documentation. You can also refer to the PGD manual installation guide which covers the installation of Postgres.
Installing the BDR extension
The BDR extension is the key to PGD's distributed architecture. You need to install the BDR extension on each node in your PGD cluster. The BDR extension is available from the EDB Postgres Distributed repository. You need to add the postgres_distributed
repository to your package management system on Linux and then install the edb-bdr
package. You can find the repository configuration instructions in the PGD manual installation guide.
Once the repository is configured, you can install the BDR package with your package manager. The package name is edb-bdr5-<postgresversion>
where <postgresversion>
is the version of Postgres you are using. For example, if you are using Postgres 13, the package name is edb-bdr5-13
.
Configuring the database for PGD
This process is specific to PGD and involves configuring the Postgres instance to work with the BDR extension and adjusting various settings to work with the PGD cluster. This process is also detailed in the PGD manual installation guide The steps are as follows:
- Add the BDR extension
$libdir/bdr
at the start of theshared_preload_libraries
setting inpostgresql.conf
. - Set the
wal_level
GUC variable tological
inpostgresql.conf
. - Turn on commit timestamp tracking by setting
track_commit_timestamp
to'on'
inpostgresql.conf
. - Increase the maximum worker processes to 16 or higher by setting
max_worker_processes
to'16'
inpostgresql.conf
.The
max_worker_processes
valueThe
max_worker_processes
value is derived from the topology of the cluster, the number of peers, number of databases, and other factors. To calculate the needed value, see Postgres configuration/settings. The value of 16 was calculated for the size of cluster being deployed in this example. It must be increased for larger clusters. - Set a password on the EnterprisedDB/Postgres user.
- Add rules to
pg_hba.conf
to allow nodes to connect to each other.- Ensure that these lines are present in
pg_hba.conf
:
- Ensure that these lines are present in
- Add a
.pgpass
file to allow nodes to authenticate each other.- Configure a user with sufficient privileges to log in to the other nodes.
- See The Password File in the Postgres documentation for more on the
.pgpass
file.
Once these steps are complete, restart the Postgres instance to apply the changes.
Initializing a PGD node
Log into the database instance you have configured and set up the BDR extension.
You can do this by running the CREATE EXTENSION bdr;
command as super user in the database.
This command creates the BDR extension.
You also need to create a database within Postgres to use as PGD's replicated database.
You can do this with the CREATE DATABASE
command.
The created database should be the name of the database that other nodes in the PGD cluster replicate. The convention is to name the database bdrdb
.
Next steps
The node is now configured and ready to be join a group, or start a group, in the PGD cluster.