HAProxy + pgbouncer服务器意外关闭了连接

时间:2016-11-23 10:54:23

标签: postgresql haproxy pgbouncer

我在Web服务器上有一个haproxy架构,它正在路由到从属服务器,我在postgre上有pgbouncer。 HAPoxy配置:

global
    log 127.0.0.1 local1 debug
    user haproxy
    group haproxy

defaults
    log global
    retries 3
    timeout connect 1s
    timeout server 20m
    timeout client 20m

listen pgsql-cluster
    bind 127.0.0.1:5433
    mode tcp
    balance leastconn
    #option pgsql-check user postgres - 
    default-server inter 1s downinter 1s rise 2 fall 1
    server pgsql-1 10.5.8.14:6432 check
    server pgsql-2 10.5.8.21:6432 check

Pgbouncer配置是默认配置。 第一个问题,pgsql-check不起作用。 pgboucer.log:

2016-11-23 12:47:37.805 17068 WARNING C-0x23bb760: (nodb)/(nouser)@10.5.8.13:48898 Pooler Error: No such database: postgres
2016-11-23 12:47:37.805 17068 LOG C-0x23bb760: (nodb)/(nouser)@10.5.8.13:48898 login failed: db=postgres user=postgres

但最大的问题是,经过一段时间后,我的网站出现了很多错误(Yii2)。经度:

2016-11-22 16:37:42 [10.5.33.135][-][-][error][application] SQLSTATE[08006] [7] server closed the connection unexpectedly
This probably means the server terminated abnormally
before or while processing the request. in file /var/www/copy-search/vendor/yiisoft/yii2/db/Connection.php on line 547

我有这样的感觉,haproxy刚刚打破会议。

1 个答案:

答案 0 :(得分:0)

要回答第一个问题,请确保在PG Bouncer配置中定义了名为postgres的用户。我目前有HA代理设置来在两个PG Bouncer进程之间分配负载,并在我的配置中定义了postgres用户和postgres数据库,并且运行状况检查工作正常。至于第二个问题,我目前得到同样的错误。

更新

我增加了HA代理的超时时间,这解决了我的问题。

listen pgsql-cluster
   bind 127.0.0.1:5433
   mode tcp
   balance leastconn
   timeout client 30h
   timeout server 30h
   #option pgsql-check user postgres - 
   default-server inter 1s downinter 1s rise 2 fall 1
   server pgsql-1 10.5.8.14:6432 check
   server pgsql-2 10.5.8.21:6432 check