Обсуждение: Re: Request for Feedback on PostgreSQL HA + Load Balancing Architecture

Поиск
Список
Период
Сортировка

Re: Request for Feedback on PostgreSQL HA + Load Balancing Architecture

От
Achilleas Mantzios
Дата:

On 6/18/25 18:12, vijay patil wrote:

Hi Team,

I am planning to implement a PostgreSQL High Availability (HA) and Load Balancing setup and would greatly appreciate your feedback on the architecture we've designed (see attached diagram).image.png

Overview of the Setup:

  • Two PostgreSQL nodes (VM1 and VM2) configured with:

    • Asynchronous replication from the Primary DB (on VM1) to the Standby DB (on VM2) using repmgr

    • HAProxy for failover management:

      • HAProxy 1 (active) on VM1

      • HAProxy 2 (passive) on VM2 with Keepalive for heartbeat and failover detection

    • PgBouncer on both nodes for connection pooling

  • A Virtual IP (VIP) managed by HAProxy for routing traffic from the application

  • Read/Write operations go to the Primary DB, and Read-Only queries can be served from either node

Objectives:

  • Ensure high availability with automatic failover

  • Enable basic load balancing for read-only queries

  • Maintain connection pooling and routing efficiency

Request for Feedback:

  • Is this architecture considered a best practice within the PostgreSQL community?

  • Are there any potential bottlenecks or failure points I should be aware of?

  • Would you recommend any improvements or alternative tools for achieving better reliability and performance?

Personally I will test long run via app -> pgbouncer -> pgpool-ii in order to combine :

* Query Routing (read/write automatic split)

* Load Balancing

* High Availability

* Query caching

Have you consider pgpool-ii ?  I know most support / service companies push for patroni, and manually separating read / write traffic from within the app, but I still find pgpool's query routing very nice.


Thanks 

Vijay 

Вложения

Re: Request for Feedback on PostgreSQL HA + Load Balancing Architecture

От
Jehan-Guillaume de Rorthais
Дата:
On Wed, 23 Jul 2025 12:13:26 +0100
Achilleas Mantzios <a.mantzios@cloud.gatewaynet.com> wrote:
…
> Have you consider pgpool-ii ?  I know most support / service companies
> push for patroni, and manually separating read / write traffic from
> within the app,

Indeed

> but I still find pgpool's query routing very nice.

Using Pgpool for HA is a no go in my opinion. Pgpool HA requires the
DBA/sysadmin to deal alone with the real high availability challenges. Pgpool
doesn't handle the HA complexity itself, it stays quite "naive". It requires the
sysadmin/DBA to mess with the complexity to keep the cluster safe from
corruption. In other word, implement the HA safety stack in bash yourself. This
is partly true for repmgr as well last time I checked.

Don't implement Patroni or Pacemaker yourself in a collection of "action
scripts" triggered by a naive HA stack. Some people tried, some clusters has
been corrupted.

Pgpool for routing and/or pooling is an acceptable solution. Of course, it comes
with its drawbacks and some inefficiences, that's why most support/service
companies avoid it when possible. But depending on the context, it could be OK.

Regards,